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

结果图:

相关推荐
月明长歌13 小时前
【码道初阶】【LeetCode 160】相交链表:让跑者“起跑线对齐”的智慧
java·算法·leetcode·链表
菜鸟小芯13 小时前
OpenHarmony环境搭建——02-JDK17安装教程
java
咕噜签名-铁蛋13 小时前
火山引擎:字节跳动技术火山喷发,赋能千行百业智能升级
服务器·网络
开***能14 小时前
PROFINET转ASI网关:破解自动化异构网络互联难题的核心枢纽
运维·网络·自动化
蚁巡信息巡查系统14 小时前
网站风险词内容防控对网络安全管理有哪些影响
网络·内容运营
捷米研发三部14 小时前
ProfibusDP转ModbusTCP:工业通讯网关实现西门子S7-300PLC与MES生产线通信
服务器·网络
原来是好奇心14 小时前
深入Spring Boot源码(二):启动过程深度剖析
java·源码·springboot
听风吟丶14 小时前
Spring Boot 自动配置原理深度解析与实战
java·spring boot·后端
原来是好奇心14 小时前
深入Spring Boot源码(一):环境搭建与初探项目架构
java·gradle·源码·springboot