Linux 网络编程 --- 应用层

2024-09-09 17:12
文章标签 linux 编程 网络 应用层

本文主要是介绍Linux 网络编程 --- 应用层,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、自定义协议和序列化反序列化
代码:

序列化反序列化实现网络版本计算器

二、HTTP协议

1、谈两个简单的预备知识

https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址

http的端口号为80端口,https的端口号为443

url为统一资源定位符。CSDNicon-default.png?t=O83Ahttps://mp.csdn.net/mp_blog/creation/editor?spm=1000.2115.3001.4503这就是一个url,所有网络上的资源,都可以用唯一的一个字符串标识,并且可以获取到资源。

网络行为:把别人的东西拿下来,把自己的东西传上去。

少量的情况,提交或者获取的数据本身可能包含和url中特殊的字符冲突的字符,要求BS双方进行编码和解码。

转义规则

2、http请求和响应,格式画出来,两个工具见一见http请求/响应的样子。

请求行内容

3、写一个最简单的httpserver,用浏览器直接测试

代码:

自主http实现

上图为http协议的请求报文的真实格式,每个字段代表什么,可以去自己搜一下。

user_agent :代表了客户机上所对应的浏览器型号等内容。通常表明这是一个很正常的客户端。反爬虫可以去检测这个user_agent。检测客户端是否合法。

4、谈http报文的细节

HTTP的方法

我们日常使用某些网站,我们把我们的数据是通过html中的表单来提交的

如果我们要提交 参数给我们的服务器,我们使用get方法的时候,我们提交的参数是通过url提交的!!

POST方法也可以提交参数,通过正文进行提交。GET方法通过URL进行提参,参数数量是受限的。不私密。POST方法是私密的。

HTTP的状态码

404没有发现要访问的资源

302 临时重定向,301永久重定向,搭配报头中的Location字段来使用。

让服务器指导浏览器,让浏览器访问新的地址

HTTP常见的Header

Content-Type: 数据类型 (text/html )
Content-Length: Body 的长度
Host: 客户端告知服务器 , 所请求的资源是在哪个主机的哪个端口上 ;
User-Agent: 声明用户的操作系统和浏览器版本信息 ;
referer: 当前页面是从哪个页面跳转过来的 ;
location: 搭配 3xx 状态码使用 , 告诉客户端接下来要去哪里访问 ;
Cookie: 用于在客户端存储少量信息 . 通常用于实现会话 (session) 的功能 ;

 connection: keep_alive,这是一个长连接。一个巨大的页面是会包含非常多的元素的!每一个元素就是一个资源!一次请求响应一个资源就关闭连接,叫做短链接。建立一个TCP连接,发送和返回多个http的请求和回复,叫做长连接。

Content-type: 内容格式 

cookie

http协议本身是无状态的。http对登录用户的会话保持功能。

原理:

浏览器保存cookie文件有两种方式,文件级和内存级。

向我们的浏览器写入cookie,做一个实验。

在回复报文中添加set-cookie字段

cookie被盗取的问题和个人信息泄漏的问题。

解决方案:session ID ,解决了私人信息泄露的问题。

 session ID 是服务器端统一管理分配的。

HTTPS解决安全问题

HTTPS 协议讲解

HTTPS也是一个应用层协议

两个观点:

1、攻破的成本大于攻破后的收益,这样的网络协议就是安全的。

2、ssl权威的官方的加密解密方案。

SSL(Secure Sockets Layer)是一种用于在计算机网络上保护数据传输安全的协议,它通过在客户端浏览器和Web服务器之间建立一条SSL安全通道,提供对用户和服务器的认证、对传送的数据进行加密和隐藏、确保数据在传送中不被改变,即数据的完整性。SSL协议主要用来提供对用户和服务器的认证,确保数据传输的安全性,现已成为该领域中全球化的标准。此外,SSL证书是遵守SSL协议,由受信任的数字证书颁发机构(CA)在验证服务器身份后颁发的具有服务器身份验证和数据传输加密功能的数字证书‌(AI的回答)

基础概念的理解:

什么是加密:把一个明文通过一系列变换变成密文。

什么是解密:把一个密文通过一系列变换变成明文。

密钥:一系列变换的辅助数据称为密钥

常见的加密方式:

对称加密:加密解密所采用的密钥只有一个。特点是算法公开,计算量小,速度快。

需要两个密钥来进行加密和解密。特点是运算速度特别慢。

对公钥进行加密时,只有拥有私钥的人来解密。

数据指纹(数据摘要)使用hash算法转换为固定长度的,非常低概率发生冲突的字符串,具有唯一性。(MD5是典型的哈希算法)称为数据指纹(数据指纹)在经过加密会形成一个数据签名。

 讲解思路

我们自己设计一套加密方式

方案一:只是用对称加密:

方案二:只是用非对称加密 

非对称加密,用公钥加密的数据可以用私钥解密。用私钥加密的数据只能用公钥解密。 

方案三:双方都是用非对称加密

双方互相把公钥发送给对方,都用对方的公钥进行加密。c-s用服务器的私钥解密。s-c 用客户端的私钥解密。貌似没有问题但是这里的效率太慢了并且仍然由安全问题。

 方案四:非对称加密 + 对称加密

但是上面的方案,最开始就会受到中间人的攻击呢?

上面的方法就都不安全了。下面的方式为中间人攻击

确实,在⽅案2/3/4中,客⼾端获取到公钥S之后,对客⼾端形成的对称秘钥X⽤服务端给客⼾端的公钥 S进⾏加密,中间⼈即使窃取到了数据,此时中间⼈确实⽆法解出客⼾端形成的密钥X,因为只有服务 器有私钥S' ,但是中间⼈的攻击,如果在最开始握⼿协商的时候就进⾏了,那就不⼀定了,假设hacker已经成功成 为中间⼈
1. 服务器具有⾮对称加密算法的公钥S,私钥S'
2. 中间⼈具有⾮对称加密算法的公钥M,私钥M'
3. 客⼾端向服务器发起请求,服务器明⽂传送公钥S给客⼾端
4. 中间⼈劫持数据报⽂,提取公钥S并保存好,然后将被劫持报⽂中的公钥S替换成为⾃⼰的公钥M, 并将伪造报⽂发给客⼾端
5. 客⼾端收到报⽂,提取公钥M(⾃⼰当然不知道公钥被更换过了),⾃⼰形成对称秘钥X,⽤公钥M加 密X,形成报⽂发送给服务器
6. 中间⼈劫持后,直接⽤⾃⼰的私钥M'进⾏解密,得到通信秘钥X,再⽤曾经保存的服务端公钥S加 密后,将报⽂推送给服务器
7. 服务器拿到报⽂,⽤⾃⼰的私钥S'解密,得到通信秘钥X
8. 双⽅开始采⽤X进⾏对称加密,进⾏通信。但是⼀切都在中间⼈的掌握中,劫持数据,进⾏窃听甚 ⾄修改,都是可以的

 客户端无法验证服务器发来的公钥是否是合法的。、

那么如何保证安全呢?如何验证公钥是合法的呢?

CA证书:CA认证

服务端在使⽤HTTPS前,需要向CA机构申领⼀份数字证书,数字证书⾥含有证书申请者信息、公钥信 息等。服务器把证书传输给浏览器,浏览器从证书⾥获取公钥就⾏了,证书就如⾝份证,证明服务端 公钥的权威性。

问题又来了,你怎么保证你的证书是权威机构发布且没有被改过呢?

证书里面有一个签名

理解签名:

签名的形成是基于⾮对称加密算法的,注意,⽬前暂时和https没有关系,不要和https中的公钥私钥搞 混了

CA证书的形成就可以用上面的算法来进行。上面的数据就是提交给CA的申请信息。CA使用散列函数。形成签名,CA机构也有自己的公钥和私钥注意这里的私钥和公钥跟之前讲的私钥和公钥毫无关系。用自己的私钥对签名进行加密。和数据附加到一起就形成了CA证书。服务器把证书发送给客户端的时候,client通过CA的公钥对签名进行解密。再按照上图验证的方式对数据和签名进行判断。如果在传输的过程中被修改。数据摘要和散列值会不相同,证书不可信。

 方案五:

非对称加密 + 对称加密 + CA证书

所有的客户端只使用CA的公钥去解密我们的数字签名,也就意味着,只有CA能够进行证书的签发,因为只有CA自己具有私钥。所以中间人没资格进行证书的重新形成。如果我们中间人把整个证书都调换了呢?黑客申请真证书,提交信息。证书中的域名是不同的,域名具有唯一性。客户端还是可以识别的。

如何看待HTTPS?

其实是很安全的。但是如果中间人是客户本身。

这篇关于Linux 网络编程 --- 应用层的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1151776

相关文章

Linux流媒体服务器部署流程

《Linux流媒体服务器部署流程》文章详细介绍了流媒体服务器的部署步骤,包括更新系统、安装依赖组件、编译安装Nginx和RTMP模块、配置Nginx和FFmpeg,以及测试流媒体服务器的搭建... 目录流媒体服务器部署部署安装1.更新系统2.安装依赖组件3.解压4.编译安装(添加RTMP和openssl模块

linux下多个硬盘划分到同一挂载点问题

《linux下多个硬盘划分到同一挂载点问题》在Linux系统中,将多个硬盘划分到同一挂载点需要通过逻辑卷管理(LVM)来实现,首先,需要将物理存储设备(如硬盘分区)创建为物理卷,然后,将这些物理卷组成... 目录linux下多个硬盘划分到同一挂载点需要明确的几个概念硬盘插上默认的是非lvm总结Linux下多

如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解

《如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解》:本文主要介绍如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别的相关资料,描述了如何使用海康威视设备网络SD... 目录前言开发流程问题和解决方案dll库加载不到的问题老旧版本sdk不兼容的问题关键实现流程总结前言作为

linux进程D状态的解决思路分享

《linux进程D状态的解决思路分享》在Linux系统中,进程在内核模式下等待I/O完成时会进入不间断睡眠状态(D状态),这种状态下,进程无法通过普通方式被杀死,本文通过实验模拟了这种状态,并分析了如... 目录1. 问题描述2. 问题分析3. 实验模拟3.1 使用losetup创建一个卷作为pv的磁盘3.

Linux环境变量&&进程地址空间详解

《Linux环境变量&&进程地址空间详解》本文介绍了Linux环境变量、命令行参数、进程地址空间以及Linux内核进程调度队列的相关知识,环境变量是系统运行环境的参数,命令行参数用于传递给程序的参数,... 目录一、初步认识环境变量1.1常见的环境变量1.2环境变量的基本概念二、命令行参数2.1通过命令编程

Linux之进程状态&&进程优先级详解

《Linux之进程状态&&进程优先级详解》文章介绍了操作系统中进程的状态,包括运行状态、阻塞状态和挂起状态,并详细解释了Linux下进程的具体状态及其管理,此外,文章还讨论了进程的优先级、查看和修改进... 目录一、操作系统的进程状态1.1运行状态1.2阻塞状态1.3挂起二、linux下具体的状态三、进程的

Linux编译器--gcc/g++使用方式

《Linux编译器--gcc/g++使用方式》文章主要介绍了C/C++程序的编译过程,包括预编译、编译、汇编和链接四个阶段,并详细解释了每个阶段的作用和具体操作,同时,还介绍了调试和发布版本的概念... 目录一、预编译指令1.1预处理功能1.2指令1.3问题扩展二、编译(生成汇编)三、汇编(生成二进制机器语

C#多线程编程中导致死锁的常见陷阱和避免方法

《C#多线程编程中导致死锁的常见陷阱和避免方法》在C#多线程编程中,死锁(Deadlock)是一种常见的、令人头疼的错误,死锁通常发生在多个线程试图获取多个资源的锁时,导致相互等待对方释放资源,最终形... 目录引言1. 什么是死锁?死锁的典型条件:2. 导致死锁的常见原因2.1 锁的顺序问题错误示例:不同

Rsnapshot怎么用? 基于Rsync的强大Linux备份工具使用指南

《Rsnapshot怎么用?基于Rsync的强大Linux备份工具使用指南》Rsnapshot不仅可以备份本地文件,还能通过SSH备份远程文件,接下来详细介绍如何安装、配置和使用Rsnaps... Rsnapshot 是一款开源的文件系统快照工具。它结合了 Rsync 和 SSH 的能力,可以帮助你在 li

Linux部署jar包过程

《Linux部署jar包过程》文章介绍了在Linux系统上部署Java(jar)包时需要注意的几个关键点,包括统一JDK版本、添加打包插件、修改数据库密码以及正确执行jar包的方法... 目录linux部署jar包1.统一jdk版本2.打包插件依赖3.修改密码4.执行jar包总结Linux部署jar包部署