用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();
    }
}

结果图:

相关推荐
0509152 分钟前
测试基础笔记第十一天
java·数据库·笔记
IDRSolutions_CN30 分钟前
如何将 PDF 中的文本提取为 JSON 格式
java·经验分享·pdf·软件工程·团队开发
xxy!32 分钟前
OSI七层模型和TCP/IP四层模型
网络·网络协议·tcp/ip
unique_pursuit42 分钟前
CS144 Lab 6 实战记录:构建 IP 路由器
网络·tcp/ip·智能路由器
摘星编程1 小时前
并发设计模式实战系列(6):读写锁
java·设计模式·并发编程
Java中文社群1 小时前
最火向量数据库Milvus安装使用一条龙!
java·人工智能·后端
Apache Flink1 小时前
京东物流基于Flink & StarRocks的湖仓建设实践
java·大数据·flink
JAVA百练成神1 小时前
深度理解spring——BeanFactory的实现
java·后端·spring
兔子蟹子2 小时前
Java集合框架解析
java·windows·python
DKPT2 小时前
正则表达式
java·数据库·笔记·学习·正则表达式