注明
本笔记主要参考《Django应用开发实战》《Django企业开发实战》,这两本书前者详细,后者精炼。学习之后真的是感觉自己进步了很多。值得一读,如果您遇到了值得一读的书籍,欢迎推荐给我,大家共同进步。
@[TOC](文章目录)
前言
Web聊天室的实现方法有多种,下面将简要介绍一下实现方法
- AJAX技术利用AJAX实现网页与服务器的无刷新交互。缺点是实时性不高。
- Coment技术Coment是一种Web应用框架,服务器以异步方式向浏览器推送数据,无需浏览器发送请求,非常适合事件驱动的Web应用,以及对交互性和实时性要求较高的应用。
- XMPP协议:可扩展消息处理协议,专为及时通信系统设计的通信协议,用于即时消息以及在线探测
- Flash的XmlSocket:Flash Media Server 是一个强大的流媒体服务器,它基于RTMP协议,提供了稳定的流媒体交互功能,内置远程共享对象的机制,是浏览器创建并连接服务器的远程共享
- websocket协议:WebSocket是一种在单个TCP连接上进行全双工通信的协议WebSocket使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送数据。在WebSocket
API中,浏览器和服务器只需要完成一次握手,两者之间就直接可以创建持久性的连接,并进行双向数据传输
django实现websocket大致上有两种方式,一种channels,一种是dwebsocket。channels依赖于redis,twisted等
提示:以下是本篇文章正文内容,下面案例可供参考
一、Channels?
Channels安装与配置
pip install channels
pip channels_redis
pip install pypiwin32
settings配置
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'channels', # 添加channels功能
'chat',
]
ASGI_APPLICATION = '项目名.routing.application'
CHANNEL_LAYERS = {
'default': {
'BACKEND': 'channels_redis.core.RedisChannelLayer',
'CONFIG': {
"hosts": [('127.0.0.1', 6379)],
},
},
}
说明:
- CHANNEL_LAYERS用于设置Redis数据库的连接方式.
- ASGI_APPLICATION:代表routing.py定义的application对象。
项目名文件夹下定义routing.py
from channels.routing import ProtocolTypeRouter
from channels.routing import URLRouter
from .urls import websocket_urlpatterns
application = ProtocolTypeRouter({
# (http->django views is added by default)
'websocket': AuthMiddlewareStack(
URLRouter(
websocket_urlpatterns
)
),
})
说明:
定义这个文件是为了响应ASGI_APPLICATION定义application对象,将Django与该插件建立连接。
在项目名文件夹下urls.py,定义websocket_urlpatterns
from django.urls import path, include
from .consumers import ChatConsumer
urlpatterns = [
path('', include(('chat.urls', 'chat'), namespace='chat'))
]
websocket_urlpatterns