您好,登錄后才能下訂單哦!
Django通過dwebsocket實現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__() # 當迭代器使用
關于Django通過dwebsocket實現websocket問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。