Linux学习记录——삼십구 数据链路层协议

news2025/1/11 9:07:56

文章目录

  • 1、了解数据链路层
  • 2、认识以太网
  • 3、认识MAC地址
  • 4、以太网报文
  • 5、局域网通信原理
    • 1、基本原理
    • 2、数据碰撞
    • 3、交换机
    • 4、ARP协议
    • 5、RARP协议
    • 6、局域网中间人
  • 6、DNS(简单介绍)
  • 7、ICMP协议
    • 1、报文
    • 2、traceroute命令
  • 7、NAT技术
    • 1、基本过程
    • 2、NAPT
    • 3、缺陷
  • 8、代理服务器


应用层(HTTP,HTTPS) → 传输层(TCP,UDP) → 网络层(IP) → 数据链路层

1、了解数据链路层

实际上IP协议提供的路由功能,路径选择,比如从主机D到路由器F,从路由器F到路由器G。链路层解决的就是如何将数据从D送到F。D和F属于同一个子网,F和G属于同一子网,所以链路层解决了在同一子网内发送数据的问题。同一子网内,两台设备可以直接连接,直接通信,跨网络就是在不同的子网之间不断发送,通过这些同子网的设备跨多个子网,而走哪些路线就是网络层IP协议决定的,怎样走是由链路层的MAC帧来决定的,这两层共同决定了如何将数据从一个主机跨网络送到B主机的能力,如果这两层有问题就让TCP来解决。

链路层属于驱动层,底层的网络有很多不一样的网络,网络的差异就体现在网卡、设备、软件驱动上,所以这个东西无法做到操作系统里。

2、认识以太网

以太网是一个局域网(子网)的技术标准,既包含链路层的内容,也包含了一些物理层的内容,是当前应用最广泛的局域网技术,和以太网并列的还有令牌环网、无线LAN等,以太网的网线必须使用双绞线。

3、认识MAC地址

局域网中,当来到消息时,每个主机都去检查是否是自己的信息,不是就丢掉,是就匹配上了。虽然两个主机都会认为在和对方通信,但其它主机也都知道一个主机发信息了。每个主机都有网卡,网卡有MAC地址,标准长度6个字节。

在这里插入图片描述

ether后面的一串就是mac地址。

4、以太网报文

在这里插入图片描述

MAC帧的报头是目的地址 + 源地址 + 类型 + CRC,有效载荷就是中间的数据,大小范围是46 ~ 1500字节,所以上层给的报文最多不超过1500字节,要超过46个字节,如果不够就填充PAD字段,实际上就填充一些垃圾数据。

报头部分,目的地址是MAC地址,源地址是发送方地址,都占6个字节,类型占2个,CRC校验码占4个字节。MAC帧的报头是定长报头,总共18个字节,有效载荷也有长度范围。类型是帧类型,表示数据类型,填的是0800,就是IP数据报,0806就是ARP请求/应答,8035则是RARP请求/应答。后两种原理相似,本篇只写ARP。

5、局域网通信原理

1、基本原理

假设主机ABCD,主机的mac地址假设为macABCD,路由器R,路由器也是局域网主机。主机A要给主机D发信息。

A的网络层发现A和D在同一子网内,在MAC帧的报文中,目的地址是macD,源地址是macA,类型是0800,数据是IP报文,以及CRC校验码。链路层将这个MAC帧报文发送到局域网中,BCDR各自的链路层都收到了这个MAC帧报文,比如主机C,C将MAC帧的报头和有效载荷分离,拿到报头这个结构体中的目的地址macD,发现不是macC,那么在链路层C就丢弃了这个报文,BR也是这样的操作,D也一样,不过D发现目的地址就是它自己的MAC地址,然后就交付给网络层,传输层,应用层,而其它几个,只有链路层知道这个报文,网络层及之上的都不知情。网卡中也可以设置一个混杂模式,不对报文的目标MAC地址进行认证。直接向上层交付,这也就是大部分局域网抓包软件的原理。要想不被抓包,在应用层对数据加密,因为其它层都是公开的代码。

D给A响应的时候,目的地址就是macA,源地址是macD,类型是0800,数据是IP报文,以及CRC校验码,然后发送到局域网,一样的过程,最终A得到了响应。

2、数据碰撞

局域网是共享的资源,有可能出现多个主机给多台主机通信,这时候会出现数据碰撞,网络都是光电信号,如果碰撞的话光波就会互相干扰,数据就不对了,所以局域网也叫碰撞域。任何时刻,只能有一台主机在给另一台主机发送数据帧。

为了预防这个问题发生,主机的网卡通过校验码来做碰撞检测,如果会发生碰撞就sleep上几秒,再重新发,避免碰撞。局域网内的所有主机都有这个机制,不过每个主机休息的时间不一样,所以就能错开发送;以及都在休息,没在休息的主机就可以发送了。所以局域网内主机越少越好,碰撞概率越低。现实中,很多人聚集在一起,或者像下班期间这样的网络使用高峰期,网络会变得卡,就是因为碰撞概率大了,很多设备都在丢包等待重发中。

如果要黑掉局域网,就发送大量垃圾数据,就有可能和所有主机碰撞,不过发送垃圾数据的主机得绕开以太网的驱动程序,让自己没有碰撞测试,通过某种方式直接去干扰局域网。

链路层也有重传,这是为了保证把数据发送到另一台主机。在OS角度,局域网是临界资源,因为一次只能让一个主机发送消息,其它都得等,碰撞检测和碰撞避免就是在保护临界资源的安全。而令牌环网有一些数据当作令牌,只有拿着令牌的主机才可以发送数据,发完后交给另一台主机,这台主机才能发数据,这个令牌就相当于互斥锁。

3、交换机

交换机工作在数据链路层,周围的设备也都在一个局域网内。假设局域网分为左右两部分,中间有交换机,左部分发生碰撞,交换机就不会把碰撞产生的垃圾数据传到右部分,不影响右部分的主机,这里交换机的作用就是划分碰撞域。

左部分正常交互,但数据有可能扩散到右部分,交换机也会收到这些数据就会丢掉,不会转发到右部分,减少右部分的碰撞概率。

一个区域内使用网络的设备很多时就得使用交换机。

4、ARP协议

在整个传输过程中,IP地址和目标MAC地址一直不变,源MAC地址一直在变。对方的IP地址是可以知道的,那么对方的MAC地址如何知道?

因为IP地址,目的MAC地址不变,底层网络的差异就会缩小。

ARP协议的主要功能是建立了IP地址和MAC地址的映射,工作在链路层,可以控制MAC帧报文的发送。MAC帧正常通信时直接将报文交给网络层,除非不知道对方的MAC地址才用ARP协议来获得。链路层有MAC帧和ARP层。

APR的工作流程是将IP地址发送到局域网内,对应的主机收到后返回带有自己的MAC地址的响应。

ARP报头

在这里插入图片描述

图中以太网首部就是MAC帧的报头,ARP总共28字节,存在于MAC帧的有效载荷里。以太网地址是MAC地址,如果不知道,就写成全F,这时候就是在局域网内的广播地址,帧类型是0806。硬件类型表明是网络类别,比如以太网,令牌环网,设为1就是以太网;协议类型是要转换的地址类型,也就是IP地址,写为0x0800…,硬件地址长度这里固定为6字节,因为是以太网的MAC地址,协议地址长度这里就固定为IPv4地址,所以是4字节,op为1表示ARP请求,为2是ARP应答,目的以太网地址为全F,表示不知道。

一个局域网内,任何一台主机都可能向别的主机发送ARP请求,收到其它主机发送的ARP请求,也都可以发送ARP应答。因此,一个主机可能既收到ARP应答,又收到APR请求。

还是之前的例子,好几台主机ABCDEF,MAC地址就是macB这样的形式。主机A是一台入口路由器,收到了一个IP报文,里面有目的IP:ipF。此时入口路由器要获取F的MAC地址,就构建一个ARP报文,除去以太网首部,填充剩下的部分,1,0800,6,4,1,macA,ipA,全F,ipF。将填充好的部分,也就是不包括上图的以太网首部的部分,拿着这个,去封装进MAC帧报文,先不管CRC校验和,MAC帧报头填充全F,macA,0806,有效载荷就是刚才构建的ARP报文,整个就构成一个MAC帧报文,发送到局域网中。

所有的主机都收到了这个MAC帧报文,都去分离报头和数据,看到目的MAC地址是全F,就交给ARP层,ARP层拿到除去报头的MAC帧的有效载荷,也就是之前构建的ARP报文,先看到op是1,就知道是请求,再看到目的IP地址是ipF,不是对应主机,那就在ARP层丢弃。当F收到并做同样的步骤后,发现是要询问的是自己的,F就知道A主机在广播询问我的MAC地址,于是构建ARP应答,1,0806,6,4,2,macF,ipF,macA,ipA,然后封装进MAC帧报文,报头是macA,macF,0806,然后F将ARP应答发送到局域网中,其它主机都能收到,但在链路层中的MAC帧层,没有去到链路层的ARP层,就能看到目的MAC地址是macA,不是自己就在MAC帧层丢弃。A也收到,在MAC帧层知道只发给自己的,又看到0806,于是交给ARP层,看到ARP报文,先看op,是2应答,所以就提取发送端以太网地址macF。

所以顺序就是,收到ARP报文后,先看op,因为主机在发送ARP请求后就忘记这码事,所以得先看看来者何人。所以ARP请求和ARP响应是相互独立的。为了防止碰撞,主机内会在得知结果后就把这个关系维护起来。ARP大量存在于各个子网之间的路由器之间,比如传输过程中有什么路由器换了,那就得ARP一下。局域网内要想知道各个主机的IP地址,比如在192.168.1.0子网内。0
位置最多变为255,所以192.168.1.1主机就全都发一遍请求,有应答的就说明对应IP地址有主机,也就拿到了这个主机的IP地址,然后在本主机中保存起来。

Windows下命令arp -a可以看到主机保存的MAC地址,也就是物理地址。想得到对端主机的MAC地址,要发送ARP请求,只需要发送IP协议往上层的任何一个报文即可;或者用ping命令,ping后面加上网址,可以测试网络连通性,会发送IP报文,并且必须给应答,在发ping之前,主机就会发送ARP报文。

主机之间在局域网内发送的单个数据帧体积越小越好。如果碰撞的话,数据帧更长,重发成本就更高。

5、RARP协议

ARP是地址信息协议,RARP是逆地址信息协议。RARP在知道MAC地址时找到IP地址,这个很简单,直接封装MAC帧报文,发送过去询问就可。

6、局域网中间人

在一个局域网内,ABCDE主机和路由器R,E可以和C发消息,E可以发消息到R,由R发到别的子网中。主机的IP地址是公开的,在应用层就知道了。IP地址知道了,就可以ARP找到MAC地址。ARP有缓存,用来维护最新的IP地址和MAC地址。

现在有中间人接入这个局域网,有ipM和macM。主机构建ARP请求时,可以作假,所以中间人可以构建一个ARP请求,表明IP地址是ipR,MAC地址是macM。中间人将ARP请求发给主机A,A的ARP缓存就以为主机R的MAC地址变了,ipR应当对应着macM,而不是之前的macR。之后A每次要发消息给路由器R,都会发给M而不是R。

中间人M给路由器R发送ARP请求,写明IP地址ipA,MAC地址macM。R会发送大量应答冲刷,防止应答丢失,保证应答发送成功。R收到假报文后,就改变了映射关系,将ipA和macM对应起来,这样每次R以为发送给A,其实发送给了M。

像这样的做法叫做ARP欺骗。

6、DNS(简单介绍)

域名解析系统。能把域名转为IP地址,在应用层工作,使用UDP协议来进行DNS请求。IP地址不利于互联网推广宣传,因为全是数字,所以出现域名。域名和IP地址都可以访问同一个网页。浏览器收到输入的域名后,向内置的域名解析服务器发送DNS请求,得到IP地址,再开始和厂商服务器交互。浏览器还会保存一些常见的域名和IP地址的映射关系。当上不了网时,有可能是域名解析服务器挂掉了。

但域名其实并不是大众使用的点,而是搜索引擎,所以需要搜索引擎去做域名。大众打开电脑,打开浏览器,在搜索框内输入内容就可以访问网页,浏览器就通过域名服务来找到相应的网页。

命令cat /etc/hosts,域名解析时会优先查看hosts文件的内容。

一级域名是.后的,比如com,edu,cn等。二级域名是中间的那部分,比如www.baidu.com,baidu就是二级域名。不同的一级域名对应的域名解析也会有所不同。

7、ICMP协议

ICMP在应用层,它可以让应用层协议绕过传输层,直接使用ICMP协议。网络传输中,IP协议只负责传输报文,IP协议不提供传输可靠性,并不知道是否丢包等问题。ICMP协议用来解决IP协议产生的问题,双方ICMP进行交流,如果有丢包对方就得发送报文告知。

确认IP包是否成功到达目标地址
通知在发送过程中IP包被丢弃的原因
ICMP基于IP协议工作
ICMP只能搭配IPv4使用,IPV6得用ICMPv6。

假如对方主机挂掉,发送方多次重发后,对端主机就会发送一个ICMP报文告知发送方出现的问题原因。ICMP既可以通知出错原因,也可以用于诊断查询。

1、报文

在这里插入图片描述

ICMP报文在IP报文的有效载荷中,就像ARP报文在MAC帧的有效载荷中。

在这里插入图片描述

ping命令是C/C++写的工作在应用层的软件,用的就是ICMP协议。发送路径上任何一个主机出问题,都需要给应答,就会被ICMP收到。发送出去的IP报文,报文中有一个TTL字段,一开始设为1,如果中间被丢弃,那么不能直接丢弃,要给应答,这样TTL逐渐增加,就知道一个主机到一个主机时需要多少个中间主机,也就是跳数。

ICMP没有端口号,因为端口号是传输层的内容。

2、traceroute命令

基于ICMP协议实现,能够打印出可执行程序主机,一直到目标主机之前经历多少路由器。

7、NAT技术

解决IPv4地址不足的问题。从运营商内网到公网,通过不断地LAN口和WAN口转换,就是NAT技术。之前已经写过,从内网一个设备发送出去,要能够转换到公网;从公网再回到内网时也要能转换回来。NAT路由器就是做转换工作。

1、基本过程

在这里插入图片描述

当内网一个设备发送请求时,有源IP地址和目的IP地址,NAT路由器对内网有LAN口,对公网有WAN口,请求到达NAT路由器时,源IP地址换成NAT路由器在公网的IP地址,目的地址不变,这就是从内网到公网的过程。

NAT路由器有一个映射表NAPT。从内网到公网会经过一次映射得到公网IP地址,回来的时候也会通过这个映射表来得到内网的源IP地址。

2、NAPT

内网内会有多个设备要访问一个公网的服务器,NAT在转化回来的时候要分清楚是哪个主机,主机的哪个进程。所以IP地址,端口号都得知道,NAT路由器其实甚至能工作到应用层。

图中可以看出,每个主机的源IP地址通过NAT路由器发送到公网时都会变成WAN口的IP地址,但端口号也会不同,所以就出现了上图灰框类似的映射表。IP地址和端口号都换就是因为有多个主机的多个程序在发送消息,需要给所有程序都返回应答。在NAT角度下,内网里就可以没有主机这个概念,而是看作一个个网络客户端进程,而公网里就是一个个网络服务器进程,无论是公网还是内网,ip + port就是它们唯一的进程ID。在一个内网和一个公网的交互过程中,两个网内的ID都是唯一的,放在一起,就是这组网络的唯一,所以NAT路由器就是将唯一做到了现实。

不过映射表中还维护了目的IP。这是因为防止有别的服务器发错信息,映射关系中有目的IP,就能保证接收的是目的服务器的信息,而不是哪个服务器都收。

家里设备上网时,经过的家用路由器,运营商路由器都使用NAPT。

3、缺陷

无法从NAT外部向内部服务器建立连接,转换表的生成和销毁都需要额外开销,通信过程中一旦NAT设备异常,即使存在热备,所有的TCP连接也都会断开。

从外网访问到内网,外网可以发消息到和这个内网NAT路由器相连的网,通过这个网去访问内网。

8、代理服务器

正向代理:在客户端与服务器之间再加一个代理服务器,客户端发给这个代理服务器,代理服务器发给服务器,发送后,传回来的资源也经过代理服务器,代理服务器再发送给客户端,资源也会存在代理服务器,如果有客户端需要曾经某个客户端请求的资源,那么代理服务器就直接把这个资源给客户端,不需要再去访问服务器。正向代理服务器和厂商服务器之间还有路由器。正向代理可以起到缓存资源、提高访问效率的作用。正向代理需要认证,不能让所有人都可以访问,它只是一个区域的方案。正向代理也会过滤非法请求。

反向代理:一个代理服务器不可能面对太多客户端,所有就建立多个代理服务器,提供一样的服务,这些代理服务器就是集群。但这需要客户端发送时要挑选代理服务器吗?这个任务再叫一个代理服务器去做,它通常都是高并发服务器,用来接收所有客户端的请求,然后再分发给集群里的各个代理服务器,要让这些服务器的负载达到均衡。只接受请求并发送出去,所以它的负担不算重,但也需要高并发。这样的高并发的代理服务器就是反向代理服务器。每个集群都有反代理。当有多个集群时,不需要再用一个服务器来接收所有请求,然后分发给所有集群。当客户端要访问某个资源时,每个集群的反代理都有自己的IP地址,所以就通过平衡各集群压力,让这个请求去合适的反代理服务器,再发送到集群中,通过代理服务器去访问资源。

NAT和代理服务器的区别:
NAT解决IPv4地址不足的问题,代理服务器贴近具体应用,比如通过代理来翻墙,迅游加速器也是利用了代理服务器
NAT工作在应用层,直接对IP地址进行替换,代理服务器工作在应用层1
NAT一般在局域网的出口部署,代理服务器可以在局域网做,也可以在广域网,也可以跨网
NAT一般集成在防火墙、路由器等硬件设备上,代理服务器则是一个软件程序,需要部署在服务器上

代理服务器广泛用于翻墙(广域网中的代理)和负载均衡(局域网中的代理)中。

结束。

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

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

相关文章

springboot基于Web的社区医院管理服务系统源码和论文

在Internet高速发展的今天,我们生活的各个领域都涉及到计算机的应用,其中包括社区医院管理服务系统的网络应用,在外国线上管理系统已经是很普遍的方式,不过国内的管理系统可能还处于起步阶段。社区医院管理服务系统具有社区医院信…

你了解计算机网络的发展历史吗?

1.什么是计算机网络 计算机网络是指将一群具有独立功能的计算机通过通信设备以及传输媒体被互联起来的,在通信软件的支持下,实现计算机间资源共享、信息交换或协同工作的系统。计算机网络是计算机技术与通信技术紧密结合的产物,两者的迅速发展…

Vue3组件库 -- element plus 树形选择器组件怎样显示已有的树形菜单?

<el-tree-selectv-model"form.topmneu":data"tableData":props"{ label: title, value: id }":render-after-expand"false"style"width: 100%"check-strictly/> 添加 :props "{ lable : 字段名 , value: 字段…

【计算机网络】TCP原理 | 可靠性机制分析(三)

个人主页&#xff1a;兜里有颗棉花糖 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 兜里有颗棉花糖 原创 收录于专栏【网络编程】【Java系列】 本专栏旨在分享学习网络编程、计算机网络的一点学习心得&#xff0c;欢迎大家在评论区交流讨论&#x1f48c; 目…

讲讲关于跨域的问题,什么是跨域?怎么办?

文章目录 什么是跨域如果非同源&#xff0c;共有三种行为受到限浏览器客户端和向服务器跨域请求的判定流程 跨域问题演示参考 以下内容为我结合他人知识进行的自我总结, 如有错误欢迎指出~ 什么是跨域 跨域就是不同的域名下的资源访问&#xff0c;会被浏览器的本地安全策略阻…

清晰讲解Cookie、Session、Token、JWT之间的区别

文章目录 什么是认证(Authentication)什么是授权(Authorization)什么是凭证(Credentials)什么是Cookie什么是SessionSession的痛点 Cookie 和 Session 的区别什么是Token(令牌)Acesss TokenRefresh Token Token 和 Session 的区别Token 与 Cookie什么是 JWT生成JWTJWT 的原理JW…

rime中州韵小狼毫 词组注释 滤镜

在rime中州韵小狼毫 联想词组 滤镜一文中&#xff0c;我们通过Filter滤镜功能配置了联想词组的功能&#xff0c;这使得我们在输入一些关键词汇时&#xff0c;可以联想补充一些附加的词组&#xff0c;例如我输入“手机”&#xff0c;就可以联想补充对应的手机号&#xff0c;如下…

C语言通过ODBC函数操作Access数据库(mdb和accdb格式)(char字符数组)

编译环境&#xff1a;Windows XP Visual Studio 2010 数据库&#xff1a;Access 2010&#xff0c;accdb格式 本例程只使用char[]字符数组&#xff0c;不使用wchar_t[]字符数组&#xff0c;更适合C语言初学者。 如果读取字符串时&#xff0c;提供的字符数组空间小了&#xff0c…

Airtest-Selenium实操小课:爬取新榜数据

1. 前言 最近看到群里很多小伙伴都在用Airtest-Selenium做一些web自动化的尝试&#xff0c;正好趁此机会&#xff0c;我们也出几个关于web自动化的实操小课&#xff0c;仅供大家参考~ 今天跟大家分享的是一个非常简单的爬取网页信息的小练习&#xff0c;在百度找到新榜网页&am…

【C初阶——指针4】鹏哥C语言系列文章,基本语法知识全面讲解——指针(4)

本文由睡觉待开机原创&#xff0c;转载请注明出处。 本内容在csdn网站首发 欢迎各位点赞—评论—收藏 如果存在不足之处请评论留言&#xff0c;共同进步&#xff01; 这里写目录标题 前言1.回调函数2.qsort函数的使用3.qsort函数的模拟实现 思路大纲&#xff1a; 前言 本节博…

嵌入式培训机构四个月实训课程笔记(完整版)-Linux系统编程第十天-Linux下mplayer音乐播放器练习题(物联技术666)

更多配套资料CSDN地址:点赞+关注,功德无量。更多配套资料,欢迎私信。 物联技术666_嵌入式C语言开发,嵌入式硬件,嵌入式培训笔记-CSDN博客物联技术666擅长嵌入式C语言开发,嵌入式硬件,嵌入式培训笔记,等方面的知识,物联技术666关注机器学习,arm开发,物联网,嵌入式硬件,单片机…

【每日一题】2696. 删除子串后的字符串最小长度-2024.1.10

题目&#xff1a; 2696. 删除子串后的字符串最小长度 给你一个仅由 大写 英文字符组成的字符串 s 。 你可以对此字符串执行一些操作&#xff0c;在每一步操作中&#xff0c;你可以从 s 中删除 任一个 "AB" 或 "CD" 子字符串。 通过执行操作&#xff0c…

Element|Upload结合Progress实现上传展示进度条

背景 &#xff1a; 项目里的 附件上传 题型组件&#xff0c;用户在上传过程中&#xff0c;如果文件较大&#xff0c;上传过程较慢&#xff0c;而又没有一个类似 Loading... 的加载过程的话&#xff0c;会显得干愣愣的&#xff0c;用户体验较差&#xff0c;所以需要添加一个进度…

Springboot+vue的毕业论文管理系统(有报告)。Javaee项目,springboot vue前后端分离项目

演示视频&#xff1a; Springbootvue的毕业论文管理系统&#xff08;有报告&#xff09;。Javaee项目&#xff0c;springboot vue前后端分离项目 项目介绍&#xff1a; 本文设计了一个基于Springbootvue的前后端分离的毕业论文管理系统&#xff0c;采用M&#xff08;model&…

JWT---JSON Web Token

JSON Web Token是什么 JSON Web Token (JWT)是一个开放标准(RFC 7519)&#xff0c;它定义了一种紧凑的、自包含的方式&#xff0c;用于作为JSON对象在各方之间安全地传输信息。该信息可以被验证和信任&#xff0c;因为它是数字签名的。 JSON Web Token的结构是什么样的 JSON…

Handsfree_ros_imu:ROS机器人IMU模块ARHS姿态传感器(A9)Liunx系统Ubuntu20.04学习启动和运行教程

这个是篇学习 Handsfree_ros_imu 传感器的博客记录 官方教程链接见&#xff1a; https://docs.taobotics.com/docs/hfi-imu/ 产品功能 IMU 内有 加速度计&#xff0c;陀螺仪&#xff0c;磁力计这些传感器&#xff0c;通过固定 imu 到物体上后&#xff0c;可以获取物体在运动…

登录模块的实现

一.前期的准备工作 1.页面的布局 (1)表单的校验: 利用element-ui提供的文档绑定rules规则后实现校验 (2)跨域的配置 &#xff1a; 利用proxy代理来解决跨域的问题 (3)axios拦截器的配置 两个点:1. 在请求拦截的成功回调中,如果token,因为调用其它的接口需要token才能调取。 在请…

锤科HandShaker修改版,支持安卓14、澎湃OS

如今几乎各家手机厂商都在布局生态&#xff0c;但PC端往往是最容易被忽略的一环&#xff0c;哪怕是很强的华为鸿蒙、小米澎湃&#xff0c;想要做到手机和电脑互联&#xff0c;也限制了笔记本机型 虽然我一直致力于解锁非小米电脑安装小米电脑管家&#xff0c;比如前几天刚刚更…

在WindowsServer2012中部署war项目

目录 前言 一.jdk安装 二.Tomact安装 三.MySQL安装 ​编辑​编辑​编辑​编辑​编辑​编辑​编辑 四.开放端口号 MySQL开放端口号 Tomact开放端口号 ​编辑 五.项目部署 1.将war放置在tomact中 2.配置项目sql脚本 3.最终效果 前言 安装Java开发工具包&#xff08…

【设计模式-02】Strategy策略模式及应用场景

一、参考资料 Java 官方文档 Overview (Java SE 18 & JDK 18)module indexhttps://docs.oracle.com/en/java/javase/18/docs/api/index.html Java中使用到的策略模式 Comparator、comparable Comparator (Java SE 18 & JDK 18)declaration: module: java.base, pa…