时间:2021-05-20
方式一:同步阻塞方式(BIO):
服务器端(Server):
package com.ietree.basicskill.socket.mode1;import java.io.IOException;import java.net.ServerSocket;import java.net.Socket;/** * 服务端 */public class Server { // 端口号 final static int PORT = 8765; public static void main(String[] args) { ServerSocket server = null; try { server = new ServerSocket(PORT); System.out.println("Server start......"); // 进行阻塞 Socket socket = server.accept(); // 创建一个程序执行客户端的任务 new Thread(new ServerHandler(socket)).start(); } catch (IOException e) { e.printStackTrace(); } finally { if(server != null){ try { server.close(); } catch (IOException e) { e.printStackTrace(); } } server = null; } }}采用多线程来处理接收到的请求(ServerHandler):
package com.ietree.basicskill.socket.mode1;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStreamReader;import java.io.PrintWriter;import java.net.Socket;public class ServerHandler implements Runnable { private Socket socket; public ServerHandler(Socket socket) { this.socket = socket; } @Override public void run() { BufferedReader in = null; PrintWriter out = null; try { in = new BufferedReader(new InputStreamReader(this.socket.getInputStream())); out = new PrintWriter(this.socket.getOutputStream(), true); String body = null; while (true) { body = in.readLine(); if(body == null){ break; } System.out.println("Server: " + body); out.println("服务器端回送响应的数据。"); } } catch (Exception e) { e.printStackTrace(); } finally { if(in != null){ try { in.close(); } catch (IOException e) { e.printStackTrace(); } } if(out != null){ try { out.close(); } catch (Exception e) { e.printStackTrace(); } } if(socket != null){ try { socket.close(); } catch (IOException e) { e.printStackTrace(); } } socket = null; } }}客户端(Client):
package com.ietree.basicskill.socket.mode1;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStreamReader;import java.io.PrintWriter;import java.net.Socket;/** * 客户端 */public class Client { final static String ADDRESS = "127.0.0.1"; final static int PORT = 8765; public static void main(String[] args) { Socket socket = null; BufferedReader in = null; PrintWriter out = null; try { socket = new Socket(ADDRESS, PORT); in = new BufferedReader(new InputStreamReader(socket.getInputStream())); out = new PrintWriter(socket.getOutputStream(), true); // 向服务器端发送数据 out.println("接收到客户端的请求数据......"); String response = in.readLine(); System.out.println("Client: " + response); } catch (Exception e) { e.printStackTrace(); } finally { if(in != null){ try { in.close(); } catch (IOException e) { e.printStackTrace(); } } if(out != null){ try { out.close(); } catch (Exception e) { e.printStackTrace(); } } if(socket != null){ try { socket.close(); } catch (IOException e) { e.printStackTrace(); } } socket = null; } }}程序输出:
Server:
Server start......Server: 接收到客户端的请求数据......Client:
Client: 服务器端回送响应的数据。同步非阻塞(NIO)
异步非阻塞(AIO)
以上这篇Java网络通信基础编程(必看篇)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
java基础知识之网路通信总结在这篇文章里,我们主要讨论如何使用Java实现网络通信,包括TCP通信、UDP通信、多播以及NIO。 TCP连接 TCP的基础
tcpip是供已连接因特网的计算机进行通信的通信协议。Tcpip是一个网络通信模型,以及一整个网络传输协议家族,为互联网的基础通信架构。 互联网协议(Inte
网络通信协议的功能是为连接不同操作系统和不同硬件体系结构的互联网络引提供通信支持,是一种网络通用语言。 网络通信协议(InternetProtocol,缩写:
最近做项目是关于Docker的网络通信,需要多个主机进行链接通信,这里记录下,以后便于项目开发,大家需要的话也可以看下,少走些弯路。Docker多主机网络通信详
以网络通信协议为例,基本通信协议有NetBEUI协议、IPX/SPX及其兼容协议、TCP/IP协议。网络通信协议为连接不同操作系统和不同硬件体系结构的互联网络引