从零开始学Java Socket编程:客户端与服务器通信实战

简介: 【6月更文挑战第21天】Java Socket编程教程带你从零开始构建简单的客户端-服务器通信。安装JDK后,在命令行分别运行`SimpleServer`和`SimpleClient`。服务器监听端口,接收并回显客户端消息;客户端连接服务器,发送“Hello, Server!”并显示服务器响应。这是网络通信基础,为更复杂的网络应用打下基础。开始你的Socket编程之旅吧!

在编程的世界里,网络通信是不可或缺的一环,而Java Socket编程则是掌握这项技能的基石。本篇教程将以“从零开始”的理念,引导你逐步构建一个简单的客户端-服务器通信系统,无需任何先验知识,只需跟随步骤,即可体验Socket编程的魅力。

开始前的准备

在我们开始之前,确保你的开发环境已安装Java JDK。本教程将在命令行下进行,如果你使用的是IDE(如IntelliJ IDEA或Eclipse),也可以在相应的环境中运行代码。

第一步:创建服务器端

首先,我们来创建一个基本的服务器端。服务器的主要任务是监听特定端口上的连接请求,并能接收客户端发来的消息。

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

public class SimpleServer {
   
    public static void main(String[] args) {
   
        int port = 12345; // 监听的端口号
        try (ServerSocket serverSocket = new ServerSocket(port)) {
   
            System.out.println("Server started. Listening on port " + port);

            // 等待客户端连接
            Socket clientSocket = serverSocket.accept();
            System.out.println("Client connected.");

            // 创建输入流,用于读取客户端发来的消息
            BufferedReader in = new BufferedReader(
                new InputStreamReader(clientSocket.getInputStream())
            );

            // 创建输出流,用于向客户端发送消息
            PrintWriter out = new PrintWriter(
                new OutputStreamWriter(clientSocket.getOutputStream()), 
                true // 自动刷新缓冲区
            );

            String receivedMessage;
            while ((receivedMessage = in.readLine()) != null) {
   
                System.out.println("Received: " + receivedMessage);
                // 反馈消息给客户端
                out.println("Echo: " + receivedMessage);
            }

            // 关闭连接
            clientSocket.close();
        } catch (IOException e) {
   
            System.err.println("Error occurred: " + e.getMessage());
        }
    }
}

第二步:创建客户端

接下来,我们构建客户端,它将连接到上面创建的服务器,并发送一条消息,然后接收服务器的反馈。

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

public class SimpleClient {
   
    public static void main(String[] args) {
   
        String serverAddress = "localhost"; // 服务器地址
        int port = 12345; // 服务器监听的端口

        try (Socket socket = new Socket(serverAddress, port)) {
   
            System.out.println("Connected to server at " + serverAddress + ":" + port);

            // 创建输出流,用于向服务器发送消息
            PrintWriter out = new PrintWriter(
                new OutputStreamWriter(socket.getOutputStream()), 
                true // 自动刷新缓冲区
            );

            // 创建输入流,用于读取服务器发来的消息
            BufferedReader in = new BufferedReader(
                new InputStreamReader(socket.getInputStream())
            );

            // 向服务器发送消息
            out.println("Hello, Server!");

            // 接收服务器的反馈
            String receivedMessage = in.readLine();
            System.out.println("Received from server: " + receivedMessage);

            // 关闭连接
            socket.close();
        } catch (IOException e) {
   
            System.err.println("Error occurred: " + e.getMessage());
        }
    }
}

运行程序

现在,你可以先在命令行中运行SimpleServer,然后在另一个终端窗口中运行SimpleClient。观察服务器和客户端的控制台输出,你会发现客户端发送的消息被服务器接收,并原样返回给了客户端。

结语

恭喜你完成了第一个Socket编程项目!通过本教程,你不仅学习了如何创建服务器和客户端,还掌握了基本的网络通信原理。这是你迈向网络编程领域的重要一步。随着经验的积累,你将能够构建更复杂的应用,如多人聊天室、文件传输服务等。继续探索,Java Socket编程的世界正等着你去征服。

相关文章
|
存储 开发工具 git
[Git] 深入理解 Git 的客户端与服务器角色
Git 的核心设计理念是分布式,每个仓库既可以是客户端也可以是服务器。通过 GitHub 远程仓库和本地仓库的协作,Git 实现了高效的版本管理和代码协作。GitHub 作为远程裸仓库,存储项目的完整版本历史并支持多客户端协作;本地仓库则通过 `.git` 文件夹独立管理版本历史,可在离线状态下进行提交、回滚等操作,并通过 `git pull` 和 `git push` 与远程仓库同步。这种分布式特性使得 Git 在代码协作中具备强大的灵活性和可靠性。
[Git] 深入理解 Git 的客户端与服务器角色
|
人工智能 搜索推荐 程序员
用 Go 语言轻松构建 MCP 客户端与服务器
本文介绍了如何使用 mcp-go 构建一个完整的 MCP 应用,包括服务端和客户端两部分。 - 服务端支持注册工具(Tool)、资源(Resource)和提示词(Prompt),并可通过 stdio 或 sse 模式对外提供服务; - 客户端通过 stdio 连接服务器,支持初始化、列出服务内容、调用远程工具等操作。
2976 5
|
网络协议 开发者 Python
Socket如何实现客户端和服务器间的通信
通过上述示例,展示了如何使用Python的Socket模块实现基本的客户端和服务器间的通信。Socket提供了一种简单且强大的方式来建立和管理网络连接,适用于各种网络编程应用。理解和掌握Socket编程,可以帮助开发者构建高效、稳定的网络应用程序。
702 10
|
存储 人工智能 自然语言处理
ChatMCP:基于 MCP 协议开发的 AI 聊天客户端,支持多语言和自动化安装 MCP 服务器
ChatMCP 是一款基于模型上下文协议(MCP)的 AI 聊天客户端,支持多语言和自动化安装。它能够与多种大型语言模型(LLM)如 OpenAI、Claude 和 OLLama 等进行交互,具备自动化安装 MCP 服务器、SSE 传输支持、自动选择服务器、聊天记录管理等功能。
3006 16
ChatMCP:基于 MCP 协议开发的 AI 聊天客户端,支持多语言和自动化安装 MCP 服务器
|
开发框架 .NET C#
在 ASP.NET Core 中创建 gRPC 客户端和服务器
本文介绍了如何使用 gRPC 框架搭建一个简单的“Hello World”示例。首先创建了一个名为 GrpcDemo 的解决方案,其中包含一个 gRPC 服务端项目 GrpcServer 和一个客户端项目 GrpcClient。服务端通过定义 `greeter.proto` 文件中的服务和消息类型,实现了一个简单的问候服务 `GreeterService`。客户端则通过 gRPC 客户端库连接到服务端并调用其 `SayHello` 方法,展示了 gRPC 在 C# 中的基本使用方法。
479 5
在 ASP.NET Core 中创建 gRPC 客户端和服务器
|
网络协议 开发者 Python
深度探索Python Socket编程:从理论到实践,进阶篇带你领略网络编程的魅力!
【7月更文挑战第25天】在网络编程中, Python Socket编程因灵活性强而广受青睐。本文采用问答形式深入探讨其进阶技巧。**问题一**: Socket编程基于TCP/IP,通过创建Socket对象实现通信,支持客户端和服务器间的数据交换。**问题二**: 提升并发处理能力的方法包括多线程(适用于I/O密集型任务)、多进程(绕过GIL限制)和异步IO(asyncio)。**问题三**: 提供了一个使用asyncio库实现的异步Socket服务器示例,展示如何接收及响应客户端消息。通过这些内容,希望能激发读者对网络编程的兴趣并引导进一步探索。
366 4
|
开发者 Python
Python Socket编程:不只是基础,更有进阶秘籍,让你的网络应用飞起来!
【7月更文挑战第25天】在网络应用蓬勃发展的数字时代,Python凭借其简洁的语法和强大的库支持成为开发高效应用的首选。本文通过实时聊天室案例,介绍了Python Socket编程的基础与进阶技巧,包括服务器与客户端的建立、数据交换等基础篇内容,以及使用多线程和异步IO提升性能的进阶篇。基础示例展示了服务器端监听连接请求、接收转发消息,客户端连接服务器并收发消息的过程。进阶部分讨论了如何利用Python的`threading`模块和`asyncio`库来处理多客户端连接,提高应用的并发处理能力和响应速度。掌握这些技能,能使开发者在网络编程领域更加游刃有余,构建出高性能的应用程序。
235 3
|
网络协议 Python
网络世界的建筑师:Python Socket编程基础与进阶,构建你的网络帝国!
【7月更文挑战第26天】在网络的数字宇宙中,Python Socket编程是开启网络世界大门的钥匙。本指南将引领你从基础到实战,成为网络世界的建筑师。
322 2
|
消息中间件 网络协议 网络安全
Python Socket编程:打造你的专属网络通道,基础篇与进阶篇一网打尽!
【7月更文挑战第26天】在网络编程领域,Python以简洁语法和强大库支持成为构建应用的首选。Socket编程为核心,实现计算机间的数据交换。
395 1