Java Socket编程示例:服务器开启在8080端口监听,接收客户端连接并打印消息。

简介: 【6月更文挑战第23天】Java Socket编程示例:服务器开启在8080端口监听,接收客户端连接并打印消息。客户端连接服务器,发送"Hello, Server!"后关闭。注意Android中需避免主线程进行网络操作。

在Java中创建Socket连接通常涉及到客户端和服务器端的编程。以下是一个简单的例子,说明如何在Java中创建一个基本的Socket连接:

1. 创建服务器端(Server):

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

public class Server {
   
    public static void main(String[] args) throws IOException {
   
        // 创建一个ServerSocket对象,并绑定到特定的端口
        ServerSocket serverSocket = new ServerSocket(8080);

        System.out.println("Server started on port " + serverSocket.getLocalPort());

        while (true) {
   
            // 等待客户端的连接请求
            Socket socket = serverSocket.accept();

            System.out.println("New client connected: " + socket.getInetAddress().getHostAddress());

            // 获取输入流并读取客户端发送的消息
            BufferedReader in = new BufferedReader(new InputStreamReader(socket.getInputStream()));
            String inputLine;
            while ((inputLine = in.readLine()) != null) {
   
                System.out.println("Received message from client: " + inputLine);
            }

            // 关闭输入流、输出流和Socket连接
            in.close();
            socket.close();
        }
    }
}

2. 创建客户端(Client):

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

public class Client {
   
    public static void main(String[] args) throws IOException {
   
        // 创建一个Socket对象,指定要连接的服务器地址和端口号
        Socket socket = new Socket("localhost", 8080);

        System.out.println("Connected to server at " + socket.getInetAddress().getHostAddress());

        // 获取输出流并向服务器发送消息
        PrintWriter out = new PrintWriter(socket.getOutputStream(), true);
        out.println("Hello, Server!");

        // 关闭输出流、输入流和Socket连接
        out.close();
        socket.close();
    }
}

这个例子中,服务器监听在本地主机的8080端口上,等待客户端的连接请求。一旦有客户端连接,服务器就接收客户端发送的消息,并将其打印出来。

请注意,在Android环境中,从主线程直接调用网络操作是不允许的,你需要使用异步任务或者线程来处理网络通信以避免阻塞UI线程。

相关文章
|
2月前
|
存储 Java API
Java实现导出多个excel表打包到zip文件中,供客户端另存为窗口下载
Java实现导出多个excel表打包到zip文件中,供客户端另存为窗口下载
122 4
|
4月前
|
JSON NoSQL Java
redis的java客户端的使用(Jedis、SpringDataRedis、SpringBoot整合redis、redisTemplate序列化及stringRedisTemplate序列化)
这篇文章介绍了在Java中使用Redis客户端的几种方法,包括Jedis、SpringDataRedis和SpringBoot整合Redis的操作。文章详细解释了Jedis的基本使用步骤,Jedis连接池的创建和使用,以及在SpringBoot项目中如何配置和使用RedisTemplate和StringRedisTemplate。此外,还探讨了RedisTemplate序列化的两种实践方案,包括默认的JDK序列化和自定义的JSON序列化,以及StringRedisTemplate的使用,它要求键和值都必须是String类型。
redis的java客户端的使用(Jedis、SpringDataRedis、SpringBoot整合redis、redisTemplate序列化及stringRedisTemplate序列化)
|
3月前
|
分布式计算 Java Hadoop
Hadoop-30 ZooKeeper集群 JavaAPI 客户端 POM Java操作ZK 监听节点 监听数据变化 创建节点 删除节点
Hadoop-30 ZooKeeper集群 JavaAPI 客户端 POM Java操作ZK 监听节点 监听数据变化 创建节点 删除节点
90 1
|
5月前
|
Java
Java使用FileInputStream&&FileOutputStream模拟客户端向服务器端上传文件(单线程)
Java使用FileInputStream&&FileOutputStream模拟客户端向服务器端上传文件(单线程)
103 1
|
5月前
|
缓存 NoSQL 网络安全
【Azure Redis 缓存】使用开源工具redis-copy时遇见6379端口无法连接到Redis服务器的问题
【Azure Redis 缓存】使用开源工具redis-copy时遇见6379端口无法连接到Redis服务器的问题
|
6月前
|
弹性计算 应用服务中间件 Linux
阿里云服务器开放端口完整图文教程
笔者近期开发完成的服务端程序部署在阿里云的ECS云服务器上面,一些应用程序配置文件需要设置监听的端口(如Tomcat的8080、443端口等),虽然通过CentOs 7系统的的「防火墙」开放了对应的端口号,任然无法访问端口号对应的应用程序,后面了解到原来还需要设置云服务器的「安全组规则」,开放相应的端口权限,服务端的接口才能真正开放。
802 1
|
6月前
|
弹性计算 运维 数据安全/隐私保护
云服务器 ECS产品使用问题之如何更改服务器的IP地址或端口号
云服务器ECS(Elastic Compute Service)是各大云服务商阿里云提供的一种基础云计算服务,它允许用户租用云端计算资源来部署和运行各种应用程序。以下是一个关于如何使用ECS产品的综合指南。
|
6月前
|
网络协议 Linux Unix
面试官:服务器最大可以创建多少个tcp连接以及端口并解释下你对文件句柄的理解
面试官:服务器最大可以创建多少个tcp连接以及端口并解释下你对文件句柄的理解
163 0
面试官:服务器最大可以创建多少个tcp连接以及端口并解释下你对文件句柄的理解
|
5月前
|
网络协议
【qt】TCP的监听 (设置服务器IP地址和端口号)
【qt】TCP的监听 (设置服务器IP地址和端口号)
318 0
|
6月前
|
存储 安全 网络安全
服务器设置了端口映射之后外网还是访问不了服务器
服务器设置了端口映射之后外网还是访问不了服务器