django使用channels实现webSocket启动失败

问题描述

使用channels启动ASGI结果却是普通启动,如下:

python 复制代码
Watching for file changes with StatReloader
Performing system checks...

System check identified no issues (0 silenced).
July 15, 2023 - 18:23:49
Django version 4.2, using settings 'staffSystem_django.settings'
Starting development server at http://127.0.0.1:8000/
Quit the server with CONTROL-C.

我希望得到的启动方式如下:

python 复制代码
System check identified no issues (0 silenced).
July 15, 2023 - 18:23:49
Django version 4.2, using settings 'staffSystem_django.settings'
Starting ASGI/Channels version 3.0.1 development server at http://127.0.0.1:8000/
Quit the server with CTRL-BREAK.

setting.py:

python 复制代码
INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'channels',
    'app01.apps.App01Config',
]


ASGI_APPLICATION = 'staffSystem_django.asgi.application'

asgi.py:

python 复制代码
import os

from django.core.asgi import get_asgi_application
from channels.routing import ProtocolTypeRouter, URLRouter
from . import routing

os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'staffSystem_django.settings')

# application = get_asgi_application()

application = ProtocolTypeRouter({
    'http': get_asgi_application(),
    'websocket': URLRouter(routing.websocket_urlpatterns)
})

我打断点就拦不到,甚至ASGI_APPLICATION='' 都不报错。


原因分析:

盲猜是版本问题,查不到一个官方解释。人类疑惑高版本咋会失去低版本有的实用功能~

简直是人类迷惑,如果直接使用pip install channels 的话会自动下载比较高的版本(我下载的4.0.1 的版本),所以在注册channels的时候,Django的settings.py中ASGI_APPLICATION 没有被配置识别,使得总是在使用WSGI_APPLICATION 中的配置,我还以为是WSGI_APPLICATION 影响了,但是注释掉也不用ASGI_APPLICATION 。然后还不会报错,简直无语到家。我甚至还看见有另一个叫做django-channels,下载注册app后也没有卵用。


解决方案:

下载低版本

第一次尝试,我下载了2.3.0

python 复制代码
pip install channels==2.3.0

重新启动django程序,终于报错,看到报错是真开心不会一脸懵逼了。

报错提示信息说没有as_asgi() 这个函数。这个函数是我在安装channels=4.0.1 时写代码类名点出来的不是直接写出来的,证明父类 是一定有这个函数。我点进下载2.3.0后的源码查看确实没有这个函数,那就证明是后来才有这个函数。

第二次尝试,下载3.0.1,这次就成功了!!!

python 复制代码
pip install channels==3.0.1

启动django程序

python 复制代码
System check identified no issues (0 silenced).
July 15, 2023 - 18:17:31
Django version 4.2, using settings 'staffSystem_django.settings'
Starting ASGI/Channels version 3.0.1 development server at http://127.0.0.1:8000/
Quit the server with CTRL-BREAK.

看到Starting ASGI/Channels 就是成功了。

再发送一个ws请求试试看,可以看到握手与连接的请求成功收到并返回

看看浏览器抓包,可以看到黄色方框的http 请求成功,红色方框的websocket 请求也是建立连接成功。

相关推荐
喜欢猪猪15 分钟前
Java技术专家视角解读:SQL优化与批处理在大数据处理中的应用及原理
android·python·adb
海绵波波10717 分钟前
flask后端开发(1):第一个Flask项目
后端·python·flask
林的快手22 分钟前
209.长度最小的子数组
java·数据结构·数据库·python·算法·leetcode
从以前37 分钟前
准备考试:解决大学入学考试问题
数据结构·python·算法
Ven%1 小时前
如何修改pip全局缓存位置和全局安装包存放路径
人工智能·python·深度学习·缓存·自然语言处理·pip
枫欢1 小时前
将现有环境192.168.1.100中的svn迁移至新服务器192.168.1.4;
服务器·python·svn
测试杂货铺1 小时前
UI自动化测试实战实例
自动化测试·软件测试·python·selenium·测试工具·测试用例·pytest
等一场春雨2 小时前
springboot 3 websocket react 系统提示,选手实时数据更新监控
spring boot·websocket·react.js
余~~185381628002 小时前
NFC 碰一碰发视频源码搭建技术详解,支持OEM
开发语言·人工智能·python·音视频
却道天凉_好个秋2 小时前
音视频学习(二十八):websocket-flv
websocket·音视频·flv