用java实现Client和Server之间的互相通信

概要:看过我之前文章的人都知道,client和server之间的通信必不可少的就是socket。而java已经帮我们做了很多事情。

创建Server端

第一步,创建ServerSocket

这个从名字上就可以看出来,服务器上的socket 0.0

复制代码
ServerSocket serverSocket = new ServerSocket(8888);

第二步,就是接受客户端传来的socket

复制代码
 Socket socket = serverSocket.accept();

第三步,便是创建输入流和输出流

复制代码
 BufferedReader in = new BufferedReader(new InputStreamReader(socket.getInputStream()));
 PrintWriter out = new PrintWriter(socket.getOutputStream(), true);

第四步,便是循环读取或者输出,dosomething

复制代码
        String message;
        while ((message = in.readLine()) != null) {
            System.out.println("收到客户端消息:" + message);
            out.println("服务器已收到消息:" + message);
        }

最后一定不要忘记了关闭这些

复制代码
        in.close();
        out.close();
        socket.close();
        serverSocket.close();

创建Client端

第一步,创建Socket

复制代码
Socket socket = new Socket("localhost", 8888);

第二步,便是建立输入流和输出流

复制代码
    BufferedReader in = new BufferedReader(new InputStreamReader(socket.getInputStream()));
    PrintWriter out = new PrintWriter(socket.getOutputStream(), true);
    BufferedReader keyboard = new BufferedReader(new InputStreamReader(System.in));

第三步,便是循环dosomething

复制代码
        String message;
        while (true) {
            System.out.print("请输入要发送的消息:");
            message = keyboard.readLine();
            out.println(message);

            String response = in.readLine();
            System.out.println("收到服务器回复:" + response);
        }

第四步,老样子,该关闭的关闭。

由于我这里写了while(true)已经写死了,就不用关闭了,因为也抵达不到那里去。

完整代码

复制代码
package org.cyl.database.net;

import java.io.*;
import java.net.*;

public class Client {
    public static void main(String[] args) throws IOException {
        Socket socket = new Socket("localhost", 8888);
        System.out.println("已连接到服务器");

        BufferedReader in = new BufferedReader(new InputStreamReader(socket.getInputStream()));
        PrintWriter out = new PrintWriter(socket.getOutputStream(), true);
        BufferedReader keyboard = new BufferedReader(new InputStreamReader(System.in));

        String message;
        while (true) {
            System.out.print("请输入要发送的消息:");
            message = keyboard.readLine();
            out.println(message);

            String response = in.readLine();
            System.out.println("收到服务器回复:" + response);
        }
    }
}

package org.cyl.database.net;
import java.io.*;
import java.net.*;

public class Server {
    public static void main(String[] args) throws IOException {
        ServerSocket serverSocket = new ServerSocket(8888);
        System.out.println("服务器已启动,等待客户端连接...");

        Socket socket = serverSocket.accept();
        System.out.println("客户端已连接,IP地址为:" + socket.getInetAddress().getHostAddress());

        BufferedReader in = new BufferedReader(new InputStreamReader(socket.getInputStream()));
        PrintWriter out = new PrintWriter(socket.getOutputStream(), true);

        String message;
        while ((message = in.readLine()) != null) {
            System.out.println("收到客户端消息:" + message);
            out.println("服务器已收到消息:" + message);
        }

        in.close();
        out.close();
        socket.close();
        serverSocket.close();
    }
}

结果图:

相关推荐
敲敲敲-敲代码5 分钟前
【ArcGIS10.2】网络数据集构建---最短路径分析
网络·arcgis
小莫分享43 分钟前
github 镜像节点
java
链上Sniper1 小时前
智能合约状态快照技术:实现 EVM 状态的快速同步与回滚
java·大数据·linux·运维·web3·区块链·智能合约
缘来是庄1 小时前
设计模式之建造者模式
java·设计模式·建造者模式
小湘西2 小时前
Apache HttpClient 的请求模型和 I/O 类型
java·http·apache
cliffordl2 小时前
MCP 传输机制(Streamable HTTP)
网络·网络协议·http
沃夫上校2 小时前
Feign调Post接口异常:Incomplete output stream
java·后端·微服务
晨曦丿2 小时前
双11服务器
linux·服务器·网络
q567315232 小时前
Java Selenium反爬虫技术方案
java·爬虫·selenium
张小洛2 小时前
Spring IOC容器核心阶段解密:★Bean实例化全流程深度剖析★
java·后端·spring·ioc容器·bean实例化