【Linux网络编程】应用层协议HTTP(请求方法,状态码,重定向,cookie,session)

news2025/4/3 21:42:20

 🎁个人主页:我们的五年

🔍系列专栏:Linux网络编程

🌷追光的人,终会万丈光芒

🎉欢迎大家点赞👍评论📝收藏⭐文章

Linux网络编程笔记:

https://blog.csdn.net/djdjiejsn/category_12885098.html

前言:

前面讲了HTTP的请求,响应格式。但是里面的知识点还没有细讲。报文里面的内容没有讲。这篇就是对HTTP的详细讲解。

目录

1.简单信息

1.1HTTP的基本信息:

1.2URL网址:

2.请求格式:

2.1基本格式: 

3.请求方法:

3.1GET方法:

3.2POST方法:

3.3PUT方法:

3.4HEAD方法:

3.5DELETE方法:

3.6OPTIONS方法:

4.HTTP响应状态码(了解):

4.1:1开头的状态码

4.2:2开头的状态码

4.3:3开头的状态码

4.3:4开头的状态码

 4.3:5开头的状态码

5.重定向:

6.报头header

6.1关于cookie:

6.2关于session

6.3关于connection


1.简单信息

1.1HTTP的基本信息:

HTTP的英文是:(HyperText  Transfer  Protocol)超文本传输协议首字母的缩写。

超文本可以添加链接,有了链接,就可以从一个网站到另一个网站,可以传输图片,视频,音频,

超文本(Hypertext)是一种通过链接将文本的不同部分或不同文本之间相互连接的文本结构。

超文本最重要的部分就是链接功能了。

HTTP协议就是定义了浏览器(客户端Client)和服务器(服务端Server)的协议。HTTP是浏览器和服务器之间通信的基础。客户端给服务器发送请求,然后服务器收到以后,对请求进行处理,然后给客服端回响应。响应的可能是服务器上的资源(GET方法),或者提交资源(POST方法)……

HTTP是无连接的,无状态的协议,每次请求都要建立新的连接,服务器也不会保存客户端的信息。对于网站让我们登录进去可以,就认识我们了,以后每次请求都认识我们了,是服务器里面cookie的功劳。

1.2URL网址:

然后URL网址的基本信息,之前也讲过了,Encode,DeCode,下面的图讲的也是非常的清楚。

关于Encode,DeCode就可以去看这篇文章:

【Linux网络编程】:URL(encode),HTTP协议,telnet工具-CSDN博客


2.请求格式:

基本的格式这篇文章也讲了:(点击进入就可以)

【Linux网络编程】:URL(encode),HTTP协议,telnet工具-CSDN博客

2.1基本格式: 

基本格式就是是这样,然后就是讲里面的具体参数了。

请求报头Header会有一个参数Content-Length来标识请求正文的长度。

空行后面的内容就是请求正文。


3.请求方法:

请求方法有很多种,用了区分请求是要干什么,服务器要知道客户端要干什么才有后面的。

虽然请求有很多种,但是每种不可能都执行,大部分都是不允许的,比如向服务器上次资源(百度网盘,这种服务方向的除外),基本的是不允许随便上传,或者再向写文章,在抖音上产视频,也只是开放了部分的资源。部分接口。在合理,正常功能内上传资源,删除资源肯定是没问题了。

下面的表格由Kimi生成。

序号请求方法描述
1GET请求指定的页面信息,并返回实体主体。通常用于获取数据,不会对数据进行更改。
2HEAD类似于GET请求,但只返回HTTP报头,不返回文档主体。常用于检查资源是否存在或获取资源的元数据
3POST向指定资源提交数据进行处理请求(例如提交表单或者上传文件)。数据被包含在请求体中,可能会导致新的资源的建立和/或已有资源的修改。
4PUT从客户端向服务器传送的数据取代指定的文档的内容。如果资源不存在,可能会创建新的资源。
5DELETE请求服务器删除指定的页面或资源
6CONNECT把请求连接转换到透明的TCP/IP通道,通常用于代理服务器或建立HTTPS连接。
7OPTIONS返回服务器支持的HTTP方法。常用于跨域资源共享(CORS)的预检请求。
8TRACE回显服务器收到的请求,主要用于测试或诊断。
9PATCH对资源进行部分修改,实体中包含一个表,表中说明与该URI所表示的原内容的区别。
10MOVE请求服务器将指定的页面移至另一个网络地址。
11COPY请求服务器将指定的页面拷贝至另一个网络地址。
12LINK请求服务器建立链接关系。
13UNLINK请求服务器断开链接关系。
14WRAPPED允许客户端发送经过封装的请求。
15Extension-method在不改动协议的前提下,可增加另外的方法。

3.1GET方法:

🍟作用:用于请求URL的指定资源

🍟示例:GET(请求方法)             /index.html(URL)              HTTP/1.1(HTTP版本)。(请求行,要请求的就是服务器下面的iindex.html,当然可以对这个路径进行解析,在开头增加目录)。

🍟特性:指定资源经服务器端解析后返回响应内容。

3.2POST方法:

🍟用途:用于传输实体的主体,通常用于提交表单数据。
🍟示例:POST                   submit.cgi                       HTTP/1.1
🍟特性:可以发送大量的数据给服务器,并且数据包含在请求体中

3.3PUT方法:

🍟用途:用于传输文件,将请求报文主体中的文件保存到请求 URL 指定的位置
🍟示例:PUT                      /example.html                        HTTP/1.1
🍟特性:不太常用,但在某些情况下,如 RESTful API 中,用于更新资源

3.4HEAD方法:

🍟用途:与 GET 方法类似,但不返回报文主体部分,仅返回响应头。
🍟示例:HEAD /index.html HTTP/1.1
🍟特性:用于确认 URL 的有效性及资源更新的日期时间等。

3.5DELETE方法:

🍟用途:用于删除文件,是 PUT 的相反方法。
🍟示例:DELETE                         /example.html                        HTTP/1.1
🍟特性:按请求 URL 删除指定的资源

3.6OPTIONS方法:

🍟用途:用于查询针对请求 URL 指定的资源支持的方法。
🍟示例:OPTIONS           *                         HTTP/1.1
🍟特性返回允许的方法,如 GET、POST 等。


4.HTTP响应状态码(了解):

虽然定了规定的状态码,但是各个浏览器器直接没有好好的遵循。各个浏览器之间是竞争关系,状态码也各不一样。对于对于状态码浏览器来说,状态码也没那么重要。

所以在不同的浏览器之间,相同的状态码表示不同的信息。

前端工作人员可能也不会严格遵循,毕竟还要做兼容性检查。不同状态码也能被解释。

4.1:1开头的状态码

1xx(信息性状态码):请求已被接受,正在继续处理。

具体的看下表:

100,主要是在上传大型文件的时候,表示服务器已经接受到了,正在处理。

状态码状态说明
100继续请求者应当继续提出请求。服务器已收到请求的第一部分,正在等待其余部分。
101切换协议请求者已要求服务器切换协议,服务器已确认并准备切换。
102继续执行由WebDAV扩展的状态码,代表处理将被继续执行。
103早期提醒利用服务器思考时间来传递内容,当浏览器向服务器发出请求时等待回应时,由边缘网络线发送页面载入提示给浏览器。

4.2:2开头的状态码

2xx(成功状态码):请求已成功被服务器处理。

状态码状态说明
200成功服务器已成功处理了请求,通常表示服务器提供了请求的网页。
201已创建请求成功并且服务器创建了新的资源。
202已接受服务器已接受请求,但尚未处理。
203非授权信息服务器已成功处理了请求,但返回的信息可能来自另一来源。
204无内容服务器成功处理了请求,但没有返回任何内容。
205重置内容服务器成功处理了请求,但没有返回任何内容,要求客户端重置视图。
206部分内容服务器成功处理了部分GET请求。
207多种状态由WebDAV状态码,代表之后的消息体将是一个XML消息,且可能依照之前子请求数量不同,含一系列独立的响应代码

4.3:3开头的状态码

3xx(重定向状态码):客户端需要进一步操作才能完成请求

状态码状态说明
300多种选择针对不同请求,服务器可执行多种操作。
301永久移动请求的网页已永久移动到新位置。
302资源已找到(临时移动)告诉客户端,请到另一处URL获取需要的资源。
303查看其他位置请求者应当对不同的位置使用单独的GET请求来获取资源。
304资源未修改自从上次请求后,网页未做过修改。
305使用代理请求者只能使用代理访问所请求的资源。
307临时重定向服务器临时重定向请求到另一个URL。
308永久重定向请求的资源永久移动,客户端应使用新URL

4.3:4开头的状态码

请求有错误,客户端可能需要修改请求

状态码状态说明
400请求错误请求有语法错误。
401未授权请求未授权。
403禁止服务器拒绝执行。
404未找到请求的资源不存在。
405方法不允许请求方法不被允许。
406不接受服务器无法提供请求的资源。
407需要代理认证需要代理服务器认证。
408请求超时请求超时。
409冲突请求与资源的当前状态冲突。
410已删除请求的资源已被永久删除。
411需要长度服务器拒绝处理当前请求,因为请求的内容长度未定义。
412先决条件失败服务器在验证请求的头字段中给出的先决条件时,未能满足其中的一个或多个。
413负载过大请求提交的实体数据大小超过了服务器愿意或能够处理的范围。
414URI过长请求的URI长度超过了服务器能够解释的长度。
415不支持的媒体类型请求中提交的实体并不是服务器中所支持的格式。
416范围不符合请求的范围不符合。
417期望失败在请求头Expect中指定的预期内容无法被服务器满足。
422不可处理的实体请求格式正确,但服务器无法处理。
429请求过多客户端在给定的时间内发送了过多的请求

 4.3:5开头的状态码

5xx(服务器错误状态码):服务器在处理请求时发生了错误

状态码状态说明
500内部服务器错误服务器内部错误。
501未实现服务器无法处理请求。
502错误网关无效的网关。
503服务不可用服务器暂时不可用。
504网关超时网关超时。
505HTTP版本不支持服务器不支持请求的HTTP版本

5.重定向:

重定向有两种,一种是临时重定向,还有一种是永久重定向。不管是永久重定向还有临时重定向,都是和报头中的location有关的,当请求的URL需要重定向到新的URL时,header就会带location信息。

比如下面就是302临时重定向,错误码描述是Found,然后需要重定向到https://www.new-url.com。(这里)

HTTP/1.1       302         Found\r\n

Location: https://www.new-url.com\r\n


6.报头header

报文里面可能下面以下信息,也可以一个都没有,比如有正文body,但是没有Content,浏览器一样可以解释,浏览器还是很厉害的。

然后就是我们可以根据请求的资源区分是什么类型的文本,HTML还是TXT,还是其他的。

Content-Type: 数据类型(text/html 等)。

Content-Length: Body 的长度。
Host: 客户端告知服务器, 所请求的资源是在哪个主机的哪个端口上;

User-Agent: 声明用户的操作系统和浏览器版本信息;

referer: 当前页面是从哪个页面跳转过来的;

Location: 搭配 3xx 状态码使用, 告诉客户端接下来要去哪里访问;

Cookie: 用于在客户端存储少量信息. 通常用于实现会话(session)的功能;

6.1关于cookie:

cookie会保存我们的信息,比如我们登陆一个网站,输入了用户名,密码。下次访问这个网站的时候,就直接把这些信息加到HTTP请求里面。我们就不需要进行登录了,然后就可以查看这些信息了,当然这些信息我们解析不出来是什么。

6.2关于session

session的话,就是防止我们的信息泄露,再保存了cookie信息的时候,只用代号进行传输,当然代号也可以被盗走,但至少我们具体的用户名,信息不会盗走。也就是可能黑客可以登录盗走的QQ,但是没有办法知道密码,进行改密码。

6.3关于connection

 这个就表示连接的信息:需要长连接还是短连接。HTTP1.1版本默认使用长连接,即报头没有connection信息的时候,就是和服务器建立长的连接。HTTP1.0使用的是短连接,要长连接需要再报头中加入Connection: keep-alive。

HTTP/1.1:在 HTTP/1.1 协议中,默认使用持久连接。当客户端和服务器都不明确指定关闭连接时,连接将保持打开状态,以便后续的请求和响应可以复用同一个连接。

HTTP/1.0:在 HTTP/1.0 协议中,默认连接是非持久连接。如果希望在 HTTP/1.0上实现持久连接,需要在请求头中显式设置 Connection: keep-alive

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

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

相关文章

健康养生:从生活细节开启活力之旅

在忙碌的现代生活里,健康养生不再是一个抽象概念,而是关乎生活质量的关键。其实,只要掌握日常养生要点,就能轻松开启活力满满的健康生活。 饮食是健康的基石。每日饮食需遵循 “彩虹原则”,摄入多种颜色食物。早餐时&…

DeepSeek + Mermaid编辑器——常规绘图

下面这张图出自:由清华大学出品的 《DeepSeek:从入门到精通》。 作为纯文本生成模型,DeepSeek虽不具备多媒体内容生成接口,但其开放式架构允许通过API接口与图像合成引擎、数据可视化工具等第三方系统进行协同工作,最终…

【拥抱AI】GPT Researcher的诞生

一、GPT Researcher 研究过程总结 GPT Researcher 是一个开源的自主智能体,旨在通过利用人工智能技术实现高效、全面且客观的在线研究。它通过一系列创新的设计和优化,解决了传统研究工具(如 AutoGPT)中存在的问题,如…

Redis7——基础篇(三)

前言:此篇文章系本人学习过程中记录下来的笔记,里面难免会有不少欠缺的地方,诚心期待大家多多给予指教。 基础篇: Redis(一)Redis(二) 接上期内容:上期完成了Redis的基本…

MySQL登录问题总结

不管何种数据库,使用的第一步都是先登录。 MySQL命令行登录语句:mysql -u username -P port -p -D database_name 登录MySQL的报错一般从报错信息都能得到反馈,常见报错原因分析如下,实例中的以test用户为例,登录环境为…

Redis 持久化:从零到掌握

Redis 作为一款广泛使用的内存数据库,虽然核心功能是基于内存提供高性能的数据存取,但在实际应用中,数据的持久化是不可忽视的。毕竟,内存中的数据一旦出现故障或重启,就会面临数据丢失的风险。因此,Redis …

Mybatis MyBatis框架的缓存 一级缓存

1. 缓存的概念 缓存的概念 在内存中临时存储数据,速度快,可以减少数据库的访问次数。经常需要查询,不经常修改的数据,不是特别重要的数据都适合于存储到缓存中。 2.Mybatis缓存 mybatis包含了一个非常强大的查询缓存特性&#…

第1章大型互联网公司的基础架构——1.6 RPC服务

你可能在1.1节的引言中注意到业务服务层包括HTTP服务和RPC服务,两者的定位不一样。一般来说,一个业务场景的核心逻辑都是在RPC服务中实现的,强调的是服务于后台系统内部,所谓的“微服务”主要指的就是RPC服务;而HTTP服…

idea-gradle打包运行配置

最近接触了一个项目,使用gradle做为构建工具,这里记录一波,毕竟平时使用的都是maven idea 配置 这里有个坑,Gradle Wrapper,配置的地址gradle下载超时 这个配置修改成阿里的 第一张 第二张 第二张配置的jvm貌似没啥用…

(新版本onenet)stm32+esp8266/01s mqtt连接onenet上报温湿度和远程控制(含小程序)

物联网实践教程:微信小程序结合OneNET平台MQTT实现STM32单片机远程智能控制 远程上报和接收数据——汇总 前言 之前在学校获得了一个新玩意:ESP-01sWIFI模块,去搜了一下这个小东西很有玩点,远程控制LED啥的,然后我就想…

一键部署开源DeepSeek并集成到钉钉

一键部署开源DeepSeek并集成到钉钉 简介: DeepSeek发布了两款先进AI模型V3和R1,分别适用于对话AI、内容生成及推理任务。由于官方API流量限制,阿里云推出了私有化部署方案,无需编写代码即可完成部署,并通过计算巢AppF…

【爬虫基础】第一部分 网络通讯 P1/3

前言 1.知识点碎片化:每个网站实现的技术相似但是有区别,要求我们根据不同的网站使用不同的应对手段。主要是常用的一些网站爬取技术。 2.学习难度:入门比web简单,但后期难度要比web难,在于爬虫工程师与网站开发及运维…

车载音频配置(二)

目录 OEM 自定义的车载音频上下文 动态音频区配置 向前兼容性 Android 14 车载音频配置 在 Android 14 中,AAOS 引入了 OEM 插件服务,使你可以更主动地管理由车载音频服务监督的音频行为。 随着新的插件服务的引入,车载音频配置文件中添加了以下更改: • OEM 自定义的车…

级联选择器多选动态加载

一.级联展示 注:因为级联选择器这里是动态加载,因此如果上来选中一级就需要加载出后面三级的全部数据,依然会很卡,因此,和产品协商把一二级多选框去掉了,这样也避免了你选择一级不能实现子级被全部选中的问…

华为动态路由-OSPF-骨干区

华为动态路由-OSPF-骨干区 一、OSPF简介 1、OSPF概述 OSPF是一种开放式的、基于链路状态的内部网关协议(IGP),用于在自治系统内部进行路由选择和通信。 OSPF是互联网工程任务组(IETF)定义的标准之一,被广…

网络安全治理模型

0x02 知识点 安全的目标是提供 可用性 Avialability机密性 confidentiality完整性 Integrity真实性 Authenticity不可否认性 Nonrepudiation 安全治理是一个提供监督、问责和合规性的框架 信息安全系统 Information Security Management System ISMS 策略,工作程…

企业软件合规性管理:构建高效、安全的软件资产生态

引言 在数字化转型的浪潮下,企业的软件使用方式日益多元化,涉及云端、订阅制、永久授权及浮动许可等多种模式。然而,随着软件资产的增多,企业面临着合规性管理的严峻挑战:非法软件使用、许可证管理不当、软件资产闲置…

PyTorch 源码学习:阅读经验 代码结构

分享自己在学习 PyTorch 源码时阅读过的资料。本文重点关注阅读 PyTorch 源码的经验和 PyTorch 的代码结构。因为 PyTorch 不同版本的源码实现有所不同,所以笔者在整理资料时尽可能按版本号升序,版本号见标题前[]。最新版本的源码实现还请查看 PyTorch 仓…

vscode复制到下一行

linux中默认快捷键是ctrl shift alt down/up 但是在vscode中无法使用,应该是被其他的东西绑定了,经测试,可以使用windows下的快捷键shift alt down/up { “key”: “shiftaltdown”, “command”: “editor.action.copyLinesDownAction”…

Fastgpt学习(5)- FastGPT 私有化部署问题解决

1.☺ 问题描述: Windows系统,本地私有化部署,postgresql数据库镜像日志持续报错" data directory “/var/lib/postgresql/data” has invalid permissions ",“ DETAIL: Permissions should be urwx (0700) or urwx,gr…