Java 模拟基于TCP的Socket通信

简介: 效果图:单线程服务器多线程服务器客户端模拟多线程服务器代码import java.io.*;import java.

效果图:


img_58889e922b17d935e9ebc55794e3cc9e.png
单线程服务器
img_bbe93226258daca986477147df573c50.png
多线程服务器

img_749810a6d96284e202c8d72b5ac36f41.png
客户端模拟

多线程服务器代码

import java.io.*;
import java.net.InetAddress;
import java.net.ServerSocket;
import java.net.Socket;

public class MutiThreadServer implements Runnable {

    Socket socket;

    public MutiThreadServer(Socket socket) {
        this.socket = socket;
    }

    public static void main(String[] args) throws IOException {
        int count=0;
        ServerSocket serverSocket = new ServerSocket(1234);
        System.out.println("listening");
        while (true){
            Socket socket1 = serverSocket.accept();
            System.out.println("connected");
            new Thread(new MutiThreadServer(socket1)).start();
            count++;
            System.out.println("客户端的数量:"+count);
            InetAddress address = socket1.getInetAddress();
            System.out.println("当前客户端的IP为:"+ address.getHostAddress());
        }
    }

    @Override
    public void run() {
        InputStream inputStream=null; //字节输入流
        InputStreamReader inputStreamReader=null;  //把字节输入流转化为字符输入流
        BufferedReader bufferedReader=null;  //为输入流添加缓冲
        OutputStream outputStream=null;
        PrintWriter printWriter=null;
        try {
            /**
             * 获取客户端的输入信息
             */
            inputStream = socket.getInputStream();
            inputStreamReader = new InputStreamReader(inputStream);
            bufferedReader = new BufferedReader(inputStreamReader);
            String info = null;
            while ((info = bufferedReader.readLine()) != null){
                System.out.println("我是服务器,收到客户端信息:"+info);
            }
            socket.shutdownInput(); //关闭输入流

            /**
             * 响应客户端
             */
            //获取输出流,用于向服务器发送请求
            outputStream = socket.getOutputStream();
            //把输出流转化为打印流
            printWriter = new PrintWriter(outputStream);
            printWriter.write("用户名是:Harry 欢迎您!!!");
            printWriter.flush();



        } catch (IOException e) {
            e.printStackTrace();
        }finally {
            //关闭资源
            try {
                if (inputStream != null)
                    inputStream.close();

                if (inputStream != null)
                    inputStreamReader.close();

                if (bufferedReader != null) {
                    bufferedReader.close();
                }

                if (outputStream != null) {
                    outputStream.close();
                }

                if (printWriter != null) {
                    printWriter.close();
                }

                if (socket != null)
                    socket.close();
            } catch (IOException e) {
                e.printStackTrace();
            }

        }
    }

}

单线程服务器

import java.io.*;
import java.net.ServerSocket;
import java.net.Socket;

public class Server {
    public static void main(String[] args) throws IOException {
        /**
         * 创建一个服务器端的Socket,并指定要监听的端口
         */
        ServerSocket serverSocket = new ServerSocket(1234);
        System.out.println("````````````服务器即将启动````````````");
        /**
         * 启动监听
         */
        Socket socket = serverSocket.accept();

        /**
         * 获取客户端的输入信息
         */
        InputStream inputStream = socket.getInputStream(); //字节输入流
        InputStreamReader inputStreamReader = new InputStreamReader(inputStream);  //把字节输入流转化为字符输入流
        BufferedReader bufferedReader = new BufferedReader(inputStreamReader);  //为输入流添加缓冲
        String info = null;
        while ((info = bufferedReader.readLine()) != null){
            System.out.println("我是服务器,收到客户端信息:"+info);
        }
        socket.shutdownInput(); //关闭输入流

        /**
         * 响应客户端
         */
        OutputStream outputStream = socket.getOutputStream(); //获取输出流,用于向服务器发送请求
        PrintWriter printWriter = new PrintWriter(outputStream); //把输出流转化为打印流
        printWriter.write("用户名是:Harry 欢迎您!!!");
        printWriter.flush();

        //关闭资源
        printWriter.close();
        outputStream.close();
        bufferedReader.close();
        inputStreamReader.close();
        inputStream.close();
        socket.close();
        serverSocket.close();
    }
}

客户端

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

public class ClientSocket {
    public static void main(String[] args) throws IOException {
        /**
         * 创建一个客户端的Socket,并指定服务器地址和端口号
         */
        Socket socket = new Socket("localhost",1234);

        OutputStream outputStream = socket.getOutputStream(); //获取输出流,用于向服务器发送请求
        PrintWriter printWriter = new PrintWriter(outputStream); //把输出流转化为打印流
        printWriter.write("用户名是:Harry,密码是:123");
        printWriter.flush();

        socket.shutdownOutput(); //关闭输出流

        /**
         * 获取服务器的信息
         */
        InputStream inputStream = socket.getInputStream(); //字节输入流
        InputStreamReader inputStreamReader = new InputStreamReader(inputStream);  //把字节输入流转化为字符输入流
        BufferedReader bufferedReader = new BufferedReader(inputStreamReader);  //为输入流添加缓冲
        String info = null;
        while ((info = bufferedReader.readLine()) != null){
            System.out.println("我是客户端,收到服务器信息:"+info);
        }
        socket.shutdownInput(); //关闭输入流

        /**
         * 关闭资源
         */
        inputStream.close();
        inputStreamReader.close();
        bufferedReader.close();
        printWriter.close();
        outputStream.close();
        socket.close();
    }
}

注:测试的时候只需要启动其中一个服务器就即可。

目录
相关文章
|
8天前
|
Python
python socket 简单通信
python socket 简单通信
20 1
|
1天前
|
消息中间件 Java API
解密微服务架构:如何在Java中实现高效的服务通信
微服务架构作为一种现代软件开发模式,通过将应用拆分成多个独立的服务,提升了系统的灵活性和扩展性。然而,实现微服务之间的高效通信仍然是许多开发者面临的挑战。本文将探讨在Java环境中实现微服务架构时,如何使用不同的通信机制来优化服务之间的交互,包括同步和异步通信的方法,以及相关的最佳实践。
|
1天前
|
网络协议 Java
一文讲明TCP网络编程、Socket套接字的讲解使用、网络编程案例
这篇文章全面讲解了基于Socket的TCP网络编程,包括Socket基本概念、TCP编程步骤、客户端和服务端的通信过程,并通过具体代码示例展示了客户端与服务端之间的数据通信。同时,还提供了多个案例分析,如客户端发送信息给服务端、客户端发送文件给服务端以及服务端保存文件并返回确认信息给客户端的场景。
一文讲明TCP网络编程、Socket套接字的讲解使用、网络编程案例
|
17小时前
|
网络协议
socket编程(2) -- TCP通信
socket编程(2) -- TCP通信
9 0
|
26天前
|
Java
如何在Java中实现多线程的Socket服务器?
在Java中,多线程Socket服务器能同时处理多个客户端连接以提升并发性能。示例代码展示了如何创建此类服务器:监听指定端口,并为每个新连接启动一个`ClientHandler`线程进行通信处理。使用线程池管理这些线程,提高了效率。`ClientHandler`读取客户端消息并响应,支持简单的文本交互,如发送欢迎信息及处理退出命令。
|
5天前
|
Java
Java模拟文件发送给服务器,服务器将文件转发给其他用户,并保存到服务器本地,其他用户可以接收,并保存到本地磁盘,支持各种文件格式,并解决通信中服务器怎么区分客户端发来的文件类型
Java模拟文件发送给服务器,服务器将文件转发给其他用户,并保存到服务器本地,其他用户可以接收,并保存到本地磁盘,支持各种文件格式,并解决通信中服务器怎么区分客户端发来的文件类型
|
20天前
|
网络协议 Java 数据处理
(一)Java网络编程之计网基础、TCP-IP协议簇、TCP、UDP协议及腾讯QQ通信原理综述
就目前而言,多数网络编程的系列的文章都在围绕着计算机网络体系进行阐述,但其中太多理论概念,对于大部分开发者而言,用途甚微。因此,在本系列中则会以实际开发者的工作为核心,从Java程序员的角度出发,详细解读Java的网络编程核心内容。
|
26天前
|
网络协议 Java
如何在Java中使用Socket编程实现TCP连接?
在Java中,通过Socket编程实现TCP连接非常常见。以下演示了基本的TCP通信流程,可根据具体需求进行扩展。
|
1月前
|
Java 数据格式
Java面试题:简述Java Socket编程的基本流程,包括客户端和服务器的创建与通信。
Java面试题:简述Java Socket编程的基本流程,包括客户端和服务器的创建与通信。
29 0
|
2月前
|
缓存 监控 Java
Java Socket编程最佳实践:优化客户端-服务器通信性能
【6月更文挑战第21天】Java Socket编程优化涉及识别性能瓶颈,如网络延迟和CPU计算。使用非阻塞I/O(NIO)和多路复用技术提升并发处理能力,减少线程上下文切换。缓存利用可减少I/O操作,异步I/O(AIO)进一步提高效率。持续监控系统性能是关键。通过实践这些策略,开发者能构建高效稳定的通信系统。
73 1