Java一个简单的监听端口的类

 

package com.cn.ciecc.gfa.msg.utils;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.ServerSocket;
import java.net.Socket;

public class Test {

 /**
  * @param args
  * @throws IOException
  */
 public static void main(String[] args) throws Exception {
  // TODO Auto-generated method stub
   ServerSocket serverSocket;
   serverSocket = new ServerSocket(8082);
   while (true) {
    Socket socket = null;
    socket = serverSocket.accept(); // 等待客户连接
    InputStream socketIn = socket.getInputStream();
    BufferedReader br = new BufferedReader(new InputStreamReader(socketIn));
    String msg = null;
               while((msg=br.readLine())!=null){
                System.out.println(msg);
               }
   }
 }

}

### Java 实现端口监听的示例代码 以下是基于 `ServerSocket` 实现的一个简单端口监听示例。此方法适用于基础网络编程场景,能够监听特定 IP 和端口号上的数据。 ```java import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.net.ServerSocket; import java.net.Socket; public class PortListener { public static void main(String[] args) { int port = 8080; // 设置要监听端口号 try (ServerSocket serverSocket = new ServerSocket(port)) { // 创建并绑定到指定端口 System.out.println("服务器已启动,正在监听端口:" + port); while (true) { // 循环等待客户端连接 Socket socket = serverSocket.accept(); // 接受新的客户端连接 BufferedReader in = new BufferedReader(new InputStreamReader(socket.getInputStream())); String inputLine; StringBuilder clientMessage = new StringBuilder(); while ((inputLine = in.readLine()) != null) { // 读取客户端发送的数据 clientMessage.append(inputLine).append("\n"); } System.out.println("收到客户端消息:\n" + clientMessage.toString()); socket.close(); // 关闭当前会话 } } catch (IOException e) { System.err.println("发生错误:" + e.getMessage()); // 处理异常情况 } } } ``` 上述代码展示了如何使用 `ServerSocket` 来创建一个简单的服务端程序[^2]。该程序会在指定端口上持续运行,并接受来自客户端的消息。当接收到新连接时,它将读取消息并将内容打印至控制台。 #### 注意事项 - 需要在实际应用中考虑线程管理机制以支持并发访问。 - 如果需要更复杂的通信协议或者更高的性能需求,则可以引入 NIO 或者 AIO 技术替代传统的 BIO 模型。 --- ### Spring Boot 中多端口监听的实现方式 如果是在 Spring Boot 应用环境中,可以通过自定义 Tomcat 连接器的方式完成多端口监听的功能。以下是一个具体的例子: ```java import org.apache.catalina.connector.Connector; import org.springframework.boot.web.embedded.tomcat.TomcatServletWebServerFactory; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; @Configuration public class MultiPortConfig { @Bean public TomcatServletWebServerFactory servletContainer() { TomcatServletWebServerFactory tomcat = new TomcatServletWebServerFactory(); tomcat.addAdditionalTomcatConnectors(createStandardConnector()); return tomcat; } private Connector createStandardConnector() { Connector connector = new Connector("org.apache.coyote.http11.Http11NioProtocol"); connector.setScheme("http"); connector.setPort(9090); // 自定义第二个端口 connector.setRedirectPort(8443); return connector; } } ``` 在此配置下,除了默认的应用端口外,还会额外开启一个新的 HTTP 端口(此处设置为 9090),从而允许应用程序在同一实例中响应不同端口上的请求[^1]。 --- ### 使用 Kafka 监听 Topic 数据 对于分布式系统中的消息队列操作,比如通过 Kafka 订阅主题数据的情况,也可以借助其官方库轻松达成目标。这里给出一段典型的消费者逻辑作为参考: ```java import org.apache.kafka.clients.consumer.ConsumerRecord; import org.apache.kafka.clients.consumer.KafkaConsumer; import java.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值