1.多人聊天

from geventwebsocket.handler import WebSocketHandler  # 请求处理WSGI HTTP
from geventwebsocket.server import WSGIServer # 替换Flask原来的WSGI服务
from geventwebsocket.websocket import WebSocket # 语法提示
from flask import Flask, render_template, request app = Flask(__name__)
socket_dict = {} @app.route("/ws")
def my_ws():
ws_socket = request.environ.get("wsgi.websocket")# type:WebSocket
socket_dict[ws_socket] = ws_socket # 可以使用用户名,使用动态路由参数传username
print(socket_dict)
while True:
msg = ws_socket.receive()
print(msg)
for ksocket,vscoket in socket_dict.items():
if ksocket == ws_socket:
continue
vscoket.send(msg) @app.route("/wechat")
def wechat():
return render_template("测试用.html") if __name__ == "__main__": http_serv = WSGIServer(("0.0.0.0", 9527), app, handler_class=WebSocketHandler)
# WebSocketHandler既支持websocket请求,也支持http请求
http_serv.serve_forever() # wsgi启动服务
<!DOCTYPE html>
<html lang="en">
<head>
<meta 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>
<style>
body #content_list {
border: solid black;
width: 400px;
height: 400px;
}
</style>
</head>
<body>
<div id="content_list" style="overflow-y: auto"></div>
<p>
昵称:<input type="text" id="username">
<button onclick="login()">登录聊天室</button>
</p>
<input type="text" id="content">
<button onclick="send_msg()">发送消息</button>
</body>
<script type="application/javascript">
var ws = null; function send_msg() {
var msg = document.getElementById("content").value; //获取发送内容
var sender = document.getElementById("username").value; //获取发送人名字
// 发送的信息内容
var send_str = {
sender: sender,
data: msg
}; ws.send(JSON.stringify(send_str)); // 将发送的信息json序列化
var my_div = document.getElementById("content_list"); // 获取div标签
var ptag = document.createElement("p"); // 创建一个p标签
ptag.innerText = msg + " : 我"; // 设置p标签中的文本内容
ptag.style.cssText = "text-align: right"; // p标签设置css样式,文本靠右
my_div.appendChild(ptag); // 将p标签添加进div标签中
document.getElementById("content").value = "";
} function login() {
var username = document.getElementById("username").value; // 获取登录用户名
console.log(username);
ws = new WebSocket("ws://127.0.0.1:9527/ws"); // 执行websocket服务,如果需要username,可以在url上增加
// 当客户端收到消息时,执行匿名函数
ws.onmessage = function (messageEvent) {
console.log(messageEvent.data);
var obj = JSON.parse(messageEvent.data); // 将接收的数据反序列化
var my_div = document.getElementById("content_list"); // 获取div标签
var ptag = document.createElement("p"); // 获取p标签
ptag.innerText = obj.sender + " : " + obj.data; // 设置p标签中文本内容
my_div.appendChild(ptag); // 将p标签放到div中
};
}
</script>
</html>

2.一对一聊天

import json
from geventwebsocket.handler import WebSocketHandler # 请求处理WSGI HTTP
from geventwebsocket.server import WSGIServer # 替换Flask原来的WSGI服务
from geventwebsocket.websocket import WebSocket # 语法提示
from flask import Flask,render_template,request app = Flask(__name__)
socket_dict = {}
@app.route("/ws/<username>")
def my_ws(username):
# 获取链接地址
ws_socket = request.environ.get("wsgi.websocket") #type:WebSocket
socket_dict[username] = ws_socket
while True:
msg = ws_socket.receive() # 接收浏览器发来的信息
msg_dict = json.loads(msg) # 将信息反序列化,是字典
receiver = msg_dict.get("receiver") # 获取字典中接收人的名字
receiver_socket = socket_dict.get(receiver) # 从字典中找到接收人名字对应的链接地址
receiver_socket.send(msg) # 向接收人的链接地址发送信息
@app.route("/wechat")
def wechat():
return render_template("测试用.html")
if __name__ == "__main__":
http_serv = WSGIServer(("0.0.0.0",9527),app,handler_class=WebSocketHandler)
# WebSocketHandler既支持websocket请求,也支持http请求
http_serv.serve_forever() # wsgi启动服务
<!DOCTYPE html>
<html lang="en">
<head>
<meta 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>
<style>
body #content_list {
border: solid black;
width: 400px;
height: 400px;
}
</style>
</head>
<body>
<div id="content_list" style="overflow-y: auto"></div>
<p>
昵称:<input type="text" id="username">
<button onclick="login()">登录聊天室</button>
</p>
给<input type="text" id="receiver">发送<input type="text" id="content">
<button onclick="send_msg()">发送消息</button>
</body>
<script type="application/javascript">
var ws = null; function send_msg() {
var msg = document.getElementById("content").value; //获取发送内容
var receiver = document.getElementById("receiver").value; // 获取接收人名字
var sender = document.getElementById("username").value; //获取发送人名字
// 发送的信息内容
var send_str = {
receiver: receiver,
sender: sender,
data: msg
}; ws.send(JSON.stringify(send_str)); // 将发送的信息json序列化
var my_div = document.getElementById("content_list"); // 获取div标签
var ptag = document.createElement("p"); // 创建一个p标签
ptag.innerText = msg + " : 我"; // 设置p标签中的文本内容
ptag.style.cssText = "text-align: right"; // p标签设置css样式,文本靠右
my_div.appendChild(ptag); // 将p标签添加进div标签中
document.getElementById("content").value = ""; //将聊天输入框置空
} function login() {
var username = document.getElementById("username").value; // 获取登录用户名
ws = new WebSocket("ws://127.0.0.1:9527/ws/" + username); // 执行websocket服务
// 当客户端收到消息时,执行匿名函数
ws.onmessage = function (messageEvent) {
console.log(messageEvent.data);
var obj = JSON.parse(messageEvent.data); // 将接收的数据反序列化
var my_div = document.getElementById("content_list"); // 获取div标签
var ptag = document.createElement("p"); // 获取p标签
ptag.innerText = obj.sender + " : " + obj.data; // 设置p标签中文本内容
my_div.appendChild(ptag); // 将p标签放到div中
};
}
</script>
</html>

websocket简单实现聊天的更多相关文章

  1. JAVA WebSocKet ( 简单的聊天室 )

    1, 前端代码 登入页 -> login.html <!DOCTYPE html> <html> <head> <meta charset=" ...

  2. python使用websocket简单组建聊天室

    server端 ###websocket_server### import socket import threading sock = socket.socket(socket.AF_INET, s ...

  3. Spring 学习——基于Spring WebSocket 和STOMP实现简单的聊天功能

    本篇主要讲解如何使用Spring websocket 和STOMP搭建一个简单的聊天功能项目,里面使用到的技术,如websocket和STOMP等会简单介绍,不会太深,如果对相关介绍不是很了解的,请自 ...

  4. Netty学习笔记(六) 简单的聊天室功能之WebSocket客户端开发实例

    在之前的Netty相关学习笔记中,学习了如何去实现聊天室的服务段,这里我们来实现聊天室的客户端,聊天室的客户端使用的是Html5和WebSocket实现,下面我们继续学习. 创建客户端 接着第五个笔记 ...

  5. Netty+WebSocket简单实现网页聊天

    基于Netty+WebSocket的网页聊天简单实现 一.pom依赖 <dependency>        <groupId>io.netty</groupId> ...

  6. nodejs与websocket模拟简单的聊天室

    nodejs与websocket模拟简单的聊天室 server.js const http = require('http') const fs = require('fs') var userip ...

  7. 基于websocket实现的一个简单的聊天室

    本文是基于websocket写的一个简单的聊天室的例子,可以实现简单的群聊和私聊.是基于websocket的注解方式编写的.(有一个小的缺陷,如果用户名是中文,会乱码,不知如何处理,如有人知道,请告知 ...

  8. php+websocket搭建简易聊天室实践

    1.前言 公司游戏里面有个简单的聊天室,了解了之后才知道是node+websocket做的,想想php也来做个简单的聊天室.于是搜集各种资料看文档.找实例自己也写了个简单的聊天室. http连接分为短 ...

  9. Java和WebSocket开发网页聊天室

    小编心语:咳咳咳,今天又是聊天室,到现在为止小编已经分享了不下两个了,这一次跟之前的又不大相同,这一次是网页聊天室,具体怎么着,还请各位看官往下看~ Java和WebSocket开发网页聊天室 一.项 ...

随机推荐

  1. C# 使用Epplus导出数据到Excel

    简介:Epplus是一个使用Open Office XML(Xlsx)文件格式,能读写Excel 2007/2010文件的开源组件 功效:支持对excel文档的汇入汇出,图表(excel自带的图表基本 ...

  2. antd desgin vue 报错 Warning: Each record in table should have a unique `key` prop,or set `rowKey` to an unique primary key.

    警告:表的数据源中的每条记录都应该有一个唯一的“key”道具,或者将表的“rowKey”设置为一个唯一的主键, 只需要添加 :rowKey="record => record.id&q ...

  3. JSON —— 数据结构

    1.什么是 JSON JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式. 易于人阅读和编写 JSON 采用完全独立于语言的文本格式,但是也使用了类似于 C ...

  4. 【记录】使用Navicat将表设计导出数据库设计文档

    INFORMATION_SCHEMA. Tables -- 表信息 INFORMATION_SCHEMA. COLUMNS -- 列信息 参考文章地址:https://blog.csdn.net/cx ...

  5. MySQL05-- 客户端工具及SQL语句

    目录 MySQL客户端工具及SQL语句 一.客户端命令介绍 二.接收用户的SQL语句 三.字符集定义 四.字符集设置 五.select的高级用法(扩展) MySQL客户端工具及SQL语句 一.客户端命 ...

  6. [转载]解决Android studio新建项目慢的问题

    原文地址为:https://blog.csdn.net/easion_zms/article/details/73181402 Android Studio 好处很多,但是当从github上或者导入其 ...

  7. 二、Angular项目创建、安装、启动

    1.项目创建,进入预先存放项目的路径,命令行执行 ng new ProjectName 创建成功后的项目 2.项目安装,进行项目中执行命令 npm install  3. 项目运行,执行命令 ng s ...

  8. Sass-颜色运算

    所有算数运算都支持颜色值,并且是分段运算的.也就是说,红.绿和蓝各颜色分段单独进行运算.如: p { color: #010203 + #040506; } 计算公式为 01 + 04 = 05.02 ...

  9. Es学习第九课, 聚合查询和复合查询

    ES除了实现前几课的基本查询,也可以实现类似关系型数据库的聚合查询,如平均值sum.最小值min.最大值max等等 我们就用上一课的数据作为参考来举例 聚合查询 sum聚合 sum是一个求累加值的聚合 ...

  10. SSH框架整合-myeclipse

    项目结构   1.mysql数据库 stuinfo /* SQLyog 企业版 - MySQL GUI v8.14 MySQL - 5.5.40 : Database - stuinfo ****** ...