后端Python3+Flask结合Socket.io配合前端Vue2.0实现简单全双工在线客服系统
原文转载自「刘悦的技术博客」https://v3u.cn/a_id_158
在之前的一篇文章中:为美多商城(Django2.0.4)添加基于websocket的实时通信,主动推送,聊天室及客服系统,详细介绍了websocket协议以及结合Django如何实现各种功能,本次我们尝试采用Socket.io这个库和Flask来配合使用,完成一个简易的在线客服聊天系统,看看二者有什么区别。
Socket.IO 就是一个封装了 Websocket、基于 Node 的 JavaScript 框架,包含 client 的 JavaScript 和 server 的 Node(现在也支持python,go lang等语言)。其屏蔽了所有底层细节,让顶层调用非常简单,另外,Socket.IO 还有一个非常重要的好处。其不仅支持 WebSocket,还支持许多种轮询机制以及其他实时通信方式,并封装了通用的接口。这些方式包含 Adobe Flash Socket、Ajax 长轮询、Ajax multipart streaming 、持久 Iframe、JSONP 轮询等。换句话说,当 Socket.IO 检测到当前环境不支持 WebSocket 时,能够自动地选择最佳的方式来实现网络的实时通信,这一点就比websocket要智能不少。
我们先进行后端服务的搭建
pip install flask
pip install flask-cors
pip install flask-socketio
分别安装Flask本地,跨域模块,以及socketio模块
适当升级你的pip,注意版本不要过低,下面是本次demo的版本号
Flask                 1.1.1
Flask-Cors            3.0.8
Flask-SocketIO        4.3.0
Flask-SQLAlchemy      2.4.1
随后我们简单写一个flask的入口启动文件 manage.py
from flask import Flask
from flask_sqlalchemy import SQLAlchemy
import pymysql
from flask import request,jsonify
from flask_cors import CORS
from flask_socketio import SocketIO,send,emit
import urllib.parse  
pymysql.install_as_MySQLdb()  
app = Flask(__name__)  
CORS(app,cors_allowed_origins="*")  
socketio = SocketIO(app,cors_allowed_origins='*')  
@socketio.on('message')
def handle_message(message):
    message = urllib.parse.unquote(message)
    print(message)
    send(message,broadcast=True)  
@socketio.on('connect', namespace='/chat')
def test_connect():
    emit('my response', {'data': 'Connected'})  
@socketio.on('disconnect', namespace='/chat')
def test_disconnect():
    print('Client disconnected')  
if __name__ == '__main__':
    socketio.run(app,debug=True,host="0.0.0.0",port=5000)
这里简单说一下需要注意的地方,实例化socketio对象的时候,要加上cors_allowed_origins来设置跨域,前后端分离项目让人伤脑筋的地方就是浏览器同源策略问题,而跨域最好由server端来单独配置,这样的好处是当多个前端项目同时共用一套微服务接口时,就不用每个前端项目都配置一次跨域了。
我们写了三个基于socketio的视图方法,connect和disconnect顾名思义,当clinet发起连接或者断开时我们可以及时捕获到,而message方法就是前后端进行消息通信的重要方法。
发送消息的时候方法加了一个broadcast参数,这是socket.io极具特色的功能,类似广播的效果,可以同时给不同链接的client发送消息,即可以用于聊天,也可以用来做消息推送。
最后需要注意的一点是,client发送消息时,最好用urlencode编码一下,这样可以解决中文乱码问题,而在server端,可以用urllib.parse.unquote()来进行解码操作。
运行命令启动后端服务
python3 manage.py
服务正常启动在5000端口上,就说明后端没有问题了。
随后我们来配置前端(client),前端采用vue2.0框架来驱动,也需要安装socket.io模块
npm install vue-socket.io@2.1.0
这里一定要指定版本号来安装,版本是2.1.0,因为该依赖的最新版在vue2.0项目中编译时会报错
在入口文件main.js中引用
import VueSocketio from 'vue-socket.io';  
Vue.use(VueSocketio,'http://127.0.0.1:5000');
注意链接的url是后端服务的地址+端口,千万不要加其他url后缀或者命名空间
新建一个index.vue组件来进行模拟用户链接
<template>
  <div>  
	<div v-for="item in log_list"
	>
	{{item}}
  </div>  
	<input v-model="msg" />  
	<button @click="send">发送消息</button>  
</div>  
</template>  
<script>  
export default {
  data () {
    return {
	  msg: "",
	  log_list:[]
    }
  },
  //注册组件标签
  components:{  
  },
  sockets:{
    connect: function(){
      console.log('socket 连接成功')
    },
    message: function(val){
	  console.log('返回:'+val);
	this.log_list.push(val);
	}
},
  mounted:function(){  
},
  methods:{  
	send(){
	  this.$socket.emit('message',encodeURI("用户:"+this.msg));
    },  
  }
}  
</script>  
<style>  
</style>
启动前端服务
npm run dev
访问前端页面 http://localhost:8080 可以看到服务成功链接
这时可以尝试再做一个后台客服的组件页面item.vue,模拟用户和客服分别在不同的电脑进行聊天的场景
<template>
  <div>  
	<div v-for="item in log_list"
	>
	{{item}}
  </div>  
	<input v-model="msg" />  
	<button @click="send">发送消息</button>  
</div>  
</template>  
<script>  
export default {
  data () {
    return {
	  msg: "",
	  log_list:[]
    }
  },
  //注册组件标签
  components:{  
  },
  sockets:{
    connect: function(){
      console.log('socket 连接成功')
    },
    message: function(val){
	  console.log('返回:'+val);
	  this.log_list.push(val);
	}
},
  mounted:function(){  
},
  methods:{  
	send(){
	  this.$socket.emit('message',encodeURI("客服:"+this.msg));
    },  
  }
}  
</script>  
<style>  
</style>
效果是这样的:
整个流程还是相对简单的,比起django的dwebsocket模块,socket.io显然更加灵活和方便,如果需要做一些主动推送任务,也可以利用socket.io的广播功能,其原理和实时聊天是一样的。
原文转载自「刘悦的技术博客」 https://v3u.cn/a_id_158
后端Python3+Flask结合Socket.io配合前端Vue2.0实现简单全双工在线客服系统的更多相关文章
- 详解升讯威在线客服系统前端 JavaScript 脚本加密技术(1)
		
我在业余时间开发维护了一款免费开源的升讯威在线客服系统,也收获了许多用户.对我来说,只要能获得用户的认可,就是我最大的动力. 这段时间有几个技术小伙伴问了我一个有意思的问题:"你的前端脚本是 ...
 - 项目接入即时聊天客服系统(环信系统)PHP后端操作
		
环信工作原理: 一.由于环信没有直接的接口来主动调取本项目中的用户数据,所有用户信息必须在环信服务器上注册对应信息成为环信的用户:(这样才能当用户进入聊天时显示其基本信息,如:名称.昵称.电话.邮箱等 ...
 - Socket.io文字直播聊天室的简单代码
		
直接上代码吧,被注释掉的主要是调试代码,和技术选型的测试代码 var app = require('express')(); var server = require('http').Server(a ...
 - 使用Node.js+Socket.IO搭建WebSocket实时应用
		
Web领域的实时推送技术,也被称作Realtime技术.这种技术要达到的目的是让用户不需要刷新浏览器就可以获得实时更新.它有着广泛的应用场景,比如在线聊天室.在线客服系统.评论系统.WebIM等. W ...
 - (转)使用Node.js+Socket.IO搭建WebSocket实时应用
		
Web领域的实时推送技术,也被称作Realtime技术.这种技术要达到的目的是让用户不需要刷新浏览器就可以获得实时更新.它有着广泛的应用场景,比如在线聊天室.在线客服系统.评论系统.WebIM等. W ...
 - 使用Node.js+Socket.IO搭建WebSocket实时应用【转载】
		
原文:http://www.jianshu.com/p/d9b1273a93fd Web领域的实时推送技术,也被称作Realtime技术.这种技术要达到的目的是让用户不需要刷新浏览器就可以获得实时更新 ...
 - 反向Ajax之Socket.io
		
1.什么是反向ajax? 传统的ajax的困惑? 新需求--当服务器端数据发生变化时,客户端(浏览器端)如何即时得到通知呢? 找一些实际的案例:客服系统.在线聊天 这类应用,有一个显著的特点: 数据并 ...
 - Socket.IO介绍:支持WebSocket、用于WEB端的即时通讯的框架
		
一.基本介绍 WebSocket是HTML5的一种新通信协议,它实现了浏览器与服务器之间的双向通讯.而Socket.IO是一个完全由JavaScript实现.基于Node.js.支持WebSocket ...
 - 前端笔记之微信小程序(四)WebSocket&Socket.io&摇一摇案例&地图|地理位置
		
一.WebSocket概述 http://www.ruanyifeng.com/blog/2017/05/websocket.html Workerman一款开源高性能异步PHP socket即时通讯 ...
 
随机推荐
- 『忘了再学』Shell基础 — 15、环境变量(三)
			
目录 1.LANG语系变量介绍 2.如何查看Linux中支持的语系 3.查看当前系统的语系 4.总结 提示: 在Linux系统中,环境变量分为两种.一种是用户自定义的环境变量,另一种是系统自带的环境变 ...
 - L2M-GAN: Learning to Manipulate Latent Space Semantics for Facial Attribute Editing阅读笔记
			
L2M-GAN: Learning to Manipulate Latent Space Semantics for Facial Attribute Editing 2021 CVPR L2M-GA ...
 - 使用多线程提高REST服务器性能
			
异步处理REST服务 1.使用Runnable异步处理Rest服务 释放主线程,启用副线程进行处理,副线程处理完成后直接返回请求 主要代码 import java.util.concurrent.Ca ...
 - linux挂载新硬盘并进行分区格式化
			
最近要给小伙伴们写几篇文章,关于<linux下误删除文件之后该如何恢复>.对于没有进程占用的文件想要进行数据恢复,不同的文件系统格式需要使用不同的工具,比如:ext4.xfs等.我找遍了我 ...
 - Educatinal CF #122(Div. 2) E . Spanning Tree Queries
			
这一场其实有重大的意义,因为是除夕跨年,不过我FST掉大分了(ks) 题意:给你一个n点,m条边的带权图,q次询问,每次给你\(x\),每个边权为\(abs(E[i].w-x)\)答案为所有询问最小生 ...
 - Django-request的常见属性
			
瞧一瞧,看一看,Django时,获取Request的各个属性. Request的常见属性 request.META 返回一个python字典.它包含了所有的HTTP请求信息.如下代码: 点击查看代码 ...
 - 耗时半年,Eoapi 终于正式发布 API 工具的插件广场
			
这是我们的第一篇月报,每个月和每个来之不易的开发者分享产品故事以及产品进展. 在 5.20 这个极具中国特色的"节日"里,Eoapi 发布了 1.0.0 版,三个程序员掉了半年 ...
 - MVC - forward 和 redirect 的区别
			
MVC - forward 和 redirect 的区别 forward是服务器请求资源,服务器直接访问目标地址的URL,把那个URL的响应内容读取过来,然后把这些内容再发给浏览器,浏览器根本不知道服 ...
 - stm32f103ve+BH1750使用教程+oled(HAL库)
			
1.硬件:BH1750模块+oled 2.代码:BH1750是标准的iic协议的外设,我这里单独有iic的文件,之后想要实现多个设备共用一个iic. BH1750.c 1 #include " ...
 - C#中的String Interpolation
			
本文迁移自Panda666原博客,原发布时间:2021年4月17日. 在英文中,$符号表示美元符号(United States dollar).这也是很多人喜欢的东西.甚至是一生最求的东西.但在编程语 ...