本文主要介绍如何使用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通讯实例相关推荐

  1. java中websocket_Java中使用webSocket

    Java中使用webSocket package com.yaoqi.controller.message; import javax.websocket.*; import javax.websoc ...

  2. Java 接受reactjs数据_[Java教程]react.js 父子组件数据绑定实时通讯

    [Java教程]react.js 父子组件数据绑定实时通讯 0 2017-09-23 17:00:14 import React,{Component} from 'react'import Reac ...

  3. NET中winform与webform互相通讯实例,CS调用BS页面的JS函数---转载

    原创:.NET中winform与webform互相通讯实例,CS调用BS页面的JS函数 时间:2009-12-11 21:09:32 来源:原创 作者:dodo - - 现在C#越来越多朋友使用了,大 ...

  4. Java写js的Ajax代码_用JS写的一个Ajax库(实例代码)

    myajax是一个用js编写的一个跨浏览器的ajax库,支持get, post, jsonp请求,精巧,简单. 一.发送GET请求: myajax.get({ data: {}, //参数 url: ...

  5. 使用Node.js+Socket.IO搭建WebSocket实时应用

    Web领域的实时推送技术,也被称作Realtime技术.这种技术要达到的目的是让用户不需要刷新浏览器就可以获得实时更新.它有着广泛的应用场景,比如在线聊天室.在线客服系统.评论系统.WebIM等. 作 ...

  6. java 推送数据给js,Node.js实现数据推送

    场景:后端更新数据推送到客户端(Java部分使用Tomcat服务器). 后端推送数据的解决方案有很多,比如轮询.Comet.WebSocket. 1. 轮询对于后端来说开发成本最低,就是按照传统的方式 ...

  7. bus.js非父子组件之间通讯

    bus.js非父子组件之间通讯 区别: bus.js就是一个公共的vue实例专门处理emit和on事件. vuex.js是做全局数据处理的,是指限定了对公共数据的使用处理方法,统一管控 vue中非父子 ...

  8. matlab 模拟心电图,使用原生js+canvas实现模拟心电图的实例

    从2015年2月转行进入IT行业,到现在也有将近两年的时间了,从最开始的java到现在的前端,前进的路上一直靠自己摸索,一路走到现在,前端大神是绝对谈不上的,最多算一只刚入门的菜鸟. 从最开始的懵懵懂 ...

  9. javascript java 传参_[Java教程]【JS】JavaScript中的参数传递

    [Java教程][JS]JavaScript中的参数传递 0 2017-02-18 00:00:24 ECMAScript中所有函数的参数都是按值传递的,简单讲就是函数外部的值 复制给函数内部的参数, ...

最新文章

  1. 小工具查看MYSQL数据文件块和类型
  2. 向spark standalone集群提交任务
  3. ITK:创建一个固定数组
  4. Vue中使用axios的响应拦截器处理请求失败的情况(处理token过期问题)以及 登录成功跳转回原来页面问题
  5. 中livechart显示大数据_大数据显示:辽宁新基建技能人才存量居全国第十位
  6. Java基础---Java---基础加强---内省的简单运用、注解的定义与反射调用、 自定义注解及其应用、泛型及泛型的高级应用、泛型集合的综合
  7. MMKV 原理以及使用
  8. msfconsole的简单使用
  9. plc仿真实训软件_博途STEP7仿真软件与真实PLC的区别
  10. #Excel公式应用#从数据透视表进一步汇总文本信息
  11. SpringBoot整合RedisTemplate实现缓存信息监控
  12. gcc -m32报错解决
  13. Java内存中神奇的64MB
  14. 【XSY2485】MST(最小生成树+倍增lca+并查集)
  15. office2020与2016版的不同_office2016与2019有什么区别_office2016与2019的区别详细说明...
  16. 微信小程序选项卡swiper默认高度150px(让高度实现自适应)怎么解决?
  17. 开源扫描仪的工具箱:安全行业从业人员自研开源扫描器合集
  18. 您的计算机无法启动f2,华硕笔记本电脑 开机按f2无法进入BIOS 无法进入安全模式 键盘键位失灵 仅开机键可用...
  19. 计算机一级找回隐藏,重现丢失误删隐藏的程序和文件
  20. SpringBoot集成MinIo实现资源库功能

热门文章

  1. 大数据学习(机器学习)初学者常犯的9个错误
  2. 栈与队列2:用队列实现栈
  3. html页面滚动会卡顿,HTML 如何避免页面卡顿
  4. 联想企业网盘3.60版本强势升级 大量用户提前体验
  5. java计算机毕业设计共享单车使用满意度评价系统源码+mysql数据库+系统+lw文档+部署
  6. Blog代码高亮无需插件 - 代码发芽网
  7. 三工业控制系统的安全性分析
  8. 公司拖欠工资,删代码删库跑路,违法么?
  9. Unity3D 的大场景内存优化
  10. 人脸识别扫描css动画js特效