实现客户端——服务器端通信(tomcat)

目录

一、网络通讯七层模型

二、如何在某个应用程序,将数据写入网卡

三、实现源码

四、 设计缺点

为什么两个进程间使用字节的形式进行传输


一、网络通讯七层模型

二、如何在某个应用程序,将数据写入网卡

socket是个接口,通过线程(操作系统调用开辟的线程)读取数据

 代码实现一个 客户端发送,服务端接收的示例

三、实现源码

服务器ServerA
public class ServerA {
    //main是主线程对数据进行处理
    public static void main(String[] args) throws IOException {
        //监听端口号
        ServerSocket serverSocket = new ServerSocket(8080);
        System.out.println("ServerA started .....");

        while (true) {
            Socket socket = serverSocket.accept();//阻断监听
            //子线程 ----》 去网卡拿数据
            new Thread(new Runnable() {
                @Override
                public void run() {
                    try {
                        handler(socket);
                    } catch (IOException e) {
                        e.printStackTrace();
                    }
                }
            }).start();
        }
    }

    public static void handler(Socket socket) throws IOException {
        //读取数据
        InputStream inputStream = socket.getInputStream();
        //将010101这样的bit数据转化为  字符数据
        BufferedReader reader = new BufferedReader(new InputStreamReader(inputStream));
        String str = reader.readLine();
        System.out.println(str);
    }


}

客户端ServerB

public class ServerB {

    public static void main(String[] args) throws IOException {
        Socket socket = new Socket("127.0.0.1", 8080);
        System.out.println("ServerB started .....");

        Scanner scanner = new Scanner(System.in);
        String input = scanner.next();
        //获取输出流对象
        OutputStream outputStream = socket.getOutputStream();
        //将字符数据转化为bit信息
        PrintWriter writer = new PrintWriter(outputStream);
        writer.println(input);
        writer.flush();
        socket.close();
    }
}

先启动ServerA,在启动ServerB,在B中发送数据

四、 设计缺点:

 解决办法:

                可以用线程池解决

为什么两个进程间使用字节的形式进行传输

因为以字节形式传输,无法分割

猜你喜欢

转载自blog.csdn.net/weixin_51309915/article/details/125363717