客户端向服务端发送信息

/*
 * 演示TCP传输
 * 1.分客户端对应对象Socket、服务端对应ServerSocket
 */
//需求:给服务端发送一个文本数据
/*步骤:
 * 1.创建Socket服务,并指定要连接的主机和端口
 * 
 * 
 */
public class TcClient {
public static void main(String[] args) throws UnknownHostException, IOException {
//创建客户端的socket服务,指定目的主机和端口
Socket s=new Socket("ip",10000);
OutputStream out=s.getOutputStream();//输出流
out.write("tcp come".getBytes());
s.close();
}

}

//************************************************

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


/*
 * 需求:定义端点接收数据并打印在控制台
 * 服务端:
 * 1.建立服务端的socket服务,并监听一个端口
 * 2.获取连接过来的对象
 * 通过serverSocket的accept方法 ,没有连接就会等待,所以是
 * 阻塞式的
 * 3. 客户端如果发过来数据,那么服务端要使用对应的客户端对象
 * 并且获取客户端对象的读取流来读取数据
 * 4.关闭服务端(可选)
 */
public class ServSocket {
public static void main(String[] args) throws IOException {

ServerSocket   ss=new ServerSocket(10000);
Socket s=ss.accept();
String ip=s.getInetAddress().getHostAddress();

System.out.println(ip);
InputStream in=s.getInputStream();
byte[] buf=new byte[1024];
int len=in.read(buf);
System.out.println(new String(buf,0,len));
}


}

在Java中整合Netty库来创建一个服务端,监听客户端的心跳请求通常涉及以下几个步骤: 1. **设置ServerBootstrap**: 首先,你需要创建一个`ServerBootstrap`实例,并配置它以监听特定的网络端口。 ```java EventLoopGroup bossGroup = new NioEventLoopGroup(); EventLoopGroup workerGroup = new NioEventLoopGroup(); ServerBootstrap b = new ServerBootstrap(); b.group(bossGroup, workerGroup) .channel(NioServerSocketChannel.class) .childHandler(new ChannelInitializer<SocketChannel>() { @Override protected void initChannel(SocketChannel ch) throws Exception { // 初始化新连接的通道处理器 ch.pipeline().addLast(new HeartbeatHandler()); } }); ``` 2. **心跳处理器(HeartbeatHandler)**: 创建一个名为`HeartbeatHandler`的处理器,用于处理心跳消息。在这个处理器中,你可以检查接收到的消息是否是心跳请求,如果是,则响应确认信息。 ```java public class HeartbeatHandler extends ChannelInboundHandlerAdapter { @Override public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception { if (msg instanceof String && "heartbeat".equals(msg)) { // 假设心跳消息是"heartbeat" ctx.writeAndFlush("Received heartbeat."); } else { super.channelRead(ctx, msg); } } // 其他必要的关闭、异常处理等方法... } ``` 3. **启动服务器**: 调用`bind()`方法开始监听,然后在适当的地方加入关闭事件循环组的逻辑。 ```java try { ChannelFuture future = b.bind(port).sync(); future.channel().closeFuture().sync(); } finally { bossGroup.shutdownGracefully(); workerGroup.shutdownGracefully(); } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ygl6150373

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值