色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Django中如何使用Channels功能

瀏覽:12日期:2024-11-25 11:27:40
目錄一、什么是WebSocket二、什么是Channels三、Django中使用Channel四、前端Websocket使用五、測(cè)試Channels功能

前言:最近后臺(tái)寫(xiě)游戲更新版本功能,簡(jiǎn)單就是前端發(fā)送更新請(qǐng)求,后端需要對(duì)很多臺(tái)服務(wù)器進(jìn)行更新和各種操作,本來(lái)想著實(shí)現(xiàn)不難,后來(lái)發(fā)現(xiàn)因?yàn)楹蠖诵枰獔?zhí)行很長(zhǎng)時(shí)間,前端返回報(bào)錯(cuò),后端會(huì)執(zhí)行完畢,但是前端先斷開(kāi)了,這樣在前端頁(yè)面我就看不到更新結(jié)果了。通過(guò)調(diào)整nginx參數(shù),設(shè)置超時(shí)時(shí)間,還是日志會(huì)報(bào)499狀態(tài)碼錯(cuò)誤。后來(lái)了解到了websocket,對(duì)于需要長(zhǎng)時(shí)間處理的請(qǐng)求,使用websocket會(huì)更好,通過(guò)使用websocket實(shí)現(xiàn)了自己的功能,簡(jiǎn)單分享下

一、什么是WebSocket

WebSocket是一種在單個(gè)TCP連接上進(jìn)行全雙工通訊的協(xié)議。WebSocket允許服務(wù)端主動(dòng)向客戶端推送數(shù)據(jù)。在WebSocket協(xié)議中,客戶端瀏覽器和服務(wù)器只需要完成一次握手就可以創(chuàng)建持久性的連接,并在瀏覽器和服務(wù)器之間進(jìn)行雙向的數(shù)據(jù)傳輸。

WebSocket的響應(yīng)頭中重要的字段:HTTP/1.1 101 Swi tching Protocols:切換協(xié)議,WebSocket協(xié)議通過(guò)HTTP協(xié)議來(lái)建立運(yùn)輸層的TCP連接Connection和Upgrade:表示服務(wù)端發(fā)起的WebSocket響應(yīng)Sec-WebSocket-Accept:表示服務(wù)器接受了客戶端的請(qǐng)求,由Sec-WebSocket-Key計(jì)算得來(lái)

WebSocket協(xié)議的優(yōu)點(diǎn):支持雙向通信,實(shí)時(shí)性更強(qiáng)數(shù)據(jù)格式比較輕量,性能開(kāi)銷(xiāo)小,通信高效支持?jǐn)U展,用戶可以擴(kuò)展協(xié)議或者實(shí)現(xiàn)自定義的子協(xié)議(比如支持自定義壓縮算法等)

WebSocket協(xié)議的缺點(diǎn):少部分瀏覽器不支持,瀏覽器支持的程度與方式有區(qū)別長(zhǎng)連接對(duì)后端處理業(yè)務(wù)的代碼穩(wěn)定性要求更高,后端推送功能相對(duì)復(fù)雜成熟的HTTP生態(tài)下有大量的組件可以復(fù)用,WebSocket較少

WebSocket的應(yīng)用場(chǎng)景:即時(shí)聊天通信,網(wǎng)站消息通知在線協(xié)同編輯,如騰訊文檔多玩家在線游戲,視頻彈幕,股票基金實(shí)施報(bào)價(jià)

二、什么是Channels

Django本身不支持WebSocket,但可以通過(guò)集成Channels框架來(lái)實(shí)現(xiàn)WebSocketChannels是針對(duì)Django項(xiàng)目的一個(gè)增強(qiáng)框架,可以使Django不僅支持HTTP協(xié)議,還能支持WebSocket,MQTT等多種協(xié)議,同時(shí)Channels還整合了Django的auth以及session系統(tǒng)方便進(jìn)行用戶管理及認(rèn)證。

2.1channels文件和配置的含義

asgi.py:介于網(wǎng)絡(luò)協(xié)議服務(wù)和Python應(yīng)用之間的接口,能夠處理多種通用協(xié)議類(lèi)型,包括HTTP、HTTP2和WebSocketchannel_layers:在settings.py中配置。類(lèi)似于一個(gè)通道,發(fā)送者(producer)在一段發(fā)送消息,消費(fèi)者(consumer)在另一端進(jìn)行監(jiān)聽(tīng)routings.py:相當(dāng)于Django中的urls.pyconsumers.py:相當(dāng)于Django中的views.py

2.2channels文檔鏈接

https://channels.readthedocs.io/en/latest/introduction.html

2.3.WSGI和ASGI不同

WSGI(Python Web Server Gateway Interface):為Python語(yǔ)言定義的Web服務(wù)器和Web應(yīng)用程序或者框架之間的一種簡(jiǎn)單而通用的接口。

ASGI(Asynchronous Web Server Gateway Interface):異步網(wǎng)關(guān)協(xié)議接口,一個(gè)介于網(wǎng)絡(luò)協(xié)議服務(wù)和Python應(yīng)用之間的標(biāo)準(zhǔn)接口,能夠處理多種通用的協(xié)議類(lèi)型,包括HTTP,HTTP2和WebSocket。

三、Django中使用Channel

3.1安裝channels

pip install channels==2.1.7

3.2修改setting.py文件

INSTALLED_APPS = [ ’django.contrib.staticfiles’, ... ... ’channels’,] # 指定ASGI的路由地址ASGI_APPLICATION = ’webapp.routing.application’ #ASGI_APPLICATION 指定主路由的位置為webapp下的routing.py文件中的application

3.3setting.py的同級(jí)目錄下創(chuàng)建routing.py路由文件,routing.py類(lèi)似于Django中的url.py指明websocket協(xié)議的路由

from channels.auth import AuthMiddlewareStackfrom channels.routing import ProtocolTypeRouter, URLRouterfrom channels.security.websocket import AllowedHostsOriginValidatorimport webapp.routing application = ProtocolTypeRouter({ ’websocket’:AllowedHostsOriginValidator(AuthMiddlewareStack( URLRouter(webapp.routing.websocket_urlpatterns )) )})

ProtocolTypeRouter:ASGI支持多種不同的協(xié)議,在這里可以指定特定協(xié)議的路由信息,這里只使用了websocket協(xié)議,這里只配置websocket即可AllowedHostsOriginValidator:指定允許訪問(wèn)的IP,設(shè)置后會(huì)去Django中的settings.py中去查找ALLOWED_HOSTS設(shè)置的IPAuthMiddlewareStack:用于WebSocket認(rèn)證,繼承了Cookie Middleware,SessionMiddleware,SessionMiddleware。django的channels封裝了django的auth模塊,使用這個(gè)配置我們就可以在consumer中通過(guò)下邊的代碼獲取到用戶的信息,和請(qǐng)求的url路徑

self.sc

def connect(self): self.user = self.scope['user'] self.request_url = self.scope[’path’]

ope類(lèi)似于django中的request,包含了請(qǐng)求的type、path、header、cookie、session、user等等有用的信息URLRouter: 指定路由文件的路徑,也可以直接將路由信息寫(xiě)在這里,代碼中配置了路由文件的路徑,會(huì)去對(duì)應(yīng)應(yīng)用下的routeing.py文件中查找websocket_urlpatterns

3.4webapp.routing.py內(nèi)容如下

from django.urls import pathfrom webapp.consumers import ChatConsumer websocket_urlpatterns = [path(’ws/chat/’,ChatConsumer)]

routing.py路由文件跟django的url.py功能類(lèi)似,語(yǔ)法也一樣,意思就是訪問(wèn)ws/chat/都交給ChatConsumer處理。

3.5在要使用WebSocket的應(yīng)用中創(chuàng)建consumers.py,consumers.py是用來(lái)開(kāi)發(fā)ASGI接口規(guī)范的python應(yīng)用,而Django中的view.py是用來(lái)開(kāi)發(fā)符合WSGI接口規(guī)范的python應(yīng)用。

from channels.generic.websocket import WebsocketConsumerfrom channels.generic.websocket import AsyncWebsocketConsumerimport json,time

Channels支持同步,也支持異步方式

同步方式代碼如下:

class ChatConsumer(WebsocketConsumer): # websocket建立連接時(shí)執(zhí)行方法 def connect(self):self.accept() # websocket斷開(kāi)時(shí)執(zhí)行方法 def disconnect(self, close_code):self.close() # 從websocket接收到消息時(shí)執(zhí)行函數(shù) def receive(self, text_data):text_data_json = json.loads(text_data)message = f’結(jié)果:{text_data_json}’self.send(text_data=json.dumps({ ’message’: message}))

異步方式代碼如下:

class ChatConsumer(AsyncWebsocketConsumer): #websocket建立連接時(shí)執(zhí)行方法 async def connect(self):await self.accept() # websocket斷開(kāi)時(shí)執(zhí)行方法 async def disconnect(self, close_code):print(close_code) # 從websocket接收到消息時(shí)執(zhí)行函數(shù) async def receive(self, text_data):for i in range(10): time.sleep(i) message = ’結(jié)果: ’ + str(i) await self.send(text_data=json.dumps({’message’: message }))

需要注意的是在異步中所有的邏輯都應(yīng)該是異步的,不可以那同步的和異步的代碼混合使用。

四、前端Websocket使用

WebSocket對(duì)象一個(gè)支持四個(gè)消息:onopen,onmessage,oncluse和onerror

onopen: 當(dāng)瀏覽器和websocket服務(wù)端連接成功后會(huì)觸發(fā)onopen消息onerror: 如果連接失敗,或者發(fā)送、接收數(shù)據(jù)失敗,或者數(shù)據(jù)處理出錯(cuò)都會(huì)觸發(fā)onerror消息onmessage: 當(dāng)瀏覽器接收到websocket服務(wù)器發(fā)送過(guò)來(lái)的數(shù)據(jù)時(shí),就會(huì)觸發(fā)onmessage消息,參數(shù)e包含了服務(wù)端發(fā)送過(guò)來(lái)的數(shù)據(jù)onclose: 當(dāng)瀏覽器接收到websocket服務(wù)器發(fā)送過(guò)來(lái)的關(guān)閉連接請(qǐng)求時(shí),會(huì)觸發(fā)onclose消息

拼接websocket請(qǐng)求地址,建立長(zhǎng)連接

var chatSocket = new WebSocket(’ws://’ + window.location.host + ’/ws/ver_update/’);

連接事件

chatSocket.onopen = function () { console.log(getCurrentDate(2) + ’ ’ + ’websocket connection success’)};

錯(cuò)誤事件

chatSocket.onerror = function () { console.error(getCurrentDate(2) + ’ ’ + ’websocket connection error’)};

關(guān)閉事件

chatSocket.onclose = function (e) { layer.msg(’websocket關(guān)閉,檢查錯(cuò)誤日志’, {icon: 2}); console.error(getCurrentDate(2) + ’ ’ + ’websocket closed unexpectedly 狀態(tài)碼:’ + e.code); chatSocket.close();};

接收事件

chatSocket.onmessage = function (e) { var data = JSON.parse(e.data);}五、測(cè)試Channels功能

Django中如何使用Channels功能

總結(jié):自從使用Websocket功能后,再也沒(méi)發(fā)生前端突然斷開(kāi)的情況了,對(duì)于長(zhǎng)時(shí)間運(yùn)行的任務(wù),使用websocket是不錯(cuò)的選擇~,有不足的地方請(qǐng)多多指教

到此這篇關(guān)于Django中使用Channels功能的文章就介紹到這了,更多相關(guān)Django使用Channels內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Django
相關(guān)文章:
主站蜘蛛池模板: 成人国产精品999视频 | 最新中文字幕乱码在线 | 欧美午夜不卡在线观看最新 | 国产欧美一区二区精品久久久 | 韩国欧洲一级毛片 | 毛片免费高清免费 | 国产亚洲网站 | 国产精品99r8免费视频2022 | 日韩国产成人精品视频 | 午夜手机看片 | 97视频精品| 日韩视频精品在线 | 欧美在线观看成人高清视频 | 久久毛片网站 | 毛片视频网址 | 偷偷操不一样的久久 | 日韩在线视频观看 | 黄色毛片免费在线观看 | 国内精品久久久久久 | 特级毛片在线播放 | 国产美女精品在线 | 杨幂国产精品福利在线观看 | 美女被免费网站视频软件 | 亚洲一区二区三区影院 | 美女张开腿双腿让男人桶 | 私人玩物福利视频 | 日韩精品在线一区二区 | 黄色三级网站 | 在线播放人成午夜免费视频 | 成人国产网站v片免费观看 成人国产午夜在线视频 | 亚洲欧美日韩在线播放 | 在线视频中文字幕 | 欧美视频在线一区二区三区 | 免费播放特黄特色毛片 | 女人国产香蕉久久精品 | 国产欧美va欧美va香蕉在线观 | 欧美黑人xxxxxxxxxx | 亚洲成人高清 | 毛片手机在线 | 亚洲一区二区三区免费在线观看 | 亚洲欧美日韩精品在线 |