java js websocket_java js实现Websocket通讯实例
本文主要介绍如何使用java实现websocket server,以及使用java、js生成websocket client进行通讯交互
1、java所需jar包
javax.websocket
javax.websocket-api
1.0
org.java-websocket
Java-WebSocket
1.3.0
2、java类server实现
import java.net.InetSocketAddress;
import java.util.List;
import java.util.Map;
import java.util.Set;
import org.java_websocket.WebSocket;
import org.java_websocket.handshake.ClientHandshake;
import org.java_websocket.server.WebSocketServer;
import com.google.common.collect.Lists;
import com.google.common.collect.Maps;
import com.yy.ent.commons.base.valid.BlankUtil;
public class MliveWebSocket extends WebSocketServer {
public static Map> socketMap = Maps.newHashMap();//频道-进入频道用户的连接列表
public MliveWebSocket(InetSocketAddress address) {
super(address);
}
/**
*
* @param address
* @param decoders用于限制websocket版本号
*/
public MliveWebSocket(InetSocketAddress address, int decoders) {
super(address, decoders);
}
@Override
public void onOpen(WebSocket conn, ClientHandshake handshake) {
System.out.println("onOpen");
String desc = handshake.getResourceDescriptor().substring(1);//例如页面请求:'ws://127.0.0.1:4444/'+topSid; desc获取到的就是topSid。此处以desc区分不同分类的连接,用于后续通讯
if(BlankUtil.isBlank(socketMap.get(desc))){
Listlist = Lists.newArrayList();
list.add(conn);//connect成功时候执行
socketMap.put(desc, list);
} else {
socketMap.get(desc).add(conn);
}
}
@Override
public void onClose(WebSocket conn, int code, String reason, boolean remote) {
System.out.println("onClose");
SetsetList = socketMap.keySet();
for (String string : setList) {
if (socketMap.get(string).contains(conn)) {
socketMap.get(string).remove(conn);//删除连接
if (socketMap.get(string).isEmpty()) {//连接为空时清除
socketMap.remove(string);
}
break;
}
}
}
@Override
public void onMessage(WebSocket conn, String message) {
System.out.println("onMessage");
System.out.println(message);
/*ListsocketList = socketMap.get(message);
for (WebSocket webSocket : socketList) {
webSocket.send("已收到~");
}*/
sendInAllChannel("~已收到~");//测试收到信息时全局发送消息
}
@Override
public void onError(WebSocket conn, Exception ex) {
System.out.println("onError");
SetsetList = socketMap.keySet();
for (String string : setList) {
if (socketMap.get(string).contains(conn)) {
socketMap.get(string).remove(conn);//删除连接
if (socketMap.get(string).isEmpty()) {//连接为空时清除
socketMap.remove(string);
}
break;
}
}
}
/**
* 服务端启动
* @param args
*/
public static void main(String[] args) {
InetSocketAddress address = new InetSocketAddress(4444);
MliveWebSocket socket = new MliveWebSocket(address);
socket.start();//启动websocket服务器进程
}
/**
* 发送消息到某一个连接
* @param channel
* @param message
*/
public void sendInOneChannel(String channel,String message){
Listlist = socketMap.get(channel);
for (WebSocket webSocket : list) {
webSocket.send(message);
}
}
/**
* 发送消息到所有连接
* @param message
*/
public void sendInAllChannel(String message){
SetsetList = socketMap.keySet();
for (String string : setList) {
Listlist = socketMap.get(string);
for (WebSocket webSocket : list) {
webSocket.send(message);
}
}
}
}
3、html5 js连接java server
function svc_connectPlatform(topSid) {
var wsServer = 'ws://127.0.0.1:4444/'+topSid;
try {
svc_websocket = new WebSocket(wsServer);
} catch (evt) {
console.log("new WebSocket error:" + evt.data);
svc_websocket = null;
if (typeof(connCb) != "undefined" && connCb != null)
connCb("-1", "connect error!");
return;
}
svc_websocket.onopen = svc_onOpen;
svc_websocket.onclose = svc_onClose;
svc_websocket.onmessage = svc_onMessage;
svc_websocket.onerror = svc_onError;
}
function svc_onOpen(evt) {
console.log("Connected to WebSocket server.");
}
function svc_onClose(evt) {
console.log("Disconnected");
}
function svc_onMessage(evt) {
console.log('Retrieved data from server: ' + evt.data);
}
function svc_onError(evt) {
console.log('Error occured: ' + evt.data);
}
function svc_send(msg) {
if (svc_websocket.readyState == WebSocket.OPEN) {
svc_websocket.send(msg);
} else {
console.log("send failed. websocket not open. please check.");
}
}
4、java实现websocket客户端
import java.net.URI;
import java.nio.channels.NotYetConnectedException;
import org.java_websocket.WebSocket.READYSTATE;
import org.java_websocket.client.WebSocketClient;
import org.java_websocket.handshake.ServerHandshake;
/**
* websocket java客户端
* @author Administrator
*
*/
public class MliveWebSocketClient extends WebSocketClient {
public MliveWebSocketClient(URI serverURI) {
super(serverURI);
// TODO Auto-generated constructor stub
}
@Override
public void onOpen(ServerHandshake handshakedata) {
// TODO Auto-generated method stub
System.out.println("onOpen");
}
@Override
public void onMessage(String message) {
// TODO Auto-generated method stub
System.out.println("onMessage");
System.out.println(message);
}
@Override
public void onClose(int code, String reason, boolean remote) {
// TODO Auto-generated method stub
System.out.println("onClose");
}
@Override
public void onError(Exception ex) {
// TODO Auto-generated method stub
System.out.println("onError");
}
public static void main(String[] args) {
MliveWebSocketClient client = new MliveWebSocketClient(URI.create("ws://127.0.0.1:4444/1111"));
try {
client.connect();
//NOT_YET_CONNECTED, CONNECTING, OPEN, CLOSING, CLOSED;连接的所有状态
int i = 0;
while(true){
if(client.getReadyState() == READYSTATE.OPEN){
client.send("hell0");//状态为open才可以发送消息
break;
} else if(client.getReadyState() != READYSTATE.CLOSED){
System.out.println(client.getReadyState()+""+(i++));
Thread.sleep(1000);
} else {
break;
}
}
} catch (NotYetConnectedException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
}
}
java js websocket_java js实现Websocket通讯实例相关推荐
- java中websocket_Java中使用webSocket
Java中使用webSocket package com.yaoqi.controller.message; import javax.websocket.*; import javax.websoc ...
- Java 接受reactjs数据_[Java教程]react.js 父子组件数据绑定实时通讯
[Java教程]react.js 父子组件数据绑定实时通讯 0 2017-09-23 17:00:14 import React,{Component} from 'react'import Reac ...
- NET中winform与webform互相通讯实例,CS调用BS页面的JS函数---转载
原创:.NET中winform与webform互相通讯实例,CS调用BS页面的JS函数 时间:2009-12-11 21:09:32 来源:原创 作者:dodo - - 现在C#越来越多朋友使用了,大 ...
- Java写js的Ajax代码_用JS写的一个Ajax库(实例代码)
myajax是一个用js编写的一个跨浏览器的ajax库,支持get, post, jsonp请求,精巧,简单. 一.发送GET请求: myajax.get({ data: {}, //参数 url: ...
- 使用Node.js+Socket.IO搭建WebSocket实时应用
Web领域的实时推送技术,也被称作Realtime技术.这种技术要达到的目的是让用户不需要刷新浏览器就可以获得实时更新.它有着广泛的应用场景,比如在线聊天室.在线客服系统.评论系统.WebIM等. 作 ...
- java 推送数据给js,Node.js实现数据推送
场景:后端更新数据推送到客户端(Java部分使用Tomcat服务器). 后端推送数据的解决方案有很多,比如轮询.Comet.WebSocket. 1. 轮询对于后端来说开发成本最低,就是按照传统的方式 ...
- bus.js非父子组件之间通讯
bus.js非父子组件之间通讯 区别: bus.js就是一个公共的vue实例专门处理emit和on事件. vuex.js是做全局数据处理的,是指限定了对公共数据的使用处理方法,统一管控 vue中非父子 ...
- matlab 模拟心电图,使用原生js+canvas实现模拟心电图的实例
从2015年2月转行进入IT行业,到现在也有将近两年的时间了,从最开始的java到现在的前端,前进的路上一直靠自己摸索,一路走到现在,前端大神是绝对谈不上的,最多算一只刚入门的菜鸟. 从最开始的懵懵懂 ...
- javascript java 传参_[Java教程]【JS】JavaScript中的参数传递
[Java教程][JS]JavaScript中的参数传递 0 2017-02-18 00:00:24 ECMAScript中所有函数的参数都是按值传递的,简单讲就是函数外部的值 复制给函数内部的参数, ...
最新文章
- 小工具查看MYSQL数据文件块和类型
- 向spark standalone集群提交任务
- ITK:创建一个固定数组
- Vue中使用axios的响应拦截器处理请求失败的情况(处理token过期问题)以及 登录成功跳转回原来页面问题
- 中livechart显示大数据_大数据显示:辽宁新基建技能人才存量居全国第十位
- Java基础---Java---基础加强---内省的简单运用、注解的定义与反射调用、 自定义注解及其应用、泛型及泛型的高级应用、泛型集合的综合
- MMKV 原理以及使用
- msfconsole的简单使用
- plc仿真实训软件_博途STEP7仿真软件与真实PLC的区别
- #Excel公式应用#从数据透视表进一步汇总文本信息
- SpringBoot整合RedisTemplate实现缓存信息监控
- gcc -m32报错解决
- Java内存中神奇的64MB
- 【XSY2485】MST(最小生成树+倍增lca+并查集)
- office2020与2016版的不同_office2016与2019有什么区别_office2016与2019的区别详细说明...
- 微信小程序选项卡swiper默认高度150px(让高度实现自适应)怎么解决?
- 开源扫描仪的工具箱:安全行业从业人员自研开源扫描器合集
- 您的计算机无法启动f2,华硕笔记本电脑 开机按f2无法进入BIOS 无法进入安全模式 键盘键位失灵 仅开机键可用...
- 计算机一级找回隐藏,重现丢失误删隐藏的程序和文件
- SpringBoot集成MinIo实现资源库功能