Django通過dwebsocket實現websocket的例子
阿新 • • 發佈:2020-01-09
與django推薦的channel不同,dwebsocket使用更加方便簡單
使用方法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__() # 當迭代器使用
官方連結
以上這篇Django通過dwebsocket實現websocket的例子就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。