群聊

from flask import Flask, request, render_templatefrom geventwebsocket.handler import WebSocketHandlerfrom gevent.pywsgi import WSGIServer

from geventwebsocket.websocket import WebSocket

app = Flask(__name__)  # type:Flask

user_socket_list = []

@app.route("/ws")def ws():    user_socket = request.environ.get("wsgi.websocket")  # type:WebSocket    if user_socket:        user_socket_list.append(user_socket)    print(len(user_socket_list), user_socket_list)    while 1:        msg = user_socket.receive()        print(msg)        for usocket in user_socket_list:            if user_socket == usocket:                continue            try:                usocket.send(msg)            except:                continue

@app.route("/")def index():    return render_template("ws.html")

if __name__ == '__main__':    # app.run("0.0.0.0",5000,debug=True)    http_serv = WSGIServer(("0.0.0.0", 5000), app, handler_class=WebSocketHandler)    http_serv.serve_forever()**************************************************************************************************************************************************
<!DOCTYPE html><html lang="zh-CN"><head>    <meta http-equiv="content-Type" charset="UTF-8">    <meta http-equiv="x-ua-compatible" content="IE=edge">    <meta name="viewport" content="width=device-width, initial-scale=1">    <title>Title</title></head><body><p>发送内容:<input type="text" id="message"><button onclick="send_msg()">发送消息</button></p><div id="msg_list" style="width: 500px;">

</div></body><script type="application/javascript">    var ws = new WebSocket("ws://127.0.0.1:5000/ws");    // ws.onopen = function(){    //   alert("欢迎来到S14群喷");    // };    ws.onmessage = function (ws_status) {        console.log(ws_status.data);        var ptag = document.createElement("p");        ptag.innerText = ws_status.data;        document.getElementById("msg_list").appendChild(ptag);    };

    function send_msg() {        var msg = document.getElementById("message").value;        var ptag = document.createElement("p");        ptag.style.cssText = "text-align: right;";        ptag.innerText = msg;        document.getElementById("msg_list").appendChild(ptag);        ws.send(msg);    }</script></html>

单聊

from flask import Flask, request, render_templatefrom geventwebsocket.handler import WebSocketHandlerfrom gevent.pywsgi import WSGIServerimport json

from geventwebsocket.websocket import WebSocket

app = Flask(__name__)  # type:Flask

user_socket_dict = {}

@app.route("/ws/<user>")def ws(user):    user_socket = request.environ.get("wsgi.websocket")  # type:WebSocket    if user_socket:        user_socket_dict[user] = user_socket    print(len(user_socket_dict), user_socket_dict)    while 1:        msg = user_socket.receive()        print(msg)  # b"{from_user:jinwangba ,to_user:yinwangba,msg:"doushidawangba"}"        msg_dict = json.loads(msg)        to_usocket = user_socket_dict.get(msg_dict.get("to_user"))        to_usocket.send(json.dumps({"from_user": user, "to_user": msg_dict.get("to_user"), "msg": msg_dict.get("msg")}))

@app.route("/")def index():    return render_template("wsd.html")

if __name__ == '__main__':    # app.run("0.0.0.0",5000,debug=True)    http_serv = WSGIServer(("0.0.0.0", 5000), app, handler_class=WebSocketHandler)    http_serv.serve_forever()

*********************************************************************************************************************************************************************************************

<!DOCTYPE html><html lang="zh-CN"><head>    <meta http-equiv="content-Type" charset="UTF-8">    <meta http-equiv="x-ua-compatible" content="IE=edge">    <meta name="viewport" content="width=device-width, initial-scale=1">    <title>Title</title></head><body><p>您的昵称:<input type="text" id="nick"><button onclick="openws()">进入聊天室</button></p><p>给<input type="text" id="to_user">发送:<input type="text" id="message"><button onclick="send_msg()">发送消息</button></p><div id="msg_list" style="width: 500px;">

</div></body><script type="application/javascript">    var ws = null;    // ws.onopen = function(){    //   alert("欢迎来到S14群喷");    // };

    function openws(){        var nick = document.getElementById("nick").value;        ws = new WebSocket("ws://127.0.0.1:5000/ws/"+nick);        ws.onmessage = function (ws_status) {            console.log(ws_status.data);            var msg_obj = JSON.parse(ws_status.data);            var ptag = document.createElement("p");            ptag.innerText = msg_obj.from_user + " : " +msg_obj.msg;            document.getElementById("msg_list").appendChild(ptag);        };    }

    function send_msg() {        var msg = document.getElementById("message").value;        var from_user = document.getElementById("nick").value;        var to_user = document.getElementById("to_user").value;        var ptag = document.createElement("p");        ptag.style.cssText = "text-align: right;";        ptag.innerText = msg + " : "+ from_user;        document.getElementById("msg_list").appendChild(ptag);        var msg_obj = {            msg:msg,            from_user:from_user,            to_user:to_user        };        ws.send(JSON.stringify(msg_obj));    };

</script></html>

加密

加密:

 1 import struct
 2 msg_bytes = "hello".encode("utf8")
 3 token = b"\x81"
 4 length = len(msg_bytes)
 5
 6 if length < 126:
 7     token += struct.pack("B", length)
 8 elif length == 126:
 9     token += struct.pack("!BH", 126, length)
10 else:
11     token += struct.pack("!BQ", 127, length)
12
13 msg = token + msg_bytes
14
15 print(msg)

解密

解密:

 1 # b'\x81\x83\xceH\xb6\x85\xffz\x85'
 2
 3 hashstr = b'\x81\x83\xceH\xb6\x85\xffz\x85'
 4 # b'\x81    \x83    \xceH\xb6\x85\xffz\x85'
 5
 6 # 将第二个字节也就是 \x83 第9-16位 进行与127进行位运算
 7 payload = hashstr[1] & 127
 8 print(payload)
 9 if payload == 127:
10     extend_payload_len = hashstr[2:10]
11     mask = hashstr[10:14]
12     decoded = hashstr[14:]
13 # 当位运算结果等于127时,则第3-10个字节为数据长度
14 # 第11-14字节为mask 解密所需字符串
15 # 则数据为第15字节至结尾
16
17 if payload == 126:
18     extend_payload_len = hashstr[2:4]
19     mask = hashstr[4:8]
20     decoded = hashstr[8:]
21 # 当位运算结果等于126时,则第3-4个字节为数据长度
22 # 第5-8字节为mask 解密所需字符串
23 # 则数据为第9字节至结尾
24
25
26 if payload <= 125:
27     extend_payload_len = None
28     mask = hashstr[2:6]
29     decoded = hashstr[6:]
30
31 # 当位运算结果小于等于125时,则这个数字就是数据的长度
32 # 第3-6字节为mask 解密所需字符串
33 # 则数据为第7字节至结尾
34
35 str_byte = bytearray()
36
37 for i in range(len(decoded)):
38     byte = decoded[i] ^ mask[i % 4]
39     str_byte.append(byte)
40
41 print(str_byte.decode("utf8"))
 1 # b'\x81\x83\xceH\xb6\x85\xffz\x85'
 2
 3 hashstr = b'\x81\x83\xceH\xb6\x85\xffz\x85'
 4 # b'\x81    \x83    \xceH\xb6\x85\xffz\x85'
 5
 6 # 将第二个字节也就是 \x83 第9-16位 进行与127进行位运算
 7 payload = hashstr[1] & 127
 8 print(payload)
 9 if payload == 127:
10     extend_payload_len = hashstr[2:10]
11     mask = hashstr[10:14]
12     decoded = hashstr[14:]
13 # 当位运算结果等于127时,则第3-10个字节为数据长度
14 # 第11-14字节为mask 解密所需字符串
15 # 则数据为第15字节至结尾
16
17 if payload == 126:
18     extend_payload_len = hashstr[2:4]
19     mask = hashstr[4:8]
20     decoded = hashstr[8:]
21 # 当位运算结果等于126时,则第3-4个字节为数据长度
22 # 第5-8字节为mask 解密所需字符串
23 # 则数据为第9字节至结尾
24
25
26 if payload <= 125:
27     extend_payload_len = None
28     mask = hashstr[2:6]
29     decoded = hashstr[6:]
30
31 # 当位运算结果小于等于125时,则这个数字就是数据的长度
32 # 第3-6字节为mask 解密所需字符串
33 # 则数据为第7字节至结尾
34
35 str_byte = bytearray()
36
37 for i in range(len(decoded)):
38     byte = decoded[i] ^ mask[i % 4]
39     str_byte.append(byte)
40
41 print(str_byte.decode("utf8"))

websocket 群聊,单聊,加密,解密的更多相关文章

  1. websocket 群聊单聊

    websocket 介绍 介绍引自 https://segmentfault.com/a/1190000012709475 群聊 from flask import Flask, request, r ...

  2. Flask请求上下文源码讲解,简单的群聊单聊web

    请求上下文流程图 群聊html代码 <!DOCTYPE html> <html lang="en"> <head> <meta chars ...

  3. Flask-session,WTForms,POOL,Websocket通讯原理 -握手,加密解密过程

    1.Flask-session Flask中的session 需要执行 session_interface - open_session存储到redis中,存的key:session:d3f07db2 ...

  4. websocket实现群聊和单聊(转)

    昨日内容回顾 1.Flask路由 1.endpoint="user" # 反向url地址 2.url_address = url_for("user") 3.m ...

  5. flask 第五章 WebSocket GeventWebsocket 单聊群聊 握手 解密 加密

    1.WebSocket 首先我们来回顾一下,我们之前用socket学习过的项目有: 1.django 2.flask 3.FTP - 文件服务 HTTP - TCP (特点): 1.一次请求,一次响应 ...

  6. websocket 实现单聊群聊 以及 握手原理+加密方式

    WebSocket 开始代码 服务端 群聊 # type:WebSocket 给变量标注类型 # websocket web + socket from geventwebsocket.server ...

  7. 基于websocket的单聊.群聊

    关于ai.baidu.com的 代码: #########################################核心代码################################### ...

  8. Websocket实现群聊、单聊

    Websocket 使用的第三方模块:gevent-websocket 群聊 ws群聊.py中的内容 from flask import Flask, request, render_template ...

  9. WebSocket群聊与单聊

    一 . WebSocket实现群聊 py文件代码 # py文件 from flask import Flask, render_template, request from geventwebsock ...

随机推荐

  1. Day 04 if判断,while循环,for循环

    if判断语法一:if 条件: # 条件成立时执行的子代码块 代码1 代码2 代码3 示例:sex='female'age=18is_beautiful=True if sex == 'female' ...

  2. 大数据框架对比:Hadoop、Storm、Samza、Spark和Flink--容错机制(ACK,RDD,基于log和状态快照),消息处理at least once,exactly once两个是关键

    分布式流处理是对无边界数据集进行连续不断的处理.聚合和分析.它跟MapReduce一样是一种通用计算,但我们期望延迟在毫秒或者秒级别.这类系统一般采用有向无环图(DAG). DAG是任务链的图形化表示 ...

  3. 基于Java+SparkStreaming整合kafka编程

    一.下载依赖jar包 具体可以参考:SparkStreaming整合kafka编程 二.创建Java工程 太简单,略. 三.实际例子 spark的安装包里面有好多例子,具体路径:spark-2.1.1 ...

  4. 【巷子】---redux---【react】

    一.flux的缺陷 因为dispatcher和Store可以有多个互相管理起来特别麻烦 二.什么是redux 其实redux就是Flux的一种进阶实现.它是一个应用数据流框架,主要作用应用状态的管理 ...

  5. 【转】SQL Server日志文件过大 大日志文件清理方法 不分离数据库

    https://blog.csdn.net/slimboy123/article/details/54575592 还未测试 USE[master] GO ALTER DATABASE 要清理的数据库 ...

  6. 写在vue总结之前(二)

    都说要快速学会一个技术(会使用),比如一个框架,在实际的工作中做相关的项目是最快的学习方式.而为什么在实际的工作项目中去学习是最快的方式?个人的体会是,在实际的工作项目中,很多功能的实现是你不得不做的 ...

  7. CTE(Common Table Expression) 公用表表达式

    在编写T-SQL代码时,往往需要临时存储某些结果集.前面我们已经广泛使用和介绍了两种临时存储结果集的方法:临时表和表变量.除此之外,还可以 使用公用表表达式的方法.公用表表达式(Common Tabl ...

  8. JSON 简介

    ylbtech-JSON: JSON 简介 JSON:JavaScript Object Notation(JavaScript 对象表示法) JSON是存储和交换文本信息的语法,类似 XML. JS ...

  9. linux采集CPU温度并上传数据到云平台判断是否需要beep

    如果要beep肯定要apt install beep的 但光安装好还不够,需要执行模块加载 /sbin/modprobe pcspkr 再写一个bash脚本 data=$(/usr/bin/senso ...

  10. VRRP、Track与NQA联动配置举例(Master监视上行链路)

    原文 http://www.h3c.com/cn/d_201708/1018729_30005_0.htm#_Toc488338729 1. 组网需求 Host A需要访问Internet上的Host ...