1.WebSocket

首先我们来回顾一下,我们之前用socket学习过的项目有:

  1.django

  2.flask

  3.FTP - 文件服务

HTTP - TCP (特点):

  1.一次请求,一次响应,然后断开

  2.客户端永远处于主动状态

  3.服务端永远处于被动状态

  4.HTTP请求是无状态的 -- 在服务器不保存客户端的信息

  5.由于HTTP请求是无状态的,所以服务器无法主动找到客户端

  优点 :

    1.速度快

    2.信息安全

    3.不是特别占用资源

1.轮询:

  客户端不停的向服务端发送请求,服务端不停的向客户端响应,直到客户端拿到数据为止.

  劣势:

    1.服务端和客户端双端资源浪费

    2.带宽资源占用(带宽 : 网络连接时所能传送的最大数据流速)

    3.不能保证数据的实时性

2. 长轮询:

  客户端向服务端发送一个请求,服务端保持这个请求,不返回值就不响应,一定时间后,服务器抛弃这个请求或者是返回. 客户端收到请求后,立即再次发起保持连接.

在这里我们类比一个实例:

  你去传达室问大爷有没有快递,大爷款待你喝茶(喝茶的时候就相当于保持连接),如果中途你想去厕所(去厕所就相当于是断开了连接),回来之后继续喝茶(再次建立保持连接).

  劣势:

    1.相比于轮询方式,长轮询方式只是浪费了服务器的资源

    2.无法保证是数据实时性

  优势:

    1.相比于轮询方式,他节省了客户端的资源

    2.保证数据有效

3.长连接

  永久的保持连接(现在我们用的基本上都是长连接)

  劣势:

      对服务器的CPU要求比较高

  优势:

    1.节省了大量的资源(客户端和服务端的资源都节省了)

    2.数据实时有效性

    3.带宽资源几乎不占用

WebSocket协议 : ws协议 ws://127.0.0.1 用JavaScript封装客户端

  三方 : geventWebsocket Flask

  web框架 : 用来进行Http请求的处理(握手)

4.单聊 

.py文件的代码如下:

import json

from flask import Flask, render_template, request
from geventwebsocket.handler import WebSocketHandler
from gevent.pywsgi import WSGIServer
from geventwebsocket.websocket import WebSocket
from geventwebsocket.exceptions import WebSocketError app = Flask(__name__) user_socket_dict = {} @app.route('/my_app')
def my_app():
return render_template('myapp.html') @app.route('/my_ws/<username>')
def my_ws(username):
user_socket = request.environ.get( 'wsgi.websocket')
# 'wsgi.websocket': <geventwebsocket.websocket.WebSocket object at 0x00000206FCDC1528>,
user_socket_dict[username] = user_socket # type:WebSocket
# print(user_socket_dict)
while 1:
try:
# 阻塞等待消息数据
msg = user_socket.receive()
# 将接收到的消息反序列化成字典
msg_dict = json.loads(msg)
# print(msg)
to_user = msg_dict.get('to_user')
to_user_socket = user_socket_dict.get(to_user)
to_user_socket.send(msg)
except WebSocketError:
user_socket_dict.pop(username)
return '有个地方错了' if __name__ == '__main__':
http_server = WSGIServer(('0.0.0.0', 9527), app, handler_class=WebSocketHandler)
http_server.serve_forever()

myapp.html 文件代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
你的名字:<input type="text" id="nkname">
<button onclick="open_chat()">登录聊天室</button>
<p>发送至<input type="text" id="to_user"></p>
消息<input type="text" id="message">
<button onclick="send_msg()">发送</button>
<div id="chat_list"> </div>
</body>
<script type="application/javascript">
var ws = null; function open_chat() {
var nkname = document.getElementById('nkname').value;
ws = new WebSocket("ws://127.0.0.1:9527/my_ws/" + nkname);
ws.onopen = function () {
alert('欢迎' + nkname + '登录对骂平台!!')
};
ws.onmessage = function (EventMessage) {
var chat = JSON.parse(EventMessage.data);
var p = document.createElement('p');
p.style.cssText = 'width : 250px; text-align:left';
p.innerText = chat.from_user + '-->' + chat.message;
document.getElementById('chat_list').appendChild(p);
};
ws.onclose = function () {
console.log('断开连接了,啥情况啊? 搞事情啊');
};
} function send_msg() {
var message = document.getElementById('message').value;
var from_user = document.getElementById('nkname').value;
var to_user = document.getElementById('to_user').value;
var send_str = {
message: message,
from_user: from_user,
to_user: to_user
};
ws.send(JSON.stringify(send_str));
var p = document.createElement('p');
p.style.cssText = "width: 250px;text-align: right";
p.innerText = send_str.message + "<-我";
document.getElementById('chat_list').appendChild(p);
} </script>
</html>

5.群聊

.py文件代码如下:

from geventwebsocket.handler import WebSocketHandler
from gevent.pywsgi import WSGIServer
from geventwebsocket.websocket import WebSocket
from geventwebsocket.exceptions import WebSocketError from flask import Flask,render_template,request app = Flask(__name__) user_socket_list = [] @app.route("/my_app")
def my_app():
return render_template("my_app.html") @app.route("/my_ws")
def my_ws():
user_socket = request.environ.get("wsgi.websocket")
# type:WebSocket
user_socket_list.append(user_socket)
# print(len(user_socket_list),user_socket_list)
while 1:
try:
msg = user_socket.receive() # 阻塞等待消息数据
except WebSocketError:
user_socket_list.remove(user_socket)
return "good bye"
for u in user_socket_list:
if u == user_socket:
continue
try:
u.send(msg)
except :
continue if __name__ == '__main__':
# app.run()
http_serv = WSGIServer(("0.0.0.0",9527),app,handler_class=WebSocketHandler)
http_serv.serve_forever()

myapp.html文件代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<input type="text" id="message"><button onclick="send_message()">发送</button>
<div id="chat_list"> </div>
</body>
<script type="application/javascript">
var ws = new WebSocket("ws://192.168.14.200:9527/my_ws");
ws.onmessage = function (eventMessage) {
// document.getElementById("chat_list").innerHTML += "<p>" + eventMessage.data + "</p>";
var p = document.createElement("p");
p.innerText = eventMessage.data;
document.getElementById("chat_list").appendChild(p);
}; function send_message() {
var message = document.getElementById("message").value;
ws.send(message);
} </script>
</html>

flask 第五章 WebSocket GeventWebsocket 单聊群聊 握手 解密 加密的更多相关文章

  1. Flask(4)- flask请求上下文源码解读、http聊天室单聊/群聊(基于gevent-websocket)

    一.flask请求上下文源码解读 通过上篇源码分析,我们知道了有请求发来的时候就执行了app(Flask的实例化对象)的__call__方法,而__call__方法返回了app的wsgi_app(en ...

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

    spring websocket 和socketjs实现单聊群聊,广播的消息推送详解 WebSocket简单介绍 随着互联网的发展,传统的HTTP协议已经很难满足Web应用日益复杂的需求了.近年来,随 ...

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

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

  4. 基于websocket的单聊.群聊

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

  5. WebSocket+Java 私聊、群聊实例

    前言 之前写毕业设计的时候就想加上聊天系统,当时已经用ajax长轮询实现了一个(还不懂什么是轮询机制的,猛戳这里:https://www.cnblogs.com/hoojo/p/longPolling ...

  6. WebSocket刨根问底(三)之群聊

    前两篇文章[WebSocket刨根问底(一)][WebSocket刨根问底(二)]我们介绍了WebSocket的一些基本理论,以及一个简单的案例,那么今天继续,我们来看一个简单的群聊的案例,来进一步了 ...

  7. jquery 第五章 jQuery操作表单与表格

    1.回顾 对象.bind("事件名称",function(){ // }) 阻止冒泡事件 return false,   event stopProapagation() 模拟事件 ...

  8. 从零一起学Spring Boot之LayIM项目长成记(六)单聊群聊的实现

    文章传送门: https://my.oschina.net/panzi1/blog/1577007 并没有放弃博客园,只是 t-io 在 oschina发展.用了人家的框架,也得帮人家做做宣传是吧~~

  9. 从零一起学Spring Boot之LayIM项目长成记(五)websocket

    前言 距离上一篇已经比较久的时间了,项目也是开了个头.并且,由于网上的关于Spring Boot的websocket讲解也比较多.于是我采用了另外的一个通讯框架 t-io 来实现LayIM中的通讯功能 ...

随机推荐

  1. SAP基本计量单位更改(转载)

    转载自:http://blog.csdn.net/sapmatinal/article/details/50997819 在SAP中物料创建后,一旦发生业务,其基本计量单位便很难修改.由于单位无法满足 ...

  2. SpringBoot服务器部署

    注释本地tomcat jar包 jdk版本必须1.8以上 tomcat版本必须8以上 配置tomcat server.xml文件 Swagger 配置

  3. HBase API 基础操作

    对于数据操作,HBase支持四类主要的数据操作,分别是: Put :增加一行,修改一行 Delete :删除一行,删除指定列族,删除指定column的多个版本,删除指定column的制定版本等 Get ...

  4. Java基础学习-三元运算符和键盘录入的基本步骤和使用

    1.三元运算符的执行流程   package com.denniscui_05; /*  * 三元运算符:  *         关系表达式?表达式1:表达式2  *  * 执行流程:  *      ...

  5. make capslock+hjkl as arrows

    Solution 2 (probably better) I was happy with solution 1, until I realized I couldn't use the key bi ...

  6. 钉钉授权第三方WEB网站扫码登录

    一.阅读开发文档 首先阅读钉钉官方的开发文档,扫码登录其实用的是官方文档描述的第二种方式,即将钉钉登录二维码内嵌到自己页面中,用户使用钉钉扫码登录第三方网站,网站可以拿到钉钉的用户信息. 二.准备工作 ...

  7. IDEA Maven项目的Mybatis逆向工程

    IDEA Maven项目的Mybatis逆向工程 1.配置.pom 如果是在多模块开发下,该文件逆向工程要生成的那个模块下的pom文件. <build> <plugins> & ...

  8. Http 状态码:

    消息 100 Continue 101 Switching Protocols 102 Processing 成功 200 OK 201 Created 202 Accepted 203 Non-Au ...

  9. C++学习建议

    C++学习建议 C++缺点之一,是相对许多语言复杂,而且难学难精.许多人说学习C语言只需一本K&R<C程序设计语言>即可,但C++书籍却是多不胜数.我是从C进入C++,皆是靠阅读自 ...

  10. lua---研究 c-api

    c-api 参考手册:http://www.leeon.me/a/lua-c-api-manual