Каналы Django - Не найдено: /ws/stock/track/

Я следую этому видео, но я не получаю такой же вывод консоли, как в видео.

Мой консольный вывод:

[20/Feb/2024 19:09:12] "GET /stocktracker/?stockpicker=AAPL&stockpicker=AMGN HTTP/1.1" 200 6449
Not Found: /ws/stock/track/
[20/Feb/2024 19:09:12] "GET /ws/stock/track/?stockpicker=AAPL&stockpicker=AMGN HTTP/1.1" 404 2613

Вывод консоли на локальном сайте (с помощью py manage.py runserver):

stockpicker=AAPL&stockpicker=AMGN

stocktracker/?stockpicker=AAPL&stockpicker=AMGN:176 WebSocket connection to 'ws://127.0.0.1:8000/ws/stock/track/?stockpicker=AAPL&stockpicker=AMGN' failed: 
(anonymous) @ stocktracker/?stockpicker=AAPL&stockpicker=AMGN:176

asgi.py:

"""
ASGI config for backend project.

It exposes the ASGI callable as a module-level variable named ``application``.

For more information on this file, see
https://docs.djangoproject.com/en/5.0/howto/deployment/asgi/
"""

import os

from channels.routing import ProtocolTypeRouter, URLRouter
from django.core.asgi import get_asgi_application
from channels.auth import AuthMiddlewareStack
from Tradingapp.routing import websocket_urlpatterns

os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'mysite.settings')
# Initialize Django ASGI application early to ensure the AppRegistry
# is populated before importing code that may import ORM models.
django_asgi_app = get_asgi_application()

application = ProtocolTypeRouter({
    "http": django_asgi_app,
    # Just HTTP for now. (We can add other protocols later.)
    "websocket": AuthMiddlewareStack(
      URLRouter(
        websocket_urlpatterns
      )
    )
})

routing.py:

from django.urls import re_path

from . import consumers

websocket_urlpatterns = [
    # Celery data is sent to a "group" and this group has multiple users
    #to listen for the same thing via websockets
    re_path(r'ws/stock/(?P<room_name>\w+)/$', consumers.StockConsumer.as_asgi()),
]

JS-соединение:

    const roomName = JSON.parse(document.getElementById('room-name').textContent)
    var queryString = window.location.search
    queryString = queryString.substring(1)
    console.log(queryString)
    const stockSocket = new WebSocket('ws://' + window.location.host + '/ws/stock/' + roomName + '/' + '?' + queryString)

consumers.py:

import json

from channels.generic.websocket import AsyncWebsocketConsumer


class StockConsumer(AsyncWebsocketConsumer):
    async def connect(self):
        self.room_name = self.scope["url_route"]["kwargs"]["room_name"]
        self.room_group_name = f"stock_{self.room_name}"

        # Join room group
        await self.channel_layer.group_add(self.room_group_name, self.channel_name)

        await self.accept()

    async def disconnect(self, close_code):
        # Leave room group
        await self.channel_layer.group_discard(self.room_group_name, self.channel_name)

    # Receive message from WebSocket
    async def receive(self, text_data):
        text_data_json = json.loads(text_data)
        message = text_data_json["message"]

        # Send message to room group
        await self.channel_layer.group_send(
            self.room_group_name, {"type": "stock_update", "message": message}
        )

    # Receive message from room group
    async def stock_update(self, event):
        message = event["message"]

        # Send message to WebSocket
        await self.send(text_data=json.dumps({"message": message}))

CHANNEL_LAYERS в settings.py:

CHANNEL_LAYERS = {
    "default": {
        "BACKEND": "channels_redis.core.RedisChannelLayer",
        "CONFIG": {
            "hosts": [("127.0.0.1", 6379)],
        },
    },
}

Я просмотрел другие вопросы в stack overflow, например этот, но не нашел решения, которое помогло бы мне

Я спросил в Django discord, и добрый человек по имени Ваарун помог мне с моей проблемой; я не установил Daphne в моих установленных приложениях.

Не работает

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'Tradingapp',
    'corsheaders',
    'rest_framework',
    'django_celery_results',
    'django_celery_beat',
    'channels',
]

Работает

INSTALLED_APPS = [
    'daphne',
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'Tradingapp',
    'corsheaders',
    'rest_framework',
    'django_celery_results',
    'django_celery_beat',
    'channels',
]

Не забудьте также запустить pip install daphne.

Вернуться на верх