websocket发送数据

1. 使用JSON格式传输参数

可以使用库如Jackson或Gson来处理JSON。

客户端发送JSON消息

javascript 复制代码
var socket = new WebSocket("ws://localhost:8080/ws");
socket.onopen = function() {
    var message = {
        "action": "greet",
        "name": "Alice"
    };
    socket.send(JSON.stringify(message));
};

服务器端解析JSON消息

java 复制代码
import com.fasterxml.jackson.databind.ObjectMapper; // Jackson库

// ... 在WebSocket的handler中

@Override
public void handleTextMessage(WebSocketSession session, TextMessage message) throws Exception {
    ObjectMapper mapper = new ObjectMapper();
    JsonNode jsonNode = mapper.readTree(message.getPayload());
    String action = jsonNode.get("action").asText();
    String name = jsonNode.get("name").asText();
    
    // 根据解析的参数执行相应操作
    if ("greet".equals(action)) {
        String response = "Hello, " + name + "!";
        session.sendMessage(new TextMessage(response));
    }
}

2. 使用查询参数式格式传输

客户端发送查询参数式消息

javascript 复制代码
var socket = new WebSocket("ws://localhost:8080/ws");
socket.onopen = function() {
    socket.send("action=greet&name=Alice");
};

服务器端解析查询参数式消息

java 复制代码
// ... 在WebSocket的handler中

@Override
public void handleTextMessage(WebSocketSession session, TextMessage message) throws Exception {
    String[] params = message.getPayload().split("&");
    Map<String, String> paramMap = new HashMap<>();
    for (String param : params) {
        String[] keyValue = param.split("=");
        paramMap.put(keyValue[0], keyValue[1]);
    }
    String action = paramMap.get("action");
    String name = paramMap.get("name");
    
    // 处理逻辑...
}

3. 使用XML格式传输参数

虽然XML相对于JSON更为冗长,但在某些情况下,它可能更为适合,特别是当消息结构复杂或需要与遗留系统集成时。

客户端发送XML消息

javascript 复制代码
var socket = new WebSocket("ws://localhost:8080/ws");
socket.onopen = function() {
    var xmlString = '<message><action>greet</action><name>Alice</name></message>';
    socket.send(xmlString);
};

服务器端解析XML消息

java 复制代码
import javax.xml.parsers.DocumentBuilder; // Java内置的XML解析器
import javax.xml.parsers.DocumentBuilderFactory;
import org.w3c.dom.Document;

// ... 在WebSocket的handler中

@Override
public void handleTextMessage(WebSocketSession session, TextMessage message) throws Exception {
    DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
    DocumentBuilder builder = factory.newDocumentBuilder();
    Document doc = builder.parse(new InputSource(new StringReader(message.getPayload())));
    
    String action = doc.getElementsByTagName("action").item(0).getTextContent();
    String name = doc.getElementsByTagName("name").item(0).getTextContent();
    
    // 处理逻辑...
}
相关推荐
桦说编程1 天前
Guava 迭代器增强类介绍
java·后端·设计模式
235161 天前
【JVM】Java为啥能跨平台?JDK/JRE/JVM的关系?
java·开发语言·jvm·spring boot·后端·spring·职场和发展
courtfu1 天前
Plugin ‘mysql_native_password‘ is not loaded`
java·后端
枫子有风1 天前
Go语言流程控制
android·java·golang
小裕哥略帅1 天前
订单管理--实时算出在途数量、收货数量、到货数量、已发货数量和未发货数量
java·开发语言
Dxxyyyy1 天前
零基础学JAVA--Day27(注释+异常+异常处理方法)
java·开发语言
好望角雾眠1 天前
第四阶段C#通讯开发-5:TCP
网络·笔记·网络协议·tcp/ip·c#
Craaaayon1 天前
如何选择两种缓存更新策略(写缓存+异步写库;写数据库+异步更新缓存)
java·数据库·redis·后端·缓存·mybatis
AAA卷不动了1 天前
JVM(二)------ 类加载、初始化与单例模式的联系
java·jvm·单例模式
一 乐1 天前
点餐|智能点餐系统|基于java+ Springboot的动端的点餐系统小程序(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·小程序·论文