前端websocket连接报错403_自己动手实现基于websocket的聊天web聊天功能高仿仿qq

基于websocket的聊天功能实现

1.前端咱们使用layui的前端框架layim组件,需要的同学直接进官网获取代码授权,不建议破解代码。

2.后端咱们写个简单的 websocket服务,由于时间有限我会抽空分步写出实现步骤,需要的同学关注,当然如果本身是大神可以绕道。

先给大家看一下效果图

登录

5298dd5780c99815f041b3d319326716.png

好友聊天

831671c19f7bcfdb959ba7bdc4fe0a8b.png

换肤功能

e9852811786fbcc045139551d2c03864.png

消息提示

ad722eca335cee3f7a5a88df01f18a1f.png

好友消息提示

66a168d292d8b8f100b1aa5547818d01.png

最近联系人和群

f3e5bdb5330dfcdca552baeec0e1db54.png

图片发送浏览

952c29158d7d3a25424aa01b1b92310b.png

qq基本功能都有,不一一介绍了

c8b4710a9ae5354163c0385fff400efc.png

再次向layui的作者闲心表示致敬

看完了效果咱们做做前端的准备工作

websocket前端相对比较简单,以前服务端作者用Tomcat7和Tomcat9的jar包,这两个版本会有些写法上的区别作者此处用Tomcat9作为服务端。

首先我们写一个调用连接服务的方法

function connection(){

//此处用于页面提示

tips.html("开始连接服务……");

//判断浏览器是否支持

if('WebSocket' in window){

//sy()获取服务器地址方法,imchat为websocket入口地址,id为接入参数,可以不要参数

websocket = new WebSocket("ws://"+sy()+"/imchat/"+id);

}else{

tips.html("不支持websocket");

}

//连接发生错误的回调方法

websocket.onerror = function(ev,data){

tips.html("连接发生错误的回调方法");

};

//连接成功建立的回调方法

websocket.onopen = function(e){

// alert('连接成功建立的回调方法');

tips.html("");

};

//接收到消息的回调方法

websocket.onmessage = function(event){

//接收到消息处理为json对象

var json=JSON.parse(event.data);

console.log("接收信息:");

console.log(event.data);

//判断消息类型

if(json.key=="offline"){

//设置用户离线 并提示

layim.setFriendStatus(json.id, 'offline');

layim.setChatStatus('离线');

layer.msg(json.content+"无法接收到消息

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值