django使用websocket
WebSocket协议是基于TCP的一种新的协议。WebSocket最初在HTML5规范中被引用为TCP连接,作为基于TCP的套接字API的占位符。它实现了浏览器与服务器全双工(full-duplex)通信。其本质是保持TCP连接,在浏览器和服务端通过Socket进行通信。
django 使用websocket需要安装channels
pip3 install channels==2.3 -i https://pypi.tuna.tsinghua.edu.cn/simple
创建django项目
在settings.py里注册channels
INSTALLED_APPS = [ ‘django.contrib.admin‘, ‘django.contrib.auth‘, ‘django.contrib.contenttypes‘, ‘django.contrib.sessions‘, ‘django.contrib.messages‘, ‘django.contrib.staticfiles‘, ‘app01.apps.App01Config‘, # 项目中要使用channels做websocket了. "channels", ]
本质: channels会把原来只支持http协议的wsgi,换成支持http和websocket协议的asgi
配置application
# settings.py INSTALLED_APPS = [ ‘django.contrib.admin‘, ‘django.contrib.auth‘, ‘django.contrib.contenttypes‘, ‘django.contrib.sessions‘, ‘django.contrib.messages‘, ‘django.contrib.staticfiles‘, ‘app01.apps.App01Config‘, # 项目中要使用channels做websocket了. "channels", ] ASGI_APPLICATION = "channel_demo.routing.application"
# channel_demo/routing.py(新建routing.py文件) from channels.routing import ProtocolTypeRouter, URLRouterfrom django.conf.urls import urlfrom app01 import consumersapplication = ProtocolTypeRouter({ ‘websocket‘: URLRouter([ url(r‘^chat/$‘, consumers.ChatConsumer), ])})
app下建立consumers文件
和view文件功能一样,专门处理websocket请求
from channels.generic.websocket import WebsocketConsumer from channels.exceptions import StopConsumer CONSUMER_OBJECT_LIST = [] class ChatConsumer(WebsocketConsumer): def websocket_connect(self, message): """ 客户端发来连接请求之后就会被触发 :param message: :return: """ # 服务端接收连接,向客户端浏览器发送一个加密字符串 self.accept() # 连接成功 CONSUMER_OBJECT_LIST.append(self) def websocket_receive(self, message): """ 客户端浏览器向服务端发送消息,此方法自动触发 :param message: :return: """ # 服务端给客户端回一条消息 # self.send(text_data=message[‘text‘]) for obj in CONSUMER_OBJECT_LIST: obj.send(text_data=message[‘text‘]) def websocket_disconnect(self, message): """ 客户端主动断开连接 :param message: :return: """ # 服务端断开连接 CONSUMER_OBJECT_LIST.remove(self) raise StopConsumer()