【Java网络原理】 四

本文主要介绍了TCP/IP五层协议中的应用层常见的数组组织格式和传输层UDP协议。

一.应用层

1.网络通信数据的实质

网络上传输的数据,本质就是字符串(准确的说,是二进制的字符串)

Java中的各种对象,是无法直接传输的

>在发送的时候,就需要把对象转成二进制字符串   ---序列化

>收数据的时候,也需要把二进制字符串转回对象   ---反序列化


通信的要求:

客户端的请求以及服务器的响应,具体的数据组织格式,是非常灵活的,

程序员想怎样组织都可以,只需要保证客户端和服务器使用的相同的规格就行

应用层有很多现成的协议,但是有时候需要程序员自定义协议

自定义协议:

1.明确好传递的信息有什么

2.约定好信息按照什么格式来组织

注意:自定义格式虽然可以任意,但是为了避免出现过于天马行空的设计,有一些大佬就搞出了一些 通用的协议格式,对我们的协议设计是有重要的指导作用的。

下面是介绍三种常见数据组织格式:

2.常见的数据格式

1.xml

以成对的标签,来表示键值对信息,同时标签支持嵌套,构成一些更复杂的树形结构数据。

请求:<request><userId>123</userId>         //键值对结构  userId: 123<password>111</password>     //           password:111
</request>响应:
<response><allSubjects><subject><name>math</name><score>99</score></subject><subject><name>chinese</name><score>99</score></subject>	</allSubjects>
</response>

和html区别:

html里的标签,有自己的标准

xml里的标签,就是程序员自定义的

优点:xml把结构化数据表示的非常清晰

缺点:表示数据需要引入大量的标签,看起来繁琐,同时会占用很多网络带宽

现状:xml用的越来越少了

2.json

当前最流行的组织格式

本质上也是键值对,但是比xml要干净很多

组织形式:

{}        表示键值对

[]        表示数组,数组中可以是数组,还可以是{}或者[]

请求:
{UserId:123,Password:11a}响应:
[{Name:math,Score:99},{Name:chinese,Score:99}
]

现状:最主流使用的一种网络传输数据的格式,未来在实际开发中会经常使用json格式的数组

特性:json中可以把所有内容放在同一行,通常网络传输中,会把json进行压缩,同时把所有数据放到一行,整体占用的带宽就降低了。

3.protobuffer

谷歌提出的一套二进制的数据序列化方式

特性:使用二进制的方式,约定哪几个字节,表示哪个数据。最大程序的节省空间,不必传输key,根据位置和长度区分每个属性

优点:节省带宽,最大效率化

缺点:二进制数据,无法用肉眼观察,不方便调试;使用复杂;

适用场景:性能要求更高的场景(牺牲了开发效率,换来运行效率)

总结:

除了以上三种,业界还有很多其他的数组组织格式,比如Java标准库就提供了方式;还有其他的第三方库提供的方式更丰富

二.传输层

1.UDP用户数据报协议

UDP基本特点:无连接 不可靠传输  面向数据报 全双工

学习一个协议,要掌握协议的特性,还要理解协议报文格式

1.1UDP数据报格式

UDP用户数据报报文格

报头各字段说明:

报头有四个字段,每个字段占2字节,2字节的数据范围是0 ~ 65535

>源/目的端口:范围是0 ~ 65535 

其中1-1024是知名端口,不建议使用。

>长度:指的是数据载荷的长度,最大65535,也就是64kb,这意味着一个UDP数据载荷最大只能65535这么长。

这在互联网发展之初,是比较大的;

放在现在,64KB已经非常小了,经常是不能够满足使用的;

但是现在由于种种原因,已经无法改变了。

应对方案:

1.在应用层代码中把报文拆分成多组,通过多个UDP数据报进行传输

2.使用tcp代替udp,tcp没有报文长度限制

>检验和

事实:网络传输数据过程中,收到外界干扰,就会出错;

由于本质上传输的是光信号/电信号/电磁波 (比如受太阳活动的影响,就会影响到正常的网络通信)

可能会导致比特翻转( 0->1 / 1->0 ),所以就要将收到的数据和发来的数据进行对比。

UDP使用CRC校验算法(循环冗余校验和)

思想:累加结果保存到这个2字节的变量中,最终就得到了校验和。

接受方收到数据时候,按照同样的方式再算一遍校验和

数据相同    --> 校验和相同

校验和不同 --> 数据不同

但是校验和相同 不能推出 数据相同 (可能会出现巧合)

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

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

相关文章

Cannot connect to the Docker

执行docker基础命令失败&#xff01; Cannot connect to the Docker daemon at unix:///var/run/docker.sock. Is the docker daemon running? 原因&#xff1a;docker服务没有启动。 解决方法&#xff1a;执行 systemctl start docker 即可。

用于读取验证码的 OCR 模型

介绍 此示例演示了使用功能 API 构建的简单 OCR 模型。除了结合 CNN 和 RNN 之外,它还说明了如何实例化新层并将其用作“端点层”来实现 CTC 损失。 设置 import os import numpy as np import matplotlib.pyplot as pltfrom pathlib import Path from collections import Co…

基于STM32两轮自平衡小车系统设计与控制

**单片机设计介绍&#xff0c;1650【毕设课设】基于STM32两轮自平衡小车系统设计与控制 文章目录 一 概要二、功能设计设计思路 三、 软件设计原理图 五、 程序文档 六、 文章目录 一 概要 主控芯片用的是100脚的STM32F103VET6&#xff0c;陀螺仪用的是MPU6050&#xff0c;电机…

中微爱芯74逻辑兼容替代TI/ON/NXP工规品质型号全

这里写自定义目录标题 工业级型号全产品线概述![在这里插入图片描述](https://img-blog.csdnimg.cn/097ef810b2234f07b0c0c1e962a73761.png)批量应用行业头部客户兼容替代封装对照逻辑参数对比电平转换系列型号对照HC/HCT 系列型号对照AHC/AHCT 系列型号对照LV/LVC 系列型号对照…

带有 Vagrant 和 Virtualbox 的 Elasticsearch 集群

模拟分布式存储和计算环境的一种简单方法是使用 Virtualbox 作为 VM&#xff08;“虚拟机”&#xff09;的提供者&#xff0c;使用 Vagrant 作为前端脚本引擎来配置、启动和停止这些 VM。这篇文章的目标是构建一个集群虚拟设备&#xff0c;提供 Elasticsearch 作为可由主机使用…

计算机视觉-光源的目的和作用

光源的目的 机器视觉系统的核心是图像采集和图像处理&#xff0c;而光源则是影响图像水平的重要因素&#xff0c;通过适当的光源照明&#xff0c;使图像中的目标信息与背景信息得到更好的分离&#xff0c;可大大降低图像识别难度&#xff0c;提高系统的精度和可靠性。 对于机器…

【错误解决方案】ModuleNotFoundError: No module named ‘torch._six‘

1. 错误提示 在python程序中&#xff0c;试图导入一个名为torch._six的模块&#xff0c;但Python提示找不到这个模块。 错误提示&#xff1a;ModuleNotFoundError: No module named torch._six 2. 解决方案 出现这个错误可能是因为你使用的PyTorch版本和你的代码不兼容。在某…

Megatron-LM GPT 源码分析(三) Pipeline Parallel分析

引言 本文接着上一篇【Megatron-LM GPT 源码分析&#xff08;二&#xff09; Sequence Parallel分析】&#xff0c;基于开源代码 GitHub - NVIDIA/Megatron-LM: Ongoing research training transformer models at scale &#xff0c;通过GPT的模型运行示例&#xff0c;从三个维…

类与面向对象

章节目录&#xff1a; 一、面向对象二、类2.1 类定义2.2 类对象2.3 self 代表类的实例&#xff0c;而非类 三、类的方法四、多继承五、方法重写六、私有属性及私有方法七、类的专有方法八、专有方法重载九、结束语 一、面向对象 Python 从设计之初就已经是一门面向对象的语言。…

从一个页面跳转到目标页面之后,对应的顶部路由高亮

需求&#xff1a;页面跳转到目标页面之后&#xff0c;对应的顶部路由高亮 上面的更多 跳转到 学情分析下面的学生分析 <template><div class"topBar" ref"topBar" v-loading.fullscreen.lock"fullscreenLoading"><div class&quo…

左神算法题系列:动态规划机器人走路

机器人走路 假设有排成一行的N个位置记为1~N&#xff0c;N一定大于或等于2 开始时机器人在其中的start位置上(start一定是1~N中的一个) 如果机器人来到1位置&#xff0c;那么下一步只能往右来到2位置&#xff1b; 如果机器人来到N位置&#xff0c;那么下一步只能往左来到N-1位…

MySQL实战2

文章目录 主要内容一.回访用户1.准备工作代码如下&#xff08;示例&#xff09;: 2.目标3.实现代码如下&#xff08;示例&#xff09;: 二.如何找到每个人每月消费的最大天数1.准备工作代码如下&#xff08;示例&#xff09;: 2.目标3.实现代码如下&#xff08;示例&#xff09…

selenium+python自动化安装驱动 碰到的问题

刚开始使用谷歌驱动&#xff0c;我的谷歌浏览器版本是最新版下载驱动地址&#xff0c;访问不了。 Chrome for Testing availability只能使用火狐驱动&#xff0c;我这里的火狐版本也是最新版119.0 查找全网找到驱动geckodriver下载地址 https://mirrors.huaweicloud.com/ge…

08.K8S高可用方案

K8S高可用方案 1、高可用部署方式 官方提供两种高可用实现方式: 堆叠etcd 拓扑,其中 etcd 节点与控制平面节点共存;外部 etcd 节点,其中 etcd 与控制平面在不同的节点上运行;1.1、堆叠 etcd 拓扑 主要特点: 每个 master 节点上运行一个 apiserver 和 etcd, etcd 只与本…

Vmware下的虚拟机NAT连接后仍然木有网络

问题描述 出现在主机能ping通&#xff0c;互联网ping不通的情况。 解决 竟然是因为网关配置文件中DNS1写成了DNS! 没想到吧&#xff01;如果你试了很多办法都没有解决记得检查下文件 T^T 在文件夹中改过来就好了&#xff1a; 之后虚拟机终端执行init 6重启&#xff0c;即可…

私有云:【3】NFS存储服务器的安装

私有云&#xff1a;【3】NFS存储服务器的安装 1、使用vmwork创建虚拟机2、配置NFS服务器3、安装NFS存储服务4、配置NFS服务及创建存储共享 1、使用vmwork创建虚拟机 新建虚拟机NFS 分配400G硬盘&#xff0c;可以更高【用作存储】 自定义硬件 选择win2012的iso文件 设置登录密码…

文件上传漏洞(2), 文件上传实战绕过思路, 基础篇

文件上传漏洞实战思路(基础) 准备一句话木马文件 mm.php 一, 前端绕过 p1 浏览器禁用js先把mm.php后缀名修改为mm.jpg, 点击提交后, 用 burp 截取请求, 将数据包中的文件名修改回mm.php再提交. 二, 类型MIME绕过 p2 使用 burp 修改 Content-Type: image/jpeg 三, 黑名单绕…

动态代理:一种灵活的设计模式

动态代理是一种在运行时创建和使用代理对象的设计模式&#xff0c;它可以在不修改原始类和接口的情况下&#xff0c;对原始对象进行额外的操作或增强。动态代理广泛应用于各种编程场景&#xff0c;如前后端处理、数据访问、业务逻辑优化等。本文将介绍动态代理的概念、分类、实…

【C++】模版进阶

我们在之前的博客中讲述过模版的使用&#xff1a;【C】模版初阶&#xff0c;但这只是模版最基本的使用&#xff0c;下面再深入模版&#xff0c;看看还有另外什么用法&#xff1a; 目录 一、非类型模板参数 二、模板的特化 2.1 什么是模版的特化 2.2 函数模版的特化 2.3 类…

python实现将图片数据以TFRecord方式存储

以TFRecord方式存储的优点 高效性&#xff1a;TFRecord是一种二进制格式&#xff0c;可以提供更高的存储和读取效率。它可以更快地读取和解析数据&#xff0c;特别适用于大规模数据集 可压缩性&#xff1a;TFRecord可以使用压缩算法进行压缩&#xff0c;减小数据文件的大小。这…