使用Java 实现一个websocket
时间: 2024-05-06 14:20:26 浏览: 16
下面是一个简单的Java WebSocket实现示例:
1. 首先,需要导入Java WebSocket API,可以在Maven中添加以下依赖:
```xml
<dependency>
<groupId>javax.websocket</groupId>
<artifactId>javax.websocket-api</artifactId>
<version>1.1</version>
</dependency>
```
2. 创建一个类来实现WebSocketEndpoint:
```java
import java.io.IOException;
import javax.websocket.OnMessage;
import javax.websocket.Session;
import javax.websocket.server.ServerEndpoint;
@ServerEndpoint("/websocket")
public class WebSocketEndpoint {
@OnMessage
public void onMessage(String message, Session session) throws IOException {
// 处理收到的消息
session.getBasicRemote().sendText("收到消息:" + message);
}
}
```
3. 在Web应用程序中,需要在web.xml中注册WebSocketEndpoint:
```xml
<web-app>
<servlet>
<servlet-name>WebSocketServlet</servlet-name>
<servlet-class>org.apache.tomcat.websocket.server.WsSci</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>WebSocketServlet</servlet-name>
<url-pattern>/websocket/*</url-pattern>
</servlet-mapping>
</web-app>
```
4. 最后,创建一个HTML页面来测试WebSocket连接:
```html
<!DOCTYPE html>
<html>
<head>
<title>WebSocket测试</title>
</head>
<body>
<input type="text" id="message" placeholder="请输入消息" />
<button onclick="sendMessage()">发送</button>
<div id="output"></div>
<script>
var websocket = new WebSocket("ws://localhost:8080/your-webapp-context/websocket");
websocket.onopen = function(event) {
console.log("WebSocket已连接");
};
websocket.onmessage = function(event) {
document.getElementById("output").innerHTML += "<br>" + event.data;
};
function sendMessage() {
var message = document.getElementById("message").value;
websocket.send(message);
}
</script>
</body>
</html>
```
以上是一个简单的Java WebSocket实现示例,可以根据实际需求进行修改和扩展。
相关推荐
![rar](https://img-home.csdnimg.cn/images/20210720083606.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)