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

结果图:

相关推荐
聪明的笨猪猪3 分钟前
Java Redis “运维”面试清单(含超通俗生活案例与深度理解)
java·经验分享·笔记·面试
FIavor.20 分钟前
怎么办这是Apifox里执行http://localhost:9002/goods/getByUserName?name=“张三“为什么我改了还是500?
java·网络·网络协议·http
编程饭碗22 分钟前
【Java集合】
java
岁岁岁平安22 分钟前
Java的双重检查锁机制(DCL)与懒加载的单例模式
java·单例模式·synchronized·
mit6.82424 分钟前
[cpprestsdk] http_client_config | GET | request()
网络·网络协议·http
Jabes.yang29 分钟前
Java面试场景:从Spring Boot到Kubernetes的技术问答
java· 面试· spring boot· 微服务· kubernetes· 技术栈· redis
小咕聊编程41 分钟前
【含文档+PPT+源码】基于SpringBoot+Gpt个人健康管理系统
java·gpt·tomcat·毕业设计·hibernate
00后程序员张1 小时前
tcpdump 抓包分析,命令、过滤技巧、常见症状定位与移动真机补充方案
网络·测试工具·ios·小程序·uni-app·iphone·tcpdump
阿无,1 小时前
Java设计模式之工厂模式
java·开发语言·设计模式
哎呀呦呵1 小时前
python内置模块-re模块介绍使用
java·python·mysql