Django websocket原理及功能实现代码


Posted in Python onNovember 14, 2020

一 什么是Websocket

WebSocket是一种在单个TCP连接上进行全双工通信的协议

WebSocket使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送数据。在WebSocket API中,浏览器和服务器只需要完成一次握手,两者之间就直接可以创建持久性的连接,并进行双向数据传输

现在,很多网站为了实现推送技术,所用的技术都是轮询。轮询是在特定的的时间间隔(如每1秒),由浏览器对服务器发出HTTP请求,然后由服务器返回最新的数据给客户端的浏览器。这种传统的模式带来很明显的缺点,即浏览器需要不断的向服务器发出请求,然而HTTP请求可能包含较长的头部,其中真正有效的数据可能只是很小的一部分,显然这样会浪费很多的带宽等资源。

而比较新的技术去做轮询的效果是Comet。这种技术虽然可以双向通信,但依然需要反复发出请求。而且在Comet中,普遍采用的长链接,也会消耗服务器资源。

在这种情况下,HTML5定义了WebSocket协议,能更好的节省服务器资源和带宽,并且能够更实时地进行通讯

二 Django实现Websocket

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

三 dwebsocket安装

pip3 install dwebsocket

四 dwebsocket配置

INSTALLED_APPS = [
  .....
  .....
  'dwebsocket',
]
 
MIDDLEWARE_CLASSES = [
  ......
  ......
  'dwebsocket.middleware.WebSocketMiddleware' # 为所有的URL提供websocket,如果只是单独的视图需要可以不选
 
]
WEBSOCKET_ACCEPT_ALL=True  # 可以允许每一个单独的视图实用websockets

五 使用

html代码:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Title</title>
</head>
<body>


<button onclick="WebSocketTest()">test</button>
</body>


<script>


  function WebSocketTest() {
    alert(1)
    if ("WebSocket" in window) {
      alert("您的浏览器支持 WebSocket!");

      // 打开一个 web socket
      ws = new WebSocket("ws://127.0.0.1:8000/path/");

      ws.onopen = function () {
        // Web Socket 已连接上,使用 send() 方法发送数据
        ws.send("发送数据");
        alert("数据发送中...");
      };

      ws.onmessage = function (evt) {
        var received_msg = evt.data;
        alert("数据已接收...");
        alert("数据:" + received_msg)
      };

      ws.onclose = function () {
        // 关闭 websocket
        alert("连接已关闭...");
      };
    }

    else {
      // 浏览器不支持 WebSocket
      alert("您的浏览器不支持 WebSocket!");
    }
  }
</script>
</html>

views视图层:

from django.shortcuts import render,HttpResponse

# Create your views here.
def login(request):
  return render(request,'login.html')

from dwebsocket.decorators import accept_websocket
@accept_websocket
def path(request):
  if request.is_websocket():
    print(1)
    request.websocket.send('下载完成'.encode('utf-8'))

路由层:

from django.conf.urls import url
from django.contrib import admin
from app01 import views
urlpatterns = [
  url(r'^admin/', admin.site.urls),
  url(r'^login/', views.login),
  url(r'^path/', views.path),
]

六 详解

#dwebsocket有两种装饰器:require_websocket和accept_websocekt,使用require_websocket装饰器会导致视图函数无法接收导致正常的http请求,一般情况使用accept_websocket方式就可以了,
#
# dwebsocket的一些内置方法:
#
# request.is_websocket():判断请求是否是websocket方式,是返回true,否则返回false
# request.websocket: 当请求为websocket的时候,会在request中增加一个websocket属性,
# WebSocket.wait() 返回客户端发送的一条消息,没有收到消息则会导致阻塞
# WebSocket.read() 和wait一样可以接受返回的消息,只是这种是非阻塞的,没有消息返回None
# WebSocket.count_messages()返回消息的数量
# WebSocket.has_messages()返回是否有新的消息过来
# WebSocket.send(message)像客户端发送消息,message为byte类型

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
跟老齐学Python之不要红头文件(2)
Sep 28 Python
Python实现比较两个文件夹中代码变化的方法
Jul 10 Python
Linux中安装Python的交互式解释器IPython的教程
Jun 13 Python
python爬虫之BeautifulSoup 使用select方法详解
Oct 23 Python
Python内置模块ConfigParser实现配置读写功能的方法
Feb 12 Python
python读取LMDB中图像的方法
Jul 02 Python
面向初学者的Python编辑器Mu
Oct 08 Python
python中嵌套函数的实操步骤
Feb 27 Python
Python中使用双下划线防止类属性被覆盖问题
Jun 27 Python
python实现网站用户名密码自动登录功能
Aug 09 Python
python中数据库like模糊查询方式
Mar 02 Python
Python学习之时间包使用教程详解
Mar 21 Python
Pycharm常用快捷键总结及配置方法
Nov 14 #Python
Django model class Meta原理解析
Nov 14 #Python
详解python爬取弹幕与数据分析
Nov 14 #Python
Ubuntu权限不足无法创建文件夹解决方案
Nov 14 #Python
Python爬虫过程解析之多线程获取小米应用商店数据
Nov 14 #Python
基于Python的身份证验证识别和数据处理详解
Nov 14 #Python
Python join()函数原理及使用方法
Nov 14 #Python
You might like
thinkphp实现163、QQ邮箱收发邮件的方法
2015/12/18 PHP
PHP编写daemon process 实例详解
2016/11/13 PHP
Laravel实现定时任务的示例代码
2017/08/10 PHP
判断JavaScript对象是否可用的最正确方法分析
2008/10/03 Javascript
javascript 模拟JQuery的Ready方法实现并出现的问题
2009/12/06 Javascript
jQuery asp.net 用json格式返回自定义对象
2010/04/07 Javascript
下载网站打开页面后间隔多少时间才显示下载链接地址的代码
2010/04/25 Javascript
ExtJS4 Grid改变单元格背景颜色及Column render学习
2013/02/06 Javascript
jQuery 无刷新分页实例代码
2013/11/12 Javascript
深入理解Javascript作用域与变量提升
2013/12/09 Javascript
JavaScript遍历table表格中的某行某列并打印其值
2014/07/08 Javascript
使用jquery.upload.js实现异步上传示例代码
2014/07/29 Javascript
JS模拟键盘打字效果的方法
2015/08/05 Javascript
jquery实现表单输入时提示文字滑动向上效果
2015/08/10 Javascript
jquery及js实现动态加载js文件的方法
2016/01/21 Javascript
微信小程序 网络请求(GET请求)详解
2016/11/16 Javascript
微信小程序实现顶部选项卡(swiper)
2020/06/19 Javascript
JS实现左边列表移到到右边列表功能
2018/03/28 Javascript
谈谈JavaScript中super(props)的重要性
2019/02/12 Javascript
Layui 动态禁止select下拉的例子
2019/09/03 Javascript
vue.js中ref及$refs的使用方法解析
2019/10/08 Javascript
vue中在vuex的actions中请求数据实例
2019/11/08 Javascript
[02:43]2018DOTA2亚洲邀请赛主赛事首日TOP5
2018/04/04 DOTA
Python中subprocess模块用法实例详解
2015/05/20 Python
python利用datetime模块计算时间差
2015/08/04 Python
python机器学习包mlxtend的安装和配置详解
2019/08/21 Python
解决django model修改添加字段报错的问题
2019/11/18 Python
tensorflow使用range_input_producer多线程读取数据实例
2020/01/20 Python
python实现简单俄罗斯方块
2020/03/13 Python
HTML5 Canvas鼠标与键盘事件demo示例
2013/07/04 HTML / CSS
课程设计心得体会
2013/12/28 职场文书
求职简历自我评价范文
2015/03/10 职场文书
乒乓球比赛通知
2015/04/27 职场文书
讲文明倡议书
2015/04/29 职场文书
人工作失职检讨书
2015/05/05 职场文书
信用卡工作证明范本
2015/06/19 职场文书