JAVA BIO 服务器与客户端实现示例

简介:

代码只兼容JAVA 7及以上版本。


服务器端代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
package  com.stevex.app.bio;
 
import  java.io.BufferedReader;
import  java.io.IOException;
import  java.io.InputStreamReader;
import  java.io.PrintWriter;
import  java.net.ServerSocket;
import  java.net.Socket;
 
import  javax.net.ServerSocketFactory;
 
public  class  XiaoNa {
     public  static  void  main(String[] args){
         XiaoNa xiaona =  new  XiaoNa();
         
         ServerSocket serverSocket =  null ;
         Socket socket =  null ;
 
         try  {
             //可以设置客户连接请求队列的长度,比如5,队列长度超过5后拒绝连接请求
             //serverSocket = ServerSocketFactory.getDefault().createServerSocket(8383, 5);      
             serverSocket = ServerSocketFactory.getDefault().createServerSocket( 8383 );
             
             while ( true ){
                 try {
                     //监听直到接受连接后返回一个新Socket对象
                     socket = serverSocket.accept(); //阻塞
                     //new一个线程处理连接请求
                     new  Thread(xiaona. new  Worker(socket)).start();;
                 }
                 catch  (Throwable e) {     //防止发生异常搞死服务器          
                     e.printStackTrace();
                 }              
             }          
         catch  (IOException e) {              
             e.printStackTrace();
         }
         finally {               
             try  {             
                 if (socket !=  null ){
                     socket.close();
                 }
             catch  (IOException e) {
                 e.printStackTrace();
             }  
         }
     }
     
     private  static  String getAnswer(String question){
         String answer =  null ;
         
         switch (question){
         case  "who" :
             answer =  "我是小娜" ;
             break ;
         case  "what" :
             answer =  "我是来帮你解闷的" ;
             break ;
         case  "where" :
             answer =  "我来自外太空" ;
             break ;
         default :
                 answer =  "请输入 who, 或者what, 或者where" ;
         }
         
         return  answer;
     }
     
     private  class  Worker  implements  Runnable{
         private  Socket socket;
         
         public  Worker(Socket socket){
             this .socket = socket;
         }
         
         @Override
         public  void  run() {
             BufferedReader reader =  null ;
             PrintWriter writer =  null ;
             
             try  {
                 reader =  new  BufferedReader( new  InputStreamReader(socket.getInputStream()));
             
                 writer =  new  PrintWriter(socket.getOutputStream());
                 
                 String question = reader.readLine(); //没有内容会阻塞
                 
                 while (!question.equals( "OVER" )){
                     String answer = getAnswer(question);
                     writer.println(answer);
                     question = reader.readLine();
                 }
                 
                 writer.println( "OVER" ); //OVER作为操作完成暗号
                 writer.flush();
                 
                 if (writer !=  null ){
                     writer.close();
                 }
                                     
                 if (reader !=  null ){
                     reader.close();
                 }
             catch  (IOException e) {
                 e.printStackTrace();
             }
         }
         
     }
}


客户端代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
package  com.stevex.app.bio;
 
import  java.io.BufferedReader;
import  java.io.IOException;
import  java.io.InputStreamReader;
import  java.io.PrintWriter;
import  java.net.Socket;
 
public  class  Client {
     public  static  void  main(String[] args) {
         Client c =  new  Client();
         
         //种20个线程发起Socket客户端连接请求
         for ( int  i= 0 ; i< 20 ; i++){
             new  Thread(c. new  Worker()).start();
         }      
     }
     
     private  class  Worker  implements  Runnable{
 
         @Override
         public  void  run() {
             Socket socket =  null ;
             BufferedReader reader =  null ;
             PrintWriter writer =  null ;
 
             try  {
                 //创建一个Socket并连接到指定的目标服务器
                 socket =  new  Socket( "localhost" 8383 );
 
                 reader =  new  BufferedReader( new  InputStreamReader(
                         socket.getInputStream()));
                 writer =  new  PrintWriter(socket.getOutputStream());
 
                 writer.println( "who" );
                 writer.println( "what" );
                 writer.println( "where" );
                 writer.println( "OVER" ); //OVER作为操作完成暗号
                 writer.flush();
 
                 String answer = reader.readLine();    //没有内容会阻塞      
                 while (! answer.equals( "OVER" )){               
                     System.out.println(Thread.currentThread().getId() +  "---Message from server:"  + answer);
                     answer = reader.readLine();
                 }
 
             catch  (IOException e) {
                 e.printStackTrace();
             finally  {
                 try  {
                     if  (writer !=  null ) {
                         writer.close();
                     }
 
                     if  (reader !=  null ) {
                         reader.close();
                     }
 
                     if  (socket !=  null ) {
                         socket.close();
                     }
                 catch  (IOException e) {
                     e.printStackTrace();
                 }
             }
         }
         
     }
}





     本文转自sarchitect 51CTO博客,原文链接:http://blog.51cto.com/stevex/1581093 ,如需转载请自行联系原作者


相关文章
|
4月前
|
人工智能 Java API
MCP客户端调用看这一篇就够了(Java版)
本文详细介绍了MCP(Model Context Protocol)客户端的开发方法,包括在没有MCP时的痛点、MCP的作用以及如何通过Spring-AI框架和原生SDK调用MCP服务。文章首先分析了MCP协议的必要性,接着分别讲解了Spring-AI框架和自研SDK的使用方式,涵盖配置LLM接口、工具注入、动态封装工具等步骤,并提供了代码示例。此外,还记录了开发过程中遇到的问题及解决办法,如版本冲突、服务连接超时等。最后,文章探讨了框架与原生SDK的选择,认为框架适合快速构建应用,而原生SDK更适合平台级开发,强调了两者结合使用的价值。
6067 33
MCP客户端调用看这一篇就够了(Java版)
|
4月前
|
存储 网络协议 Java
Java获取客户端IP问题:返回127.0.0.1
总结:要解决Java获取客户端IP返回127.0.0.1的问题,首先要找出原因,再采取合适的解决方案。请参考上述方案来改进代码,确保在各种网络环境下都能正确获取客户端IP地址。希望本文对您有所帮助。
275 25
|
6月前
|
Java Linux 定位技术
Minecraft配置文件参数说明(JAVA服务器篇)
Minecraft JAVA版服务器启动后会生成server.properties配置文件,位于minecraft_server/根目录下。该文件包含多项关键设置,如游戏模式(gamemode)、最大玩家数(max-players)、难度(difficulty)等。此文档详细说明了各配置项的功能与默认值,帮助用户高效管理服务器环境。
1454 60
|
10月前
|
Java
java小工具util系列5:java文件相关操作工具,包括读取服务器路径下文件,删除文件及子文件,删除文件夹等方法
java小工具util系列5:java文件相关操作工具,包括读取服务器路径下文件,删除文件及子文件,删除文件夹等方法
204 9
|
5月前
|
人工智能 搜索推荐 程序员
用 Go 语言轻松构建 MCP 客户端与服务器
本文介绍了如何使用 mcp-go 构建一个完整的 MCP 应用,包括服务端和客户端两部分。 - 服务端支持注册工具(Tool)、资源(Resource)和提示词(Prompt),并可通过 stdio 或 sse 模式对外提供服务; - 客户端通过 stdio 连接服务器,支持初始化、列出服务内容、调用远程工具等操作。
1364 4
|
6月前
|
前端开发 Cloud Native Java
Java||Springboot读取本地目录的文件和文件结构,读取服务器文档目录数据供前端渲染的API实现
博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
Java||Springboot读取本地目录的文件和文件结构,读取服务器文档目录数据供前端渲染的API实现
|
6月前
|
网络协议 开发者 Python
Socket如何实现客户端和服务器间的通信
通过上述示例,展示了如何使用Python的Socket模块实现基本的客户端和服务器间的通信。Socket提供了一种简单且强大的方式来建立和管理网络连接,适用于各种网络编程应用。理解和掌握Socket编程,可以帮助开发者构建高效、稳定的网络应用程序。
260 10
|
8月前
|
存储 开发工具 git
[Git] 深入理解 Git 的客户端与服务器角色
Git 的核心设计理念是分布式,每个仓库既可以是客户端也可以是服务器。通过 GitHub 远程仓库和本地仓库的协作,Git 实现了高效的版本管理和代码协作。GitHub 作为远程裸仓库,存储项目的完整版本历史并支持多客户端协作;本地仓库则通过 `.git` 文件夹独立管理版本历史,可在离线状态下进行提交、回滚等操作,并通过 `git pull` 和 `git push` 与远程仓库同步。这种分布式特性使得 Git 在代码协作中具备强大的灵活性和可靠性。
189 18
[Git] 深入理解 Git 的客户端与服务器角色
|
9月前
|
存储 人工智能 自然语言处理
ChatMCP:基于 MCP 协议开发的 AI 聊天客户端,支持多语言和自动化安装 MCP 服务器
ChatMCP 是一款基于模型上下文协议(MCP)的 AI 聊天客户端,支持多语言和自动化安装。它能够与多种大型语言模型(LLM)如 OpenAI、Claude 和 OLLama 等进行交互,具备自动化安装 MCP 服务器、SSE 传输支持、自动选择服务器、聊天记录管理等功能。
2312 16
ChatMCP:基于 MCP 协议开发的 AI 聊天客户端,支持多语言和自动化安装 MCP 服务器
|
7月前
|
缓存 网络协议 Java
JAVA网络IO之NIO/BIO
本文介绍了Java网络编程的基础与历史演进,重点阐述了IO和Socket的概念。Java的IO分为设备和接口两部分,通过流、字节、字符等方式实现与外部的交互。
215 0

热门文章

最新文章