GET与POST的区别:为什么GET请求参数会被完整保留在浏览器历史记录里,而POST中的参数不会被保留?

简介: 欢迎来到前端入门之旅!

⭐  专栏简介


       欢迎来到前端入门之旅!这个专栏是为那些对Web开发感兴趣、刚刚开始学习前端的读者们打造的。无论你是初学者还是有一些基础的开发者,我们都会在这里为你提供一个系统而又亲切的学习平台。我们以问答形式更新,为大家呈现精选的前端知识点和最佳实践。通过深入浅出的解释概念,并提供实际案例和练习,让你逐步建立起一个扎实的基础。无论是HTML、CSS、JavaScript还是最新的前端框架和工具,我们都将为你提供丰富的内容和实用技巧,帮助你更好地理解并运用前端开发中的各种技术。



       同时,我们也会关注最新的前端趋势和发展动态。随着Web技术的不断演进,前端开发也在不断推陈出新。我们会及时介绍最新的前端框架、工具和技术,使你能够站在前沿,与时俱进。通过掌握最新的前端技术,你将能够在竞争激烈的Web开发领域中有更大的竞争力。



📘  文章引言


一、GET和POST是什么


GET和POST,两者是HTTP协议中发送请求的方法


GET


GET方法请求一个指定资源的表示形式,使用GET的请求应该只被用于获取数据


POST


POST方法用于将实体提交到指定的资源,通常导致在服务器上的状态变化或副作用


本质上都是TCP链接,并无差别


但是由于HTTP的规定和浏览器/服务器的限制,导致他们在应用过程中会体现出一些区别


二、区别


从w3schools得到的标准答案的区别如下:


GET在浏览器回退时是无害的,而POST会再次提交请求。

GET产生的URL地址可以被Bookmark,而POST不可以。

GET请求会被浏览器主动cache,而POST不会,除非手动设置。

GET请求只能进行url编码,而POST支持多种编码方式。

GET请求参数会被完整保留在浏览器历史记录里,而POST中的参数不会被保留。

GET请求在URL中传送的参数是有长度限制的,而POST没有。

对参数的数据类型,GET只接受ASCII字符,而POST没有限制。

GET比POST更不安全,因为参数直接暴露在URL上,所以不能用来传递敏感信息。

GET参数通过URL传递,POST放在Request body中

参数位置

貌似从上面看到GET与POST请求区别非常大,但两者实质并没有区别


无论 GET 还是 POST,用的都是同一个传输层协议,所以在传输上没有区别


当不携带参数的时候,两者最大的区别为第一行方法名不同


POST /uri HTTP/1.1 \r\n


GET /uri HTTP/1.1 \r\n


当携带参数的时候,我们都知道GET请求是放在url中,POST则放在body中


GET 方法简约版报文是这样的


GET /index.html?name=qiming.c&age=22 HTTP/1.1
Host: localhost


POST 方法简约版报文是这样的


POST /index.html HTTP/1.1
Host: localhost
Content-Type: application/x-www-form-urlencoded
name=qiming.c&age=22


注意:这里只是约定,并不属于HTTP规范,相反的,我们可以在POST请求中url中写入参数,或者GET请求中的body携带参数


参数长度


HTTP 协议没有Body和 URL 的长度限制,对 URL 限制的大多是浏览器和服务器的原因


IE对URL长度的限制是2083字节(2K+35)。对于其他浏览器,如Netscape、FireFox等,理论上没有长度限制,其限制取决于操作系统的支持


这里限制的是整个URL长度,而不仅仅是参数值的长度


服务器处理长 URL 要消耗比较多的资源,为了性能和安全考虑,会给 URL 长度加限制


安全


POST 比 GET 安全,因为数据在地址栏上不可见


然而,从传输的角度来说,他们都是不安全的,因为 HTTP 在网络上是明文传输的,只要在网络节点上捉包,就能完整地获取数据报文


只有使用HTTPS才能加密安全


数据包


对于GET方式的请求,浏览器会把http header和data一并发送出去,服务器响应200(返回数据)


对于POST,浏览器先发送header,服务器响应100 continue,浏览器再发送data,服务器响应200 ok


并不是所有浏览器都会在POST中发送两次包,Firefox就只发送一次


⭐  写在最后


请大家不吝赐教,在下方评论或者私信我,十分感谢🙏🙏🙏.


✅ 认为我某个部分的设计过于繁琐,有更加简单或者更高逼格的封装方式


✅ 认为我部分代码过于老旧,可以提供新的API或最新语法


✅ 对于文章中部分内容不理解


✅ 解答我文章中一些疑问


✅ 认为某些交互,功能需要优化,发现BUG


✅ 想要添加新功能,对于整体的设计,外观有更好的建议


最后感谢各位的耐心观看,既然都到这了,点个 👍赞再走吧!

相关文章
|
1月前
|
前端开发
调试前端时,在浏览器上修改参数并重新调用接口
有时候我们的页面点击过了,但是接口出问题,想修改参数再调用一次,一般是用apiPost工具把接口复制,再加上token和参数,但是这样非常的效率比较低。
42 0
|
3月前
|
Web App开发 前端开发
Chrome 浏览器插件 V3 版本 Manifest.json 文件中 Action 的类型(Types)、方法(Methods)和事件(Events)的属性和参数解析
Chrome 浏览器插件 V3 版本 Manifest.json 文件中 Action 的类型(Types)、方法(Methods)和事件(Events)的属性和参数解析
156 0
|
4月前
【超实用】Angular如何修改当前页面网页浏览器url后面?param1=xxx&param2=xxx参数(多用于通过浏览器地址参数保存用户当前操作状态的需求),实现监听url路由切换、状态变化。
【超实用】Angular如何修改当前页面网页浏览器url后面?param1=xxx&param2=xxx参数(多用于通过浏览器地址参数保存用户当前操作状态的需求),实现监听url路由切换、状态变化。
【超实用】Angular如何修改当前页面网页浏览器url后面?param1=xxx&param2=xxx参数(多用于通过浏览器地址参数保存用户当前操作状态的需求),实现监听url路由切换、状态变化。
|
20天前
【超实用】Angular如何修改当前页面网页浏览器url后面?param1=xxx&param2=xxx参数(多用于通过浏览器地址参数保存用户当前操作状态的需求),实现监听url路由切换、状态变化。
【超实用】Angular如何修改当前页面网页浏览器url后面?param1=xxx&param2=xxx参数(多用于通过浏览器地址参数保存用户当前操作状态的需求),实现监听url路由切换、状态变化。
|
20天前
|
JavaScript
【归总】原生js操作浏览器hash、url参数参数获取/修改方法合集
【归总】原生js操作浏览器hash、url参数参数获取/修改方法合集
|
8月前
|
Web App开发 Python
Python Chrome handless(无界面浏览器,add_argument 支持哪些参数,替代 PhantomJS)
Python Chrome handless(无界面浏览器,add_argument 支持哪些参数,替代 PhantomJS)
95 0
|
10月前
一句话让spring-boot帮我开启浏览器参数内容协商策略
一句话让spring-boot帮我开启浏览器参数内容协商策略
|
11月前
|
JavaScript
封装js获取浏览器上面的参数
封装js获取浏览器上面的参数
46 0
|
索引
LeetCode 5430. 设计浏览器历史记录
你有一个只支持单个标签页的 浏览器 ,最开始你浏览的网页是 homepage ,你可以访问其他的网站 url ,也可以在浏览历史中后退 steps 步或前进 steps 步。
65 0
|
数据采集 Python
Python爬虫:浏览器请求头参数RequestHeaders
Python爬虫:浏览器请求头参数RequestHeaders
123 0
Python爬虫:浏览器请求头参数RequestHeaders

热门文章

最新文章