一发一收
客户端
/**
*完成Socket网络编程入门案例的客户端开发,实现一发一收
*/
public class ClientDome1 {
public static void main(String[] args) {
try {
System.out.println("===============客户端启动=====================");
//1.创建socket通信管道,请求与服务器的连接
//参数一:服务器的IP地址
//参数二:服务器端口
Socket socket=new Socket("127.0.0.1",7777);
//2.从socket通信管道中得到一个字节输出流 负责发送数据
OutputStream os =socket.getOutputStream();
//3.把低级的字节流包装成打印流
PrintStream ps=new PrintStream(os);
//4.发送消息
ps.println("我是TCP的客户端");
ps.flush();
//关闭资源
//socket.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
服务端
/**
*目标:开发Socket网络编程入门代码服务端,实现接受消息
*/
public class ServerDome1 {
public static void main(String[] args) {
try {
System.out.println("===============服务端启动=====================");
//1.注册端口
ServerSocket serverSocket = new ServerSocket(7777);
//2.必须调用accept方法:等待接收客户端的Socket的连接请求,建立Socket通信管道
Socket socket = serverSocket.accept();
//从Socket通信管道中得到一个字节输入流
InputStream is=socket.getInputStream();
//4.把字节输入流包装成缓冲字符输入流进行消息的读取
/**
* 字符输入流是无法直接包装字节输入流
* 采用转换流将字节输入流转换成字符输入流
*/
BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(is));
//5.按行读取消息
String readLine;
if ((readLine=bufferedReader.readLine())!=null){
System.out.println(socket.getRemoteSocketAddress()+":"+readLine);
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
多发多收
客户端
/**
*完成Socket网络编程入门案例的客户端开发,实现多发多收
*/
public class ClientDome1 {
public static void main(String[] args) {
try {
System.out.println("===============客户端启动=====================");
//1.创建socket通信管道,请求与服务器的连接
//参数一:服务器的IP地址
//参数二:服务器端口
Socket socket=new Socket("127.0.0.1",7777);
//2.从socket通信管道中得到一个字节输出流 负责发送数据
OutputStream os =socket.getOutputStream();
//3.把低级的字节流包装成打印流
PrintStream ps=new PrintStream(os);
//4.发送消息
Scanner sc=new Scanner(System.in);
String msg;
while (true){
System.out.println("请说");
if ((msg=sc.nextLine())!=null){
ps.println(msg);
ps.flush();
}else if("exit".equals(msg)){
socket.close();
}
}
//关闭资源
//socket.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
服务端
package com.huang.socket2;
import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.ServerSocket;
import java.net.Socket;
/**
*目标:开发Socket网络编程入门代码服务端,实现接受消息
*/
public class ServerDome1 {
public static void main(String[] args) {
try {
System.out.println("===============服务端启动=====================");
//1.注册端口
ServerSocket serverSocket = new ServerSocket(7777);
//2.必须调用accept方法:等待接收客户端的Socket的连接请求,建立Socket通信管道
Socket socket = serverSocket.accept();
//从Socket通信管道中得到一个字节输入流
InputStream is=socket.getInputStream();
//4.把字节输入流包装成缓冲字符输入流进行消息的读取
/**
* 字符输入流是无法直接包装字节输入流
* 采用转换流将字节输入流转换成字符输入流
*/
BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(is));
//5.按行读取消息
String readLine;
while ((readLine=bufferedReader.readLine())!=null){
System.out.println(socket.getRemoteSocketAddress()+":"+readLine);
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
多线程多发多收
客户端
/**
*完成Socket网络编程入门案例的客户端开发,实现多发多收
*/
public class ClientDome1 {
public static void main(String[] args) {
try {
System.out.println("===============客户端启动=====================");
//1.创建socket通信管道,请求与服务器的连接
//参数一:服务器的IP地址
//参数二:服务器端口
Socket socket=new Socket("127.0.0.1",7777);
//2.从socket通信管道中得到一个字节输出流 负责发送数据
OutputStream os =socket.getOutputStream();
//3.把低级的字节流包装成打印流
PrintStream ps=new PrintStream(os);
//4.发送消息
Scanner sc=new Scanner(System.in);
String msg;
while (true){
System.out.println("请说");
if ((msg=sc.nextLine())!=null){
ps.println(msg);
ps.flush();
}else if("exit".equals(msg)){
socket.close();
}
}
//关闭资源
//socket.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
服务端
/**
*目标:实现服务端可以同时处理多个客户端的消息
*/
public class ServerDome1 {
public static void main(String[] args) {
try {
System.out.println("===============服务端启动=====================");
//1.注册端口
ServerSocket serverSocket = new ServerSocket(7777);
//定义一个死循环有主线程负责不断的接受客户端的Socket管道连接
while (true) {
//2.每接收到一个客户端的Socket管道,交给一个独立的子线程负责读取消息
Socket socket = serverSocket.accept();
System.out.println(socket.getRemoteSocketAddress()+"上线了");
//3.开始创建独立线程处理socket
new ServerReaderThread(socket).start();
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
创建线程管理管道
public class ServerReaderThread extends Thread{
private Socket socket;
public ServerReaderThread(Socket socket){
this.socket=socket;
}
@Override
public void run() {
try {
//从Socket通信管道中得到一个字节输入流
InputStream is=socket.getInputStream();
//4.把字节输入流包装成缓冲字符输入流进行消息的读取
/**
* 字符输入流是无法直接包装字节输入流
* 采用转换流将字节输入流转换成字符输入流
*/
BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(is));
//5.按行读取消息
String readLine;
while ((readLine=bufferedReader.readLine())!=null){
System.out.println(socket.getRemoteSocketAddress()+":"+readLine);
}
} catch (Exception e) {
System.out.println(socket.getRemoteSocketAddress()+"下线了");
}
}
}
线程池多收多发
客户端
/**
*拓展:使用线程池优化,实现通信。
*/
public class ClientDome1 {
public static void main(String[] args) {
try {
System.out.println("===============客户端启动=====================");
//1.创建socket通信管道,请求与服务器的连接
//参数一:服务器的IP地址
//参数二:服务器端口
Socket socket=new Socket("127.0.0.1",7777);
//2.从socket通信管道中得到一个字节输出流 负责发送数据
OutputStream os =socket.getOutputStream();
//3.把低级的字节流包装成打印流
PrintStream ps=new PrintStream(os);
//4.发送消息
Scanner sc=new Scanner(System.in);
String msg;
while (true){
System.out.println("请说");
if ((msg=sc.nextLine())!=null){
ps.println(msg);
ps.flush();
}else if("exit".equals(msg)){
socket.close();
}
}
//关闭资源
//socket.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
服务端
/**
*目标:实现服务端可以同时处理多个客户端的消息
*/
public class ServerDome1 {
//使用静态变量记住一个线程池对象
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("===============服务端启动=====================");
//1.注册端口
ServerSocket serverSocket = new ServerSocket(7777);
//定义一个死循环有主线程负责不断的接受客户端的Socket管道连接
while (true) {
//2.每接收到一个客户端的Socket管道,交给一个独立的子线程负责读取消息
Socket socket = serverSocket.accept();
System.out.println(socket.getRemoteSocketAddress()+"上线了");
//创建任务交给线程池
ServerReaderRunnable runnable = new ServerReaderRunnable(socket);
pool.execute(runnable);
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
创建线程池任务
public class ServerReaderRunnable implements Runnable{
private Socket socket;
public ServerReaderRunnable(Socket socket){
this.socket=socket;
}
@Override
public void run() {
try {
//从Socket通信管道中得到一个字节输入流
InputStream is=socket.getInputStream();
//4.把字节输入流包装成缓冲字符输入流进行消息的读取
/**
* 字符输入流是无法直接包装字节输入流
* 采用转换流将字节输入流转换成字符输入流
*/
BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(is));
//5.按行读取消息
String readLine;
while ((readLine=bufferedReader.readLine())!=null){
System.out.println(socket.getRemoteSocketAddress()+":"+readLine);
}
} catch (Exception e) {
System.out.println(socket.getRemoteSocketAddress()+"下线了");
}
}
}