Django通过dwebsocket实现websocket 消息推送

Django通过dwebsocket实现websocket 消息推送

django实现websocket大致上有两种方式,一种channels,一种是dwebsocket。channels依赖于redis,twisted等,相比之下使用dwebsocket要更为方便一些 。

之前我们有解释过Django使用channels实现websocket的方法,这里我们就不做多的介绍,有需要的可以来看看:Django使用channels实现websocket消息通知

下面我们为大家介绍一下Django通过的websocket实现消息推送的过程。

使用方法1:
只需views.py文件中,将对应的视图函数添加装饰器

accept_websocket-—可以接受websocket请求和普通http请求
require_websocket—-只接受websocket请求,拒绝普通http请求

from dwebsocket.decorators import accept_websocket,require_websocket

@accept_websocket
def test_websocket(request):
    if request.is_websocket():
        while 1:
            time.sleep(1) ## 向前端发送时间
            dit = {
                'time':time.strftime('%Y.%m.%d %H:%M:%S',time.localtime(time.time()))
            }
            request.websocket.send(json.dumps(dit))

使用方法2:

使用中间件
步骤:
1. settings.py文件中,添加如下信息

import dwebsocket
# 为所有的URL提供websocket,如果只是单独的视图需要可以不选
MIDDLEWARE_CLASSES=['dwebsocket.middleware.WebSocketMiddleware']

WEBSOCKET_ACCEPT_ALL=True  # 可以允许每一个单独的视图实用websockets

官方说明:做了如上配置,仍然会拒绝普通视图的websockets。所以必须在视图上设置’ accept_websocket ’ ‘属性来允许websockets,所以继续做如下配置。

2. views.py文件中,相关视图添加装饰器

from dwebsocket.decorators import accept_websocket,require_websocket

@accept_websocket
def test_websocket(request):
    if request.is_websocket():
        while 1:
            time.sleep(1) ## 向前端发送时间
            dit = {
                'time':time.strftime('%Y.%m.%d %H:%M:%S',time.localtime(time.time()))
            }
            request.websocket.send(json.dumps(dit))

看起来跟方法一没什么区别,还多了一步settings配置,但是区别在哪呢???
官方是这么说的:These attributes are always available if you use the middleware
翻译过来就是,如果使用中间件,有以下这下方法可用:

request.is_websocket()  #websocket请求返回True,普通请求返回False
request.websocket  # websocket建立连接后,request将有websocket提供的相关api属性,如果没有建立连接则是None
WebSocket.wait()  # 阻塞接收消息
WebSocket.read()  # 非阻塞接收消息
WebSocket.count_messages()  #返回队列中的消息数量
WebSocket.has_messages()  # 有消息返回True,反之False
WebSocket.send(message)  # 发送消息
WebSocket.__iter__()  # 当迭代器使用

————————————————
版权声明:本文为CSDN博主「花姐毛毛腿」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_39726347/article/details/88045752

Comments are closed.