网络编程原理:回显服务器与客户端通信交互功能

文章目录

  • 路由器及网络概念
  • 网络通信基础
  • TCP/IP 五层协议
  • 封装和分用
      • 封装
      • 分用
  • 网络编程(网络协议)
    • UDP类 API使用
      • 实现回显通信程序
        • 回显服务器(UDP代码)
        • 回显客户端(UDP代码)
    • TCP API使用
        • 回显服务器(TCP代码)
        • 回显客户端(TCP代码)

路由器及网络概念

网络发展是由单机时代->局域网时代->广域网时代->移动互联网时代
局域网:通过路由器的LAN为媒介来链接不同电脑,使其进行互相通信,而路由器通常为5个网口,1个WAN(用来连接上级的路由器)4个LAN。
当局域网连接的更多时,网络也会覆盖的更大。
在这里插入图片描述

交换机概念

交换机是因为路由器的LAN口过少,而需要连接到路由器的节点过多,这时候交换机的WAN通过连接路由器的LAN口,然后通过交换机的LAN口来连接其他的路由器的WAN或者电脑,来实现层层连接,构成更复杂的网络结构。

而广域网是通过更多的局域网的来连接到一起,构成的更加庞大的网络结构,覆盖一个城市或者更大。


网络通信基础

IP地址

描述一个设备,在网络中的地址,计算机中使用32位的字节数字来表示地址。
点分十进制
计算机地址由32位字节数构成,但是32位的byte字节过长,一般会表示为4个0~255之间的十进制数字,每个数字之间通过点进行分隔。
在这里插入图片描述


端口号

端口号:区分一个主机中不同的应用程序。
端口号是一个整数0~65535(2个字节)不同的程序可以关联/绑定相同的端口号,但是同一个主机上的应用程序,不能关联同一个端口号(一个端口号只能被一个程序绑定,而一个程序可以绑定多个端口)。
在实际的通信过程中,IP和端口是相互绑定的。


协议

在网络中,本质是通过光/电信号来传输数据,通过低电平表示1,高电平表示0 ,高频光信号表示1 ,低频光信号表示0。
协议就是通过一种约定,来约定通信的双方以同样的方式进行传输数据。


网络五元组

源IP 、源端口、目的IP、目的端口 、协议的类型,是在通信过程中必不可少的信息。


协议分层

通过对协议的定位或者是作用进行分类,将定位/作用相似放到同一层,然后通过上层协议调用下层协议,下层协议给上层协议提供支持。
通过协议分层不仅能够让多个层级直接交互配合,还可以对上层和下层彼此之间进行封装,使用上层协议,不必关注上层,使用下层协议不必关注下层。


TCP/IP 五层协议

物理层:描述网络通信的硬件设备
数据链路层:两个相邻节点之间的数据传输情况
网络层:进行路径规划,规划出最合适的路径
传输层:关注起点和终点
应用层:应用程序如何使用数据
在这里插入图片描述


封装和分用

封装

分装和分用描述了在网络通信中,基本的数据传输流程
1.应用层
开发者自定义通过设计数据报的格式,当用户通过输入进行传输,给打包成一个数据报来进行封装。
例如:当用户通过信息输入发送给另一个用户。
应用层协议(数据报格式):用户A(源头) 、 用户B(目的地)、时间 、发送的内容"hello"
转换为数据报:15239(源头)、 32643(目的地) 、2024-12-27 、hello
在这里插入图片描述


当应用层的数据报打包好后,可以通过调用下层协议,调用系统的API将数据传给数据层。
2.传输层

当到达传输层后,继续对应用层传输的数据进行打包,“拼接”。
在应用层的基础上进行拼接传输层的报头
UDP报头的关键信息:源端口和目的端口
在这里插入图片描述


网络层

网络层最主要的协议:IP协议,在原有的传输层的基础上进行拼接打包。
IP报头中包含的最重要的熟悉:源IP和目的IP
在这里插入图片描述


数据链路层

以太网:传输给数据链路层之后,通过以太网再次进行打包,通过拼接以太网报头来打包。
以太网包含的最重要信息:源mac地址和目的mac地址(描述一个设备在网络中的地址)

在这里插入图片描述
以下每一都是通过报头和载荷的形式进行封装,数据链路层通过报头和报尾来进行打包。每一次的传输都被封装成为一个载荷
在这里插入图片描述


物理层

当传输到物理层后,将这些打包好的数据转换成2禁止的0 1序列,通过光信号/电信号进行传输。


分用

当数据在传输给目的地(用户B)的时候,会经历一系列的交换机和路由器的转发。
当我们的的数据通过一系列步骤到达用户B后,这时候就需要进行分用解析这个包。
当接收时通过由物理层到应用层的步骤层层解析。

1.物理层

拿到光电信号后转换成二进制的数据,得到以太网的数据报。

2.数据链路层

通过以太网协议对物理层传输过来的数据报进行解析,得到报头和报尾和中间的载荷。

3.网络层

通过IP协议对数据对数据链路层传输过来的数据报进行解析,去掉IP报头得到载荷。

4.传输层

通过UDP协议,针对网络层传输的数据报进行解析,拿到载荷,去掉UDP报头,得到载荷。

5.应用层

根据端口号来负责将数据交给指定的应用程序,然后根据开发者自定义的应用层协议进行解析并显示。


网络编程(网络协议)

在计算机中,通过网络,可以让两个主机之间相互通信,在实现相互通信的过程时,需要我们开发者通过应用程序(应用层)通过系统的API与传输层进行交互。
Socket API这套协议,可以完成不同主机之间,不同系统之间的通信。

在传输层中,提供的网络协议主要由两个,UDP和TCP

UDP和TCP的区别

1.TCP可以进行连接,UPD不可以连接。
在计算机中,通过与双方建立连接,各自保存双方的信息。
如果TCP需要通信,需要建立连接,保存对方信息,才可以进行
UDP无需建立连接,就可以通信(虽然不需要建立连接,但是需要开发者通过socket API来进行对方信息作为参数进行传输)

2.TCP时可靠传输的,UDP时不可依靠传输的
网络通信中,A与B发送消息,消息有可能无法进行传输(传输的概率无法达成100%),可能存在物理干扰。
而可靠传输是当A与B发送消息时,如果发送失败,则需要采取一定的补救措施(重写发送等),这个可靠传输也无法保证必定传达成功,只是尽力补救。
当进行可靠传输时,则必定要付出一定的代价,这样的机制会复杂且传输的效率也会大大降低。

3.TCP是面向字节流的,UDP时面向数据报的
TCP通过以字节为单位进行传输,UDP以数据报为单位进行传输。

4.TCP和UDP都是全双工的
一个信道中,允许双向通信的,就是全双工。
一个信道中,只能单向通信的,就是半双工。

UDP类 API使用

DatagramSocket类

Socket是操作系统中的概念,是系统抽象出来的”文件“,本质Socket是属于网卡
当Socket在写数据时,相当于网卡在发送数据。
当Socket在读数据时,相当于网卡接收数据。

DatagramPacket类

通过此类,表示一个UDP的数据报(UDP面向的是数据报)
每次传输以UDP数据报为基本单位。


实现回显通信程序

编写服务器和客户端的代码通过回显显示在屏幕上
上述内容描述Socket本质是一个网卡,服务器则需要网卡中指定一个端口,但是客户端无须指定端口通过系统直接分配端口,防止程序端口冲突

回显服务器(UDP代码)
package UDPECHO;import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.SocketException;public class UdpEchoServer {private DatagramSocket socket=null;//设置socket网卡public UdpEchoServer(int port) throws SocketException {socket=new DatagramSocket(port);//这里服务器需要指定端口}public void start() throws IOException {System.out.println("Server is Running");//这里receive接收客户端的请求,需要准备一个字节数组进行接收//这里的while循环只要不倒闭,服务器一直在循环状态while(true){DatagramPacket requestPacket=new DatagramPacket(new byte[5080],5080);socket.receive(requestPacket);//这里接收到请求将请求转换为String类型的字符串//这里的参数第一个是以字符串形式来获取字节数组,第二个参数表示下标,第三个表示最终的长度String request=new String(requestPacket.getData(),0,requestPacket.getLength());//对获取到的请求进行响应String response=process(request);//这里回应后开始准备继续返回给客户端影响的结果//这里的参数,第一个将响应继续转换为字节//参数2,因为是字符,所以需要转换为字节后在获取长度,如果是UTF-8的汉字则为三个字节//参数3,是传送给客户的地址,系统随机推送的地址DatagramPacket responsePacket=new DatagramPacket(response.getBytes(),response.getBytes().length,requestPacket.getSocketAddress());socket.send(responsePacket);//socket里面的参数就是响应的结果,需要使用一个Packet参数//服务器打印的内容System.out.printf("[%s:%d] request:%s response:%s\n",requestPacket.getAddress(),requestPacket.getPort(),request,response);}}private String process(String request) {//返回响应,我们在程序中大部分都在维护响应中的代码,这里是回显,我们请求是什么响应就是什么return  request;}public static void main(String[] args) throws IOException {UdpEchoServer server=new UdpEchoServer(8070);server.start();}
}

回显客户端(UDP代码)
package UDPECHO;import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;
import java.net.SocketException;
import java.util.Scanner;public class UdpEchoClient {private DatagramSocket socket=null;private String serverIp=" ";private int serverPort=0;public  UdpEchoClient(String ip,int port) throws SocketException {socket=new DatagramSocket();//默认随机指定端口serverIp=ip;serverPort=port;}public void start() throws IOException {System.out.println("Client is Running");
//            输入的内容Scanner scanner=new Scanner(System.in);while(true){System.out.println("Please enter:>");String request=scanner.next();//输入的内容//这里发送给服务器数据然后服务器进行接收//这里指定的是请求的内容长度,还有传送给服务器的IP地址和端口DatagramPacket requestPacket=new DatagramPacket(request.getBytes(),request.getBytes().length, InetAddress.getByName(serverIp),serverPort);socket.send(requestPacket);//客户端阻塞等待服务器传回来的数据,当服务器进行一系列操作后进行返回,接收服务器返回的DatagramPacket responsePacket=new DatagramPacket(new byte[5080],5080);//申请一个字节数组进行接收socket.receive(responsePacket);//最后将字节数组转换成字符串String response=new String(responsePacket.getData(),0,responsePacket.getLength());//打印显示到屏幕中System.out.println(response);}}public static void main(String[] args) throws IOException {UdpEchoClient client=new UdpEchoClient("127.0.0.1",8070);client.start();}
}

TCP API使用

ServerSocket类使用

针对服务器使用的类,来实现网卡,对客户端的请求进行操作,并最终将获取到的响应返回给客户端

Socket类使用

针对客户端的网卡,通过这个网卡来对服务器进行发起请求,并且接收服务器返回的响应,连接这两台机器的端点。


回显服务器(TCP代码)
package TCP;import java.io.*;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.Scanner;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;public class TcpEchoServer {private ServerSocket serverSocket=null;public TcpEchoServer(int port) throws IOException {serverSocket=new ServerSocket(port);//填写服务器的端口号}public void start() throws IOException {ExecutorService thread=Executors.newCachedThreadPool();//创建一个线程池来进行并发执行System.out.println("Server is running.....");while(true){//多个客户端需要循环Socket clientSocket = serverSocket.accept();//通过此方法,将内核中已经建立好的连接拿出来给到Socket类型对象//这个方法包含请求回应响应thread.submit(new Runnable() {@Overridepublic void run() {try {connection(clientSocket);} catch (IOException e) {throw new RuntimeException(e);}}});}}private void connection(Socket clientSocket) throws IOException {//对客户端的上线进行日志打印System.out.printf("客户端上线Ip:%s,端口:%d\n",clientSocket.getInetAddress(),clientSocket.getPort());//这里通过流对象来进行输入和输出,通过try包裹来避免流对象后续的释放try(InputStream inputStream=clientSocket.getInputStream();OutputStream outputStream=clientSocket.getOutputStream();PrintWriter printWriter=new PrintWriter(outputStream)){while(true){//一个客户端在运行期间不只接收一次数据,需要循环控制Scanner scanner=new Scanner(inputStream);//这里来接收输入的内容if(!scanner.hasNext()){//这里条件说明客户端退出,下线日志进行打印System.out.printf("客户端下线,Ip:%s port:%d\n",clientSocket.getInetAddress(),clientSocket.getPort());break;}//这里对客户端传入给服务器的数据进行解析得到字符串String request=scanner.next();//对请求的数据进行响应并进行接收String response=process(request);//1.通过PrintWriter来将response传入给客户端printWriter.println(response);printWriter.flush();//刷新一下System.out.printf("[%s:%d] request:%s,response:%s\n",clientSocket.getInetAddress(),clientSocket.getPort(),request,response);}}finally {//最后释放一下clientSocket对象,引用对象如果不释放,容易将文件描述符占满,导致文件泄漏clientSocket.close();}}private String process(String request) {return request;}public static void main(String[] args) throws IOException {TcpEchoServer server=new TcpEchoServer(8090);server.start();}
}

回显客户端(TCP代码)

import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.io.PrintWriter;
import java.net.Socket;
import java.util.Scanner;public class TcpEchoClient {private Socket socket=null;public TcpEchoClient(String serverIp,int serverPort) throws IOException {//这里的客户端需要与服务器进行连接,这是连接条件,ip和port为与服务器进行连接的条件socket=new Socket(serverIp,serverPort);}public void start() throws IOException {System.out.println("Client is Running......");Scanner scanner=new Scanner(System.in);//防止文件描述泄漏try(InputStream inputStream=socket.getInputStream();OutputStream outputStream=socket.getOutputStream();PrintWriter printWriter=new PrintWriter(outputStream);Scanner scannerNetwork=new Scanner(inputStream)){while(true){//1.输入System.out.print("enter:>");String request=scanner.next();//客户端控制台输入的内容//2.这里将数据发送给客户端printWriter.println(request);printWriter.flush();//3.接收服务器返回的数据String response=scannerNetwork.next();System.out.println(response);}}}public static void main(String[] args) throws IOException {TcpEchoClient client=new TcpEchoClient("127.0.0.1",8090);client.start();}
}

在这里插入图片描述


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/66145.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

设计模式 创建型 建造者模式(Builder Pattern)与 常见技术框架应用 解析

单例模式(Singleton Pattern),又称生成器模式,是一种对象构建模式。它主要用于构建复杂对象,通过将复杂对象的构建过程与其表示分离,使得同样的构建过程可以创建出具有不同表示的对象。该模式的核心思想是将…

【C++】P1428 小鱼比可爱

博客主页: [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: C 文章目录 💯前言💯题目说明题目输入格式题目输出格式样例**输入样例****输出样例** 题目解析 💯解法分析我的做法代码解法说明时间复杂度 老师的做法代码解法说明总结时间复杂度 …

maven之插件调试

当使用maven进行项目管理的时候,可能会碰到一些疑难问题。网上资料很少,可能会想着直接调试定位问题。这里以maven-compiler-plugin为例: (1)准备maven-compiler-plugin源码 进入maven 官网-》Maven Plugins-》找到对…

蓝桥杯(Java)(ing)

Java前置知识 输入流: (在Java面向对象编程-CSDN博客里面有提过相关知识------IO流) // 快读快写 static BufferedReader in new BufferedReader(new InputStreamReader(System.in)); static BufferedWriter out new BufferedWriter(new…

【C++】深入理解C语言中的特殊字符处理与问题分析优化

博客主页: [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: C 文章目录 💯前言💯题目:B2090 年龄与疾病输入格式输出格式输入输出样例 💯初始代码分析与问题排查问题点分析 💯修正后的代码与优化修正与优化要点 &#…

电商Google广告:2025年提升转化率的5种策略

展望 2025 年,Google 广告领域将迎来一系列显著变化,这些趋势对于提升广告转化率至关重要,值得我们提前关注与布局。 智能化程度持续加深,用户搜索习惯愈发精细,广告格式推陈出新,视频广告势头正猛...那么…

【pytorch练习】使用pytorch神经网络架构拟合余弦曲线

在本篇博客中,我们将通过一个简单的例子,讲解如何使用 PyTorch 实现一个神经网络模型来拟合余弦函数。本文将详细分析每个步骤,从数据准备到模型的训练与评估,帮助大家更好地理解如何使用 PyTorch 进行模型构建和训练。 一、背景 …

编程入门(2)-2024年 RAD Studio version 12发布综述

随着2024年即将画上句号,我想借此机会回顾一下我们在这一年中发布的一些Embarcadero产品、行业趋势,并感谢我们尊贵的客户们对我们的产品一如既往的支持。这一年对我们来说充满了激动人心的变化和发展,我们非常高兴能与您一起踏上这段旅程。 …

visual studio 安全模式

一、安全模式: 在 Visual Studio 中,安全模式是一种启动方式,允许你在禁用所有扩展和自定义设置的情况下启动 Visual Studio。这个模式可以帮助排除插件或扩展引起的问题,特别是在 Visual Studio 无法正常启动时。 二、安全模式下…

RocketMQ消费者如何消费消息以及ack

1.前言 此文章是在儒猿课程中的学习笔记,感兴趣的想看原来的课程可以去咨询儒猿课堂 这篇文章紧挨着上一篇博客来进行编写,有些不清楚的可以看下上一篇博客: https://blog.csdn.net/u013127325/article/details/144934073 2.broker是如何…

EasyExcel自定义动态下拉框(附加业务对象转换功能)

全文直接复制粘贴即可,测试无误 一、注解类 1、ExcelSelected.java 设置下拉框 Documented Target({ElementType.FIELD})//用此注解用在属性上。 Retention(RetentionPolicy.RUNTIME)//注解不仅被保存到class文件中,jvm加载class文件之后&#xff0c…

【2025最新计算机毕业设计】基于Spring Boot+Vue影院购票系统(高质量源码,提供文档,免费部署到本地)

作者简介:✌CSDN新星计划导师、Java领域优质创作者、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和学生毕业项目实战,高校老师/讲师/同行前辈交流。✌ 主要内容:🌟Java项目、Python项目、前端项目、PHP、ASP.NET、人工智能…

信息科技伦理与道德1:研究方法

1 问题描述 1.1 讨论? 请挑一项信息技术,谈一谈为什么认为他是道德的/不道德的,或者根据使用场景才能判断是否道德。判断的依据是什么(自身的道德准则)?为什么你觉得你的道德准则是合理的,其他…

Web安全扫盲

1、建立网络思维模型的必要 1 . 我们只有知道了通信原理, 才能够清楚的知道数据的交换过程。 2 . 我们只有知道了网络架构, 才能够清楚的、准确的寻找漏洞。 2、局域网的简单通信 局域网的简单通信(数据链路层) 一般局域网都通…

Linux驱动开发(18):linux驱动并发与竞态

并发是指多个执行单元同时、并行执行,而并发的执行单元对共享资源(硬件资源和软件上的全局变量、静态变量等)的访问 则很容易导致竞态。对于多核系统,很容易理解,由于多个CPU同时执行,多个CPU同时读、写共享资源时很容易造成竞态。…

009:传统计算机视觉之边缘检测

本文为合集收录,欢迎查看合集/专栏链接进行全部合集的系统学习。 合集完整版请参考这里。 本节来看一个利用传统计算机视觉方法来实现图片边缘检测的方法。 什么是边缘检测? 边缘检测是通过一些算法来识别图像中物体之间或者物体与背景之间的边界&…

QML使用Popup实现弹出Message

方案一:popup import QtQuick 2.15 import QtQuick.Controls 2.15 import QtQuick.Layouts 1.15ApplicationWindow {visible: truewidth: 640height: 480title: qsTr("Top Message Popup Example")ColumnLayout {anchors.centerIn: parentspacing: 10Butt…

idea java.lang.OutOfMemoryError: GC overhead limit exceeded

Idea build项目直接报错 java: GC overhead limit exceeded java.lang.OutOfMemoryError: GC overhead limit exceeded 设置 编译器 原先heap size 设置的是 700M , 改成 2048M即可

boot-126网易邮件发送

【SpringBoot整合JavaMail发送邮件】 一 . Java Mail基本概念 1.SMTP Simple Mail Transfer Protocol:简单邮件传输协议,用于发送邮件的协议。 2.POP3 Post office Protocol 3:邮局通讯协议第三版,用于接收邮件的标准协议。 3.IMAP Internet Message Acc…

【ArcGISPro/GeoScenePro】检查多光谱影像的属性并优化其外观

数据 https://arcgis.com/sharing/rest/content/items/535efce0e3a04c8790ed7cc7ea96d02d/data 操作 其他数据 检查影像的属性 熟悉检查您正在使用的栅格属性非常重要。