网站首页 > java教程 正文
TCP通信
- tcp消息一发一收
import java.io.*;
import java.net.ServerSocket;
import java.net.Socket;
/**
* 客服端
*/
public class ClinetDemo1 {
public static void main(String[] args) {
try {
System.out.println("客户端启动...");
// 创建socket 通信管道连接
String ip = "127.0.0.1";// 服务器端p
int port = 9999;// 服务端端口
Socket socket = new Socket(ip, port);
// 获取字节输出流
OutputStream os = socket.getOutputStream();
// 转换成打印流
PrintStream ps = new PrintStream(os);
// 输出数据
ps.println("我是客户端");
// 刷新数据
ps.flush();
} catch (IOException e) {
e.printStackTrace();
}
}
}
/**
* 服务端
*/
class ServerDemo1 {
public static void main(String[] args) {
try {
System.out.println("服务端启动...");
// 注册端口
int port = 9999;
ServerSocket serverSocket = new ServerSocket(port);
// 建立通信管道,阻塞等待接收客户端连接
Socket socket = serverSocket.accept();
// 读取管道数据字节流
InputStream is = socket.getInputStream();
// 字节流转换缓冲字符流
BufferedReader br = new BufferedReader(new InputStreamReader(is));
// 读取消息
String msg;
if ((msg = br.readLine()) != null) {
System.out.println(socket.getRemoteSocketAddress() + " 消息:" + msg);
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
- tcp消息多发多收,只能处理一个客户端
import java.io.*;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.Scanner;
/**
* 客服端
*/
public class ClinetDemo2 {
public static void main(String[] args) {
try {
System.out.println("客户端启动...");
// 创建socket 通信管道连接
String ip = "127.0.0.1";// 服务器端p
int port = 9999;// 服务端端口
Socket socket = new Socket(ip, port);
// 获取字节输出流
OutputStream os = socket.getOutputStream();
// 转换成打印流
PrintStream ps = new PrintStream(os);
// 输出数据
Scanner sc = new Scanner(System.in);
while (true) {
System.out.println("请输入:");
String msg = sc.nextLine();
ps.println(msg);
// 刷新数据
ps.flush();
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
/**
* 服务端
*/
class ServerDemo2 {
public static void main(String[] args) {
try {
System.out.println("服务端启动...");
// 注册端口
int port = 9999;
ServerSocket serverSocket = new ServerSocket(port);
// 建立通信管道,阻塞等待接收客户端连接
Socket socket = serverSocket.accept();
// 读取管道数据字节流
InputStream is = socket.getInputStream();
// 字节流转换缓冲字符流
BufferedReader br = new BufferedReader(new InputStreamReader(is));
// 读取消息
String msg;
while ((msg = br.readLine()) != null) {
System.out.println(socket.getRemoteSocketAddress() + " 消息:" + msg);
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
- tcp消息多发多收,处理多个客户端
import java.io.*;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.Scanner;
/**
* 服务端
*/
class ServerDemo3 {
public static void main(String[] args) {
try {
System.out.println("服务端启动...");
// 注册端口
int port = 9999;
ServerSocket serverSocket = new ServerSocket(port);
// 定义主线线程,负责接收socket管道
while (true) {
// 建立通信管道,阻塞等待接收客户端连接
Socket socket = serverSocket.accept();
// 子线程处理多个客户端
new ServerReaderThread(socket).start();
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
/**
* 服务端,线程类
*/
class ServerReaderThread extends Thread{
private Socket socket;
public ServerReaderThread(Socket socket) {
this.socket = socket;
}
@Override
public void run() {
try {
// 读取管道数据字节流
InputStream is = socket.getInputStream();
// 字节流转换缓冲字符流
BufferedReader br = new BufferedReader(new InputStreamReader(is));
// 读取消息
String msg;
while ((msg = br.readLine()) != null) {
System.out.println(socket.getRemoteSocketAddress() + " 消息:" + msg);
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
- tcp消息多发多收,线程池处理多个客户端
/**
* 服务端
*/
class ServerDemo4 {
// 使用静态变量记住一个线程池对象
private static ExecutorService pool = new ThreadPoolExecutor(3, 5,6,TimeUnit.SECONDS, new ArrayBlockingQueue<>(2), Executors.defaultThreadFactory(),new ThreadPoolExecutor.AbortPolicy());
public static void main(String[] args) {
try {
System.out.println("服务端启动...");
// 注册端口
int port = 9999;
ServerSocket serverSocket = new ServerSocket(port);
// 定义主线线程,负责接收socket管道
while (true) {
// 建立通信管道,阻塞等待接收客户端连接
Socket socket = serverSocket.accept();
// 线程池处理多个客户端
Runnable target = new ServerReaderRunnable(socket);
pool.execute(target);
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
/**
* 任务类
*/
class ServerReaderRunnable implements Runnable{
private Socket socket;
public ServerReaderRunnable(Socket socket) {
this.socket = socket;
}
@Override
public void run() {
try {
// 读取管道数据字节流
InputStream is = socket.getInputStream();
// 字节流转换缓冲字符流
BufferedReader br = new BufferedReader(new InputStreamReader(is));
// 读取消息
String msg;
while ((msg = br.readLine()) != null) {
System.out.println(socket.getRemoteSocketAddress() + " 消息:" + msg);
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
即时通信
import java.io.*;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;
/**
* 客服端
*/
public class ClinetDemo5 {
public static void main(String[] args) {
try {
System.out.println("客户端启动...");
// 创建socket 通信管道连接
String ip = "127.0.0.1";// 服务器端p
int port = 9999;// 服务端端口
Socket socket = new Socket(ip, port);
// 独立线程接收服务端消息
new ClinetReaderThread5(socket).start();
// 获取字节输出流
OutputStream os = socket.getOutputStream();
// 转换成打印流
PrintStream ps = new PrintStream(os);
// 输出数据
Scanner sc = new Scanner(System.in);
while (true) {
System.out.println("请输入:");
String msg = sc.nextLine();
ps.println(msg);
// 刷新数据
ps.flush();
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
/**
* 独立线程接收服务端消息
*/
class ClinetReaderThread5 extends Thread{
private Socket socket;
public ClinetReaderThread5(Socket socket) {
this.socket = socket;
}
@Override
public void run() {
try {
// 读取管道数据字节流
InputStream is = socket.getInputStream();
// 字节流转换缓冲字符流
BufferedReader br = new BufferedReader(new InputStreamReader(is));
// 读取消息
String msg;
while ((msg = br.readLine()) != null) {
System.out.println(socket.getRemoteSocketAddress()+ "收到消息:" + msg);
}
} catch (Exception e) {
System.out.println("服务器异常");
}
}
}
/**
* 服务端
*/
class ServerDemo5 {
// 存储所有在线socket 管道
public static List<Socket> allOnlineSockets = new ArrayList<>();
public static void main(String[] args) {
try {
System.out.println("服务端启动...");
// 注册端口
int port = 9999;
ServerSocket serverSocket = new ServerSocket(port);
// 定义主线线程,负责接收socket管道
while (true) {
// 建立通信管道,阻塞等待接收客户端连接
Socket socket = serverSocket.accept();
// 上线添加
allOnlineSockets.add(socket);
// 子线程处理多个客户端
new ServerReaderThread5(socket).start();
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
/**
* 服务端,线程类
*/
class ServerReaderThread5 extends Thread{
private Socket socket;
public ServerReaderThread5(Socket socket) {
this.socket = socket;
}
@Override
public void run() {
try {
// 读取管道数据字节流
InputStream is = socket.getInputStream();
// 字节流转换缓冲字符流
BufferedReader br = new BufferedReader(new InputStreamReader(is));
// 读取消息
String msg;
while ((msg = br.readLine()) != null) {
System.out.println(socket.getRemoteSocketAddress() + " 消息:" + msg);
// 端口转发
sendMsgToAll(msg);
}
} catch (Exception e) {
System.out.println(socket.getRemoteSocketAddress() + "下线");
// 下线移除
ServerDemo5.allOnlineSockets.remove(socket);
}
}
/**
* 端口转化数据
* @param msg
* @throws Exception
*/
private void sendMsgToAll(String msg) throws Exception {
for (Socket socket : ServerDemo5.allOnlineSockets) {
PrintStream ps = new PrintStream(socket.getOutputStream());
ps.println(msg);
ps.flush();
}
}
}
猜你喜欢
- 2024-09-10 Netty面试秘籍-1.什么是 Netty,它在网络编程中解决了什么问题?
- 2024-09-10 清华毕业大佬终于把Java网络编程面试题整理完了
- 2024-09-10 Java网络编程重点(java实现网络编程)
- 2024-09-10 Java学习:Java网络编程之TCP协议(java tcp ip socket编程)
- 2024-09-10 最全Java架构师技能树:Java编程+网络+设计模式+数据库+分布式
- 2024-09-10 Java网络编程之TCP服务器底层原理与实现
- 2024-09-10 Java面试八股文Netty网络编程,select
- 2024-09-10 Java 网络IO编程总结(网络编程java常用方法)
- 2024-09-10 想学习Java网络编程,从何入手?(java中的网络编程)
- 2024-09-10 不“精通”Java网络和并发编程也能学好Netty,这份Neety手册绝了
你 发表评论:
欢迎- 最近发表
-
- java8的stream使用小示例(java stream的用法)
- Java 中的 Lambda 表达式深入解析:从语法糖到高阶函数
- 实战解析Android架构设计原则(android的架构)
- 搭建mcp服务器用java17,可是项目开发用的是java8怎么实现?
- Java Stream:集合处理的api(java集合流操作)
- Java 8新特性全面剖析:让编程变得更简单优雅
- Java 8新特性全面解析与最佳实践:掌握未来编程的艺术
- Java 8日期时间API新特性揭秘与深度解析
- Java 8 Stream API 详解(java.stream)
- Java机器学习库(Java ML)(二、聚类)
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)