websocket 群聊,单聊,加密,解密

群聊

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"))

原文地址:https://www.cnblogs.com/xdlzs/p/10170954.html

时间: 2024-08-29 01:37:30

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

使用genvent.socket实施群聊/单聊模式

使用genvent.socket实施群聊 from flask import Flask, request, render_template from gevent.pywsgi import WSGIServer from geventwebsocket.handler import WebSocketHandler from geventwebsocket.websocket import WebSocket import json user_dict = {} #设置一个公共变量 app

websocket实现群聊和单聊(转)

昨日内容回顾 1.Flask路由 1.endpoint="user" # 反向url地址 2.url_address = url_for("user") 3.methods = ["GET","POST"] # 允许请求进入视图函数的方式 4.redirect_to # 在进入视图函数之前重定向 5./index/<nid> # 动态参数路由 <int:nid> def index(nid) 6.str

spring websocket 和socketjs实现单聊群聊,广播的消息推送详解

spring websocket 和socketjs实现单聊群聊,广播的消息推送详解 WebSocket简单介绍 随着互联网的发展,传统的HTTP协议已经很难满足Web应用日益复杂的需求了.近年来,随着HTML5的诞生,WebSocket协议被提出,它实现了浏览器与服务器的全双工通信,扩展了浏览器与服务端的通信功能,使服务端也能主动向客户端发送数据. 我们知道,传统的HTTP协议是无状态的,每次请求(request)都要由客户端(如 浏览器)主动发起,服务端进行处理后返回response结果,而

基于flask 写的web_socket 单聊和群聊

群聊 from flask import Flask,request,render_template from geventwebsocket.handler import WebSocketHandler from gevent.pywsgi import WSGIServer from geventwebsocket.websocket import WebSocket app = Flask(__name__) user_socket_list = [] @app.route("/conn

ASP.NET SignalR 与 LayIM2.0 配合轻松实现Web聊天室(三) 之 实现单聊,群聊,发送图片,文件。

上篇讲解了如何搭建聊天服务器,以及客户端js怎么和layui的语法配合.服务器已经连接上了,那么聊天还会远吗? 进入正题,正如上一篇提到的我们用 Client.Group(groupId)的方法向客户端推送消息.本篇就先不把业务搞复杂了,就默认现在两个用户都各自打开了对方的聊天窗口,那么聊天过程是这样的. 同理,B给A发消息也是这个流程,因为无论如何,A(ID)和B(ID)都会按照规则生成同一个组名.其中由于LayIM已经帮我们在客户端做好了发送消息并且将消息展示在面板上,所以我们要做的就是当接

Websocket 单聊功能

单聊代码 import json from flask import Flask,request,render_template from geventwebsocket.handler import WebSocketHandler from gevent.pywsgi import WSGIServer from geventwebsocket.websocket import WebSocket app = Flask(__name__) user_socket_dict = {} @ap

使用Nio实现一个简易的群聊和单聊

服务端:接收客户端发送的消息,并进行转发. package socket.demo2; import java.io.IOException; import java.net.InetSocketAddress; import java.net.ServerSocket; import java.nio.ByteBuffer; import java.nio.channels.*; import java.nio.charset.StandardCharsets; import java.uti

环信即时通讯单聊集成,添加好友,实现单聊

前段时间由于项目需要,了解一下环信即时通讯,然后自己通过查资料写了一个基于环信的单聊demo,一下是源码,希望可以帮助到需要的小伙伴. 首先,我们要去环信官网注册账号,这个我就不多说了,注册完登录,创建应用,新建两个测试IM用户, 这里主要用到的是应用标示(Appkey) 好了,在环信官网下载对应的sdk,这个不多说了,最好下载一个文档,里面讲的很详细的. 好了,一下是源码 AppManager.java public class AppManager { private static Stac

表单 对数据库字段自动加密解密表单提交(THINKPHP3.2)

1.config配置变量 'MODEL_FIELD_FLAG' => TRUE,//表单加密开关 'MODEL_FIELD_NAME_PRE' => 'mlm_',//表单加密前缀 'MODEL_FIELD_EMCODE' => 'md5',//加密方式 'MODEL_FIELD_EMCODE_KEY' => '[email protected]'//加密key 2.控制器层 $model  继承基础类 BaseModel BaseRelationModel 任意一个的自定义模型