java 集成 layIm 聊天工具

首先做个自我介绍,本人大学毕业两年,前两年都在花旗银行工作。银行大家都懂的,根本学不到新技术。so...技术不大好。但我有上进的心face[太开心] 哈哈,
用java集成了a(http://layim.layui.com/)[LayIM],基本功能都实现了


<1>离线消息接收(好友离线消息以及群组离线消息) 
<2>1-1发送消息(文字,图片,文件) 
<3> 群组消息(文字,图片,文件)
<4>聊天记录查询(好友聊天记录以及群聊天记录)
<5>群组管理(群主可以添加好用到群    群成员可以退出群).....


下面将实例展示给大家,不许偷笑哈,有什么问题我们可以一起探讨!
平台服务端用的框架是springmvc,总的来说,java集成layIm并不难,废话不多说。


1.初始化界面(加载成员列表,初始化群组,接收离线消息)


列表中的用户全是系统用户,由于本系统中存在角色,所以用角色名称当做组名称。(注意本系统只需要把所有用户查出来即可,默认所有人都已成为好友,是不是简单了很多啊face[偷笑] ,但这是一个坑,可能以后会改face[衰] )
初始化代码片段(socket)
[pre]
var etiger = {};
etiger.socket = {
webSocket:"",

init:function(){
if (!window.WebSocket){
alert("你的浏览器不支持websocket,请升级到IE10以上浏览器,或者使用谷歌、火狐、360浏览器。");
}
webSocket = new WebSocket(wsServer);
webSocket.onerror = function(event) {
 alert("websockt连接发生错误,请刷新页面重试!")
};


webSocket.onopen = function(event) {
//  webSocket.send("_online_user_"+currentId); 
};
webSocket.onmessage = function(event) {
var data = event.data;
console.log("lg:"+JSON.stringify(data));
if(data.indexOf("_online_all_status_")>=0){
}

if(data.indexOf('_sys_')>=0){//系统通知
               return;
}
if(data.indexOf('_msg_')>=0){
 //0.mine 1.type 2.id 3.name 4.avatar 5. content
 //聊天信息
  var arra = data.split("_msg_");
                       var mine = arra[0];
                       var type = arra[1];
                       var id = arra[2];
                       var name = arra[3];
                       var avatar = arra[4];
                       var content = arra[5];
                       layim.getMessage({
    username: name
       ,avatar: avatar
       ,id: mine
       ,type: type
       ,content: content
  });
 };
 }
},
send:function(data){
this.waitForConnection(function () {//连接建立才能发送消息
webSocket.send(data);
   }, 500);
}
,
sendData:function(data){
this.waitForConnection(function () {
webSocket.send(data);
   }, 500);
},


waitForConnection : function (callback, interval) {//判断连接是否建立

   if (webSocket.readyState === 1) {
       callback();
   } else {
       var that = this;
       setTimeout(function () {
           that.waitForConnection(callback, interval);
       }, interval);
   }
}
};


//初始化websocket by侯艳海
etiger.socket.init();
//获取离线消息  by侯艳海
etiger.socket.sendData("_online_user_"+currentId);
[/pre]
2.群组管理
本系统存在用户组管理模块,恰好与im结合,用户组即为群组,谁创建的谁为管理员! 群管理员可以删除群,同时可以删除群成员。
注:每个人只能修改自己所创建的群组


3.添加成员,退出群





4.发送文件,图片


5.个性签名修改,头像修改




6.查看聊天记录




附上java服务器端websocket推送消息代码片段:
1-1:[pre]
String state = "0";
if (TelChatSocketSessionUtils.hasConnection(toUser)) {
TelChatSocketSessionUtils.get(toUser).getAsyncRemote().sendText(_msg_);
state = "1";
}
//保存消息记录
ChatUtil.saveMessage(fromUser,toUser,"",message,state,type,name,avatar);
[/pre]


群组:
[pre]
_msg_ = groupId+"_msg_"+type+"_msg_"+groupId+"_msg_"+name+"_msg_"+avatar+"_msg_"+message;
for(int i = 0; i < memberList.size(); i++){
if (TelChatSocketSessionUtils.hasConnection(memberList.get(i))) {
TelChatSocketSessionUtils.get(memberList.get(i)).getAsyncRemote()
.sendText(_msg_);//
state = "1";
}
//保存消息记录
ChatUtil.saveMessage(fromUser,memberList.get(i),groupId,message,state,type,name,avatar);
}
//保存群消息
ChatUtil.saveMessage(fromUser,groupId,groupId,message,"1",type,name,avatar);
[/pre]


qq:1548638692 
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值