Tcp通信

一发一收

客户端

/**
 *完成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()+"下线了");
        }
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值