Java API 开发中使用 Websocket 进行实时通信

2023-07-04 0 2,163

随着互联网不断发展,Web 应用程序的实时性要求越来越高。而传统的 HTTP 协议并不能满足实时通信需求因为它是一种状态的请求-响应式通信方式,请求和响应之间是一个单向的短暂的连接。因此,为了满足实时通信的需求,Websocket 技术诞生了。Websocket 是一种全双工的、长连接的、实时的通信技术,它允许客户端和服务器之间建立一条持久化的双向连接,可以在通信过程中任意发送数据。

Java API(Application Programming Interface)作为一种开发语言,可以很方便地使用 Websocket 进行实时通信。Java API 提供了一些工具类和框架,使 Websocket 开发更简单、更高效。本文将从以下几个方面介绍 Java API 开发中如何使用 Websocket 进行实时通信。

一、Websocket 基础使用

Java API 提供了 JSR-356 标准,用于在 Java 语言中支持 Websocket 技术。Java API 中的 Websocket 接口提供了与 Websocket 相关的基本方法和事件处理方法,开发人员可以通过使用这些方法来实现自己的 Websocket 服务器和客户端。

使用 Java API 开发 Websocket 程序需要用到 javax.websocket.server.ServerEndpoint 注解和 javax.websocket.OnMessage 注解。其中,@ServerEndpoint 注解用于指定 Websocket 服务的 URL、编码方式(如 UTF-8)、消息处理器(即 WebSocketHandler)等配置信息。@OnMessage 注解用于声明一个指定类型的消息处理方法,该方法将在 Websocket 服务接收到客户端发送的消息时被调用。客户端发送消息时,消息将被提取并解析,然后传递给指定的消息处理方法进行处理。消息处理方法可以通过 Websocket Session 对象来发送响应消息。

下面是一个简单的示例代码:

@ServerEndpoint(value = "/test")
public class WebSocketDemo {

    @OnMessage
    public String handleMessage(String message, Session session) {
        System.out.println("Received message: " + message);
        String echoMsg = "Echo from server: " + message;

        // 发送响应消息
        try {
            session.getBasicRemote().sendText(echoMsg);
        } catch (IOException e) {
            e.printStackTrace();
        }

        return echoMsg;
    }
}

以上代码定义了一个名为 WebSocketDemo 的 WebSocket 处理器,绑定到 URL “/test”。当客户端发送消息时,WebSocketDemo 的 handleMessage 方法将被调用,并发送一个响应消息。

二、利用 Spring Boot 简化 Websocket 开发

Spring Boot 是一个基于 Spring 框架的开发框架,同时它也能很好地支持 Websocket。通过使用 Spring Boot,可以更加容易地集成 Websocket 技术到 Java API 项目中,从而加速应用程序的开发。

首先,需要在 Spring Boot 项目的 pom.xml 文件中添加以下依赖:

<dependency> 
   <groupId>org.springframework.boot</groupId> 
   <artifactId>spring-boot-starter-websocket</artifactId> 
</dependency>

然后,需要在 Spring Boot 应用程序中定义 WebSocketHandler 类。WebSocketHandler 类需要继承自 Spring 的 WebSocketHandler 接口,并实现一些基本方法,如 handleTextMessage() 方法,用于处理客户端发送的文本消息:

public class MyHandler extends TextWebSocketHandler {

   @Override
   public void handleTextMessage(WebSocketSession session, TextMessage message) 
           throws InterruptedException, IOException { 

        String payload = message.getPayload(); 

        // 处理消息
        String echoMsg = "Echo from server: " + payload;

        // 发送响应消息
        session.sendMessage(new TextMessage(echoMsg)); 
   } 

}

最后,需要在 Spring Boot 应用程序的配置文件中配置 WebSocket,如下所示:

@Configuration 
@EnableWebSocket 
public class WebSocketConfig implements WebSocketConfigurer { 

    @Override 
    public void registerWebSocketHandlers(WebSocketHandlerRegistry registry) { 

        registry.addHandler(new MyHandler(), "/myHandler").setAllowedOrigins("*"); 
   } 

}

在以上代码中,MyHandler 类将被绑定到 URL “/myHandler”,并设置了允许跨域请求。你可以实现自己的 WebSocket 处理器、修改 URL 或使用其他配置选项。使用 Spring Boot 可以为 Websocket 开发提供很多方便,简化开发流程。

三、利用 JavaScript 开发 Websocket 客户端

在使用 Java API 开发 Websocket 服务器的同时,我们需要开发 Websocket 客户端来与服务器进行通信。Javascript 的 websocket API 可以让我们轻松地在 Web 应用程序中使用 Websocket 实现客户端通信。

在 Javascript 中使用 Websocket,首先需要创建 Websocket 对象并指定 Websocket 服务器地址:

var ws = new WebSocket("ws://localhost:8080/test");

然后,可以使用以下代码发送消息并接收来自 Websocket 服务器的响应消息:

ws.onopen = function() {
   alert("Websocket连接已建立!");
   ws.send("Hello world!");
}; 

ws.onmessage = function(evt) {
   var receivedMsg = evt.data;
   alert("Received message: " + receivedMsg);
   ws.close();
};

以上代码将会连接到 URL 为 ws://localhost:8080/test 的 Websocket 服务器,并发送一条包含字符串 “Hello world!” 的消息。当服务器处理该消息后,便会发送响应消息,最终客户端会收到响应消息并关闭连接。

四、Websocket 实现类似聊天室的应用

通过以上的介绍,相信大家已经了解了如何使用 Java API 进行 Websocket 编程,以及如何使用 Javascript 客户端与之进行通信。接下来,我们可以尝试使用 Websocket 实现一个简单的聊天室应用。

首先,需要使用 Java API 实现一个 Websocket 处理器用于处理 Websocket 客户端发送的消息:

@ServerEndpoint(value = "/chat/{username}")
public class ChatServer {

    private static Set<Session> clients = Collections.synchronizedSet(new HashSet<>());

    @OnOpen
    public void onOpen(Session session, @PathParam("username") String username) {
        // 将用户加入到聊天室中
        clients.add(session);

        // 广播消息
        broadcast(username, " joined the chat room!");
    }

    @OnMessage
    public void onMessage(String message, Session session, @PathParam("username") String username) {
        // 广播消息
        broadcast(username, ": " + message);
    }

    @OnClose
    public void onClose(Session session, @PathParam("username") String username) {
        // 将用户从聊天室中移除
        clients.remove(session);

        // 广播消息
        broadcast(username, " left the chat room!");
    }

    private static void broadcast(String username, String message) {
        // 向所有用户广播消息
        for (Session client : clients) {
            try {
                client.getBasicRemote().sendText(username + message);
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }
}

以上代码定义了一个名为 ChatServer 的 Websocket 处理器,绑定到 URL “/chat/{username}”。当客户端连接到聊天室时,ChatServer 的 onOpen 方法将被调用,并将客户端添加到 clients 集合中,然后广播一条 “加入聊天室” 的消息。当客户端在聊天室中发送一条消息时,ChatServer 的 onMessage 方法将被调用,并向聊天室的所有客户端广播一条消息。当客户端离开聊天室时,ChatServer 的 onClose 方法将被调用,并将客户端从 clients 集合中移除,然后广播一条 “离开聊天室” 的消息。

然后,需要使用简单的 HTML 和 Javascript 代码实现一个 Websocket 客户端:

<!DOCTYPE html>
<html>
<head>
   <title>Chat room</title>
</head>
<body>
   <h1>Chat room</h1>
   <div id="messageArea"></div>
   <form>
       <input type="text" id="inputField" onkeydown="return send(event)">
   </form>

   <script>
       var ws = new WebSocket("ws://localhost:8080/chat/"+prompt("Please enter your name:"));

       ws.onmessage = function(evt) {
           var receivedMsg = evt.data;
           var messageArea = document.getElementById("messageArea");
           messageArea.innerHTML += receivedMsg + "<br>";
       };

       function send(event) {
           if (event.keyCode == 13) {
               event.preventDefault();
               var inputField = document.getElementById("inputField")
               ws.send(inputField.value);
               inputField.value = "";
               return false;
           }
       }
   </script>
</body>
</html>

以上代码将会要求用户输入他们的名称,然后使用 Websocket 连接到 ChatServer 上。用户可以在输入框中输入文本并按下回车键进行发送。当接收到来自 ChatServer 的消息时,HTML 页面将在聊天窗口底部添加一条新的消息。

通过使用 Java API 和 Websocket 技术,我们可以方便地实现高效、实时的 Web 应用程序。无论你是在开发聊天室、在线游戏还是其他实时 Web 应用程序,Websocket 都可以是一个很好的选择。现在开始尝试使用 Websocket,构建自己的实时 Web 应用程序吧!

资源下载此资源下载价格为1小猪币,终身VIP免费,请先
由于本站资源来源于互联网,以研究交流为目的,所有仅供大家参考、学习,不存在任何商业目的与商业用途,如资源存在BUG以及其他任何问题,请自行解决,本站不提供技术服务! 由于资源为虚拟可复制性,下载后不予退积分和退款,谢谢您的支持!如遇到失效或错误的下载链接请联系客服QQ:442469558

:本文采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可, 转载请附上原文出处链接。
1、本站提供的源码不保证资源的完整性以及安全性,不附带任何技术服务!
2、本站提供的模板、软件工具等其他资源,均不包含技术服务,请大家谅解!
3、本站提供的资源仅供下载者参考学习,请勿用于任何商业用途,请24小时内删除!
4、如需商用,请购买正版,由于未及时购买正版发生的侵权行为,与本站无关。
5、本站部分资源存放于百度网盘或其他网盘中,请提前注册好百度网盘账号,下载安装百度网盘客户端或其他网盘客户端进行下载;
6、本站部分资源文件是经压缩后的,请下载后安装解压软件,推荐使用WinRAR和7-Zip解压软件。
7、如果本站提供的资源侵犯到了您的权益,请邮件联系: 442469558@qq.com 进行处理!

猪小侠源码-最新源码下载平台 Java教程 Java API 开发中使用 Websocket 进行实时通信 http://www.20zxx.cn/774814/xuexijiaocheng/javajc.html

猪小侠源码,优质资源分享网

常见问题
  • 本站所有资源版权均属于原作者所有,均只能用于参考学习,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担
查看详情
  • 最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,建议提前注册好百度网盘账号,使用百度网盘客户端下载
查看详情

相关文章

官方客服团队

为您解决烦忧 - 24小时在线 专业服务