channel

什么是channel?

channel是第三方工具包,对于不支持websocket协议的框架可以借助此包实现websocket

安装

终端安装:

pip3 install channel

pycharm安装:

Project Interprete 搜索  “channel”即可

配置

1、配置 setting.py

INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'app01.apps.App01Config',
'channels',
]

配置完app后,还要对ASGI_APPLICATION配置:

# 配置 channel
ASGI_APPLICATION = "MiniChat.routing.application"

如果不配置就会报错:

CommandError: You have not set ASGI_APPLICATION, which is needed to run the server.

2.、配置路由

在app下新建routing.py文件,此文件相当于django的url.py

MiniChat/routing.py

from channels.routing import ProtocolTypeRouter, URLRouter
from django.conf.urls import url
from chat import consumers application = ProtocolTypeRouter({
"websocket":URLRouter([ ])
})

3、创建业务处理文件:consumers.py

此文件相当于django中的view.py文件

MiniChat/consumers.py

#!usr/bin/env python
#-*- coding:utf-8 _*-
from channels.generic.websocket import WebsocketConsumer
from channels.exceptions import StopConsumer class ChatConsumer(WebsocketConsumer): def websocket_connect(self, message):
"""
客户端发送请求进来,触发此方法
:param message:
:return:
"""
self.accept() def websocket_receive(self, message):
"""
客户端发送消息,触发此方法,并返回数据
:param message:
:return:
"""
self.send() def websocket_disconnect(self, message): """
客户端主动断开链接,触发此方法
:param message:
:return:
"""
# 服务端触发异常 StopConsumer
raise StopConsumer

consumers.py

最终项目目录:

案例:WebChat

基于上面的配置,先创建一个视图:

from django.shortcuts import render

# Create your views here.

def index(request):

    return render(request, "index.html")

然后在app01中创建一个templates包,在这个包中创建一个index.html.再去实现html文件:

Django默认模板查找顺序是从根目录查找,找不到再去app中查找

<div>
<div>
<input type="text" id="txt">
<input type="button" value="send" onclick="sendMsg();">
<input type="button" value="close" onclick="closeConn();">
</div>
<h2>聊天记录</h2>
<div id="content"> </div>
</div>

现在跑一下项目文件,浏览器页面显示:

现在再去完善下html文件

<script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.5.0/jquery.min.js"></script>
<script> var ws = new WebSocket("ws://127.0.0.1:8000/chat/"); ws.onopen = function(){
// 客户端验证握手环节完成之后,自动执行该方法
console.log("链接成功。。。")
}; ws.onmessage = function (event) {
// 接受服务端发送的消息
// 客户端完成握手验证之后 触发该方法
console.log(event.data);
var tag = $("<div>");
tag.text(event.data);
$("#content").append(tag);
console.log(1) }; function sendMsg() {
// ws.send():发送消息
ws.send($("#txt").val()); }; function closeConn() {
// ws.close():关闭Websocket链接
console.log("断开链接。。。");
ws.close();
}; </script>

在这里就使用简单的方式实现多人聊天的功能,对consumers.py做以下修改:

USER_list = []
class ChatConsumer(WebsocketConsumer): def websocket_connect(self, message):
"""
客户端发送请求进来,触发此方法
:param message:
:return:
"""
self.accept() # 执行accept之后代表链接成功
USER_list.append(self) # 将每一个链接的用户添加到列表中 def websocket_receive(self, message):
"""
客户端发送消息,触发此方法,并返回数据
:param message:
:return:
"""
# print("msg:", message) # msg: {'type': 'websocket.receive', 'text': '123'}
data = message["text"] # 获取字典中的数据
# self.send("over")
for user in USER_list: # 遍历用户列表返回消息
user.send(data) def websocket_disconnect(self, message):
"""
客户端主动断开链接,触发此方法
:param message:
:return:
"""
# 服务端触发异常 StopConsumer
USER_list.remove(self) # 将每一个链接的用户从列表中删除
raise StopConsumer

至此,就简单实现了多人在线聊天的功能。

Django使用channel实现websocket的更多相关文章

  1. Django使用channels实现Websocket连接

    简述: 需求:消息实时推送消息以及通知功能,采用django-channels来实现websocket进行实时通讯.并使用docker.daphne启动通道,保持websocket后台运行 介绍Dja ...

  2. django(channel)到 ubuntu

    1.准备工作 删除各app/migrations/下的以数字开头的数据库同步日志文件: 假设你使用的是Pycharm,我们要生成环境包: pip freeze > requirements.tx ...

  3. IronFort---基于Django和Websocket的堡垒机

    WebSSH有很多,基于Django的Web服务也有很多,使用Paramiko在Python中进行SSH访问的就更多了.但是通过gevent将三者结合起来,实现通过浏览器访问的堡垒机就很少见了.本文将 ...

  4. Django websocket之web端实时查看日志实践案例

    这是Django Channels系列文章的第二篇,以web端实现tailf的案例讲解Channels的具体使用以及跟Celery的结合 通过上一篇<Django使用Channels实现WebS ...

  5. 开发基于Django和Websocket的堡垒机

    WebSSH有很多,基于Django的Web服务也有很多,使用Paramiko在Python中进行SSH访问的就更多了.但是通过gevent将三者结合起来,实现通过浏览器访问的堡垒机就很少见了.本文将 ...

  6. django + nginx + uwsgi + websocket

    最近使用django框架做了一个简单的聊天机器人demo, 开发的过程中使用了django自带的websocket模块,当使用django框架自带的wsgi服务去启动的话,没有什么问题.如果要使用uw ...

  7. 11 Django实现WebSocket

    因为需要实时显示状态的需求,想到了websocket,但是Django原生不支持websocket,后来搜索到了chango-channels项目,可以实现次需求. 一.Channels 官方文档 二 ...

  8. Flask websocket

    websocket 概念 是一套协议,协议规定了: - 连接时需要握手 - 发送数据进行加密 - 连接之后不断开 意义 实现长轮询等操作 框架支持 - flask,gevent-websocket - ...

  9. Django使用Channels实现WebSocket--下篇

    希望通过对这两篇文章的学习,能够对Channels有更加深入的了解,使用起来得心应手游刃有余 通过上一篇<Django使用Channels实现WebSocket--上篇>的学习应该对Cha ...

随机推荐

  1. # Unity 游戏框架搭建 2019 (三十四、三十五) 9 ~ 10 示例整理

    第九个示例 目前代码如下: using UnityEngine; #if UNITY_EDITOR using UnityEditor; #endif namespace QFramework { p ...

  2. JS在线代码编辑器多种方案monaco-editor,vue-monaco-editor

    前言 JavaScript在线代码编辑器. 需要代码提示,关键字高亮,能够格式化代码.(不需要在线运行) 简简单单的需求. 方案一: Monaco-editor 简介:微软的开源项目,开源中国上面的在 ...

  3. foreach里的按引用传值问题

    1.foreach($arr as $k=>&$v){ } 这样循环时候最后一个结果前边会有&,出现输出不了的情况,这时候只需要加一个unset($v),加在循环里和外均可. 2 ...

  4. StringRedisTemplate的常用操作

    stringRedisTemplate.opsForValue().set("test", "100",60*10,TimeUnit.SECONDS);//向r ...

  5. 【Inno Setup】查看是否安装了VC++ 2015 Redistributeable

    可能有必要先测一下注册表的这一项是否存在 if RegValueExists(HKLM, 'SOFTWARE\WOW6432Node\Microsoft\VisualStudio\14.0\VC\Ru ...

  6. 如何给 Visual Studio 的输出程序添加版本信息

    出处:https://stackoverflow.com/questions/284258/how-do-i-set-the-version-information-for-an-existing-e ...

  7. 都2020年了,这5个java IDE神器你还不知道?

    TIOBE的4月份编程语言排行榜出来了,java还是稳坐第一位,java最新的版本也到了13,一直以来java凭借其企业级应用的优势和大量的框架级应用俘获了大量的粉丝和企业客户. 谈到开发者,java ...

  8. 【ubuntu】windows+ubuntu 设置windows为第一启动项

    进入ubuntu系统 sudo su vim /etc/default/grub 更改GRUB_DEFAULT=后的值默认是0,如果你的windows启动项在第5个就改成4.改完之后退出保存输入 up ...

  9. 阿里大牛带你深入分析spring事务传播行为

    spring框架封装了很多有用的功能和组件,便于在项目开发中快速高效的调用,其中spring的事务使用非常简单,只需要在用到事务的地方加一行注解即可: 1@Transactional 但越是看起来简单 ...

  10. 全网最清晰的ConstraintLayout教程

    ConstraintLayout是AndroidStudio2.2新增的一个功能,那么这个到底是什么呢?首先第一点我们知道传统的安卓开发,页面基本都是XML编写实现,特别在一些复杂的页面上需要嵌套多层 ...