程序员:我终于知道post和get的区别

效率工具传送门

  • 推荐20套实战源码

  • 程序员你可以考虑安装的15款谷歌插件

  • 99%的人不知道搜索引擎的6个技巧

  • 12款好用的Visual Studio插件,最后一款良心推荐

IT界知名的程序员曾说:对于那些月薪三万以下,自称IT工程师的码农们,其实我们从来没有把他们归为我们IT工程师的队伍。他们虽然总是以IT工程师自居,但只是他们一厢情愿罢了。

此话一出,不知激起了多少(码农)程序员的愤怒,却又无可奈何,于是码农问程序员。

码农:你知道get和post请求到底有什么区别?
程序员:你看这篇就知道了。
码农:你月薪三万了?
程序员:嗯。
码农:你是怎么做到的?
程序员:我做梦做到的

前言

这个问题几乎面试的时候都会问到,是一个老生常谈的话题,然而随着不断的学习,对于以前的认识有很多误区,所以还是需要不断地总结的,学而时习之,不亦说乎。

关于get和post如果你有条件上百度的话,至少有200百万条结果,每个人都有每个人的思考,当然,这篇也是我的思考,如果有些结论有错误,希望能够喷起来。在批评中不断改进,与诸君共勉一句话:若批评无意义,则赞美无意义。

文章目录

  • 前言
  • 01 特点
      • 1.1 http的特点
      • 1.2 请求方法
      • 1.3 我们耳熟能详的的区别
  • 02 常见的误区
      • 2.1 误区一
      • 2.2 误区二
      • 2.3 误区三
      • 2.4 误区四:“GET产生一个TCP数据包;POST产生两个TCP数据包。”
  • 3 http状态码附录
      • 3.1 状态码1xx
      • 3.2 状态码2xx:成功
      • 3.3 状态码3xx:重定向
      • 3.4 状态码4xx:客户端错误
      • 3.5 状态码5** 服务端错误

01 特点

1.1 http的特点

  • 基于tcp/ip、一种网络应用层协议、超文本传输协议HyperText Transfer Protocol
  • 工作方式:客户端请求服务端应答的模式
  • 快速:无状态连接
  • 灵活:可以传输任意对象,对象类型由Content-Type标记
  • 客户端请求request消息包括以下格式:请求行(request line)、请求头部(header)、空行、请求数据
    在这里插入图片描述
    服务端响应response也由四个部分组成,分别是:状态行、消息报头、空行、响应正文
    在这里插入图片描述

1.2 请求方法

http请求可以使用多种请求方法。
HTTP1.0定义了三种请求方法: GET, POST 和 HEAD方法。

HTTP1.1新增了五种请求方法:OPTIONS, PUT, DELETE, TRACE 和 CONNECT 方法。

HTTP2.0 新的二进制格式(Binary Format),HTTP1.x的解析是基于文本。基于文本协议的格式解析存在天然缺陷,文本的表现形式有多样性,要做到健壮性考虑的场景必然很多,二进制则不同,只认0和1的组合。基于这种考虑HTTP2.0的协议解析决定采用二进制格式,实现方便且健壮。

多路复用(MultiPlexing),即连接共享,即每一个request都是是用作连接共享机制的。一个request对应一个id,这样一个连接上可以有多个request,每个连接的request可以随机的混杂在一起,接收方可以根据request的 id将request再归属到各自不同的服务端请求里面。

header压缩,如上文中所言,对前面提到过HTTP1.x的header带有大量信息,而且每次都要重复发送,HTTP2.0使用encoder来减少需要传输的header大小,通讯双方各自cache一份header fields表,既避免了重复header的传输,又减小了需要传输的大小。

服务端推送(server push),同SPDY一样,HTTP2.0也具有server push功能。
参考链接:https://baike.baidu.com/item/HTTP%202.0/12520156?fr=aladdin

  • 1 GET 请求指定的页面信息,并返回实体主体。
  • 2 HEAD 类似于get请求,只不过返回的响应中没有具体的内容,用于获取报头
  • 3 POST 向指定资源提交数据进行处理请求(例如提交表单或者上传文件)。数据被包含在请求体中。POST请求可能会导致新的资源的建立和/或已有资源的修改。
  • 4 PUT 从客户端向服务器传送的数据取代指定的文档的内容。
  • 5 DELETE 请求服务器删除指定的页面。
  • 6 CONNECT HTTP/1.1协议中预留给能够将连接改为管道方式的代理服务器。
  • 7 OPTIONS 允许客户端查看服务器的性能。
  • 8 TRACE 回显服务器收到的请求,主要用于测试或诊断。

1.3 我们耳熟能详的的区别

http协议最常见的两种方法GET和POST,这几点答案其实有几点并不准确

  • 请求缓存:GET 会被缓存,而post不会

  • 收藏书签:GET可以,而POST不能

  • 保留浏览器历史记录:GET可以,而POST不能

  • 用处:get常用于取回数据,post用于提交数据

  • 安全性:post比get安全

  • 请求参数:querystring 是url的一部分get、post都可以带上。 get的querystring(仅支持urlencode编码),post的参数是放在body(支持多种编码)

  • 请求参数长度限制:get请求长度最多1024kb,post对请求数据没有限制

02 常见的误区

在这里插入图片描述
get和post误区
针对上面常见的区别,如果面试的时候这么说,肯定是有很大的毛病,刚在学校面试的时候也曾经囫囵吞枣地这样说过,现在回过头再想以前的错误认知,又有许多新的认识。

2.1 误区一

“用处:get常用于取回数据,post用于提交数据”

曾听到过这样一种说法:get替换post来优化网站性能,虽然这种说法没错,也的确get常被用于取回数据,但是post也被一些ui框架使用于取回数据,比如kendo ui中的grid,就是用post来接受数据的。所以结论是get、post用途也是因地制宜。如果你有使用过kendo UI,会发现分页、过滤、自定义的参数都包含在form data里面。

请求参数
get是querystring(仅支持urlencode编码),post是放在body(支持多种编码)
query参数是URL的一部分,而GET、POST等是请求方法的一种,不管是哪种请求方法,都必须有URL,而URL的query是可选的,可有可无。

2.2 误区二

“请求参数长度限制:get请求长度最多1024kb,post对请求数据没有限制”

这句话看上去实在没毛病啊,菜鸟教程也是这样说的啊。虽然字面意思上没有错误,但是理解一定要正确。我想说的是GET方法提交的url参数数据大小没有限制,在http协议中没有对url长度进行限制(不仅仅是querystring的长度),这个限制是特定的浏览器及服务器对他的限制

下面就是对各种浏览器和服务器的最大处理能力做一些说明

  • IE浏览器对URL的最大限制为2083个字符
  • Firefox (Browser):对于Firefox浏览器URL的长度限制为65,536个字符。
  • Safari (Browser):URL最大长度限制为 80,000个字符。
  • Opera (Browser):URL最大长度限制为190,000个字符。
  • Google (chrome):URL最大长度限制为8182个字符。
  • Apache (Server):能接受最大url长度为8,192个字符。
  • Microsoft Internet Information Server(IIS):能接受最大url的长度为16,384个字符。

所以为了符合所有标准,url的最好不好超过最低标准的2083个字符(2k+35)。当然在做客户端程序时,url并不展示给用户,只是个程序调用,这时长度只收web服务器的影响了。对于中文的传递,一个汉字最终编码后的字符长度是9个字符。

最常见的form表单,浏览器默认的form表单,默认的content-type是application/x-www-form-urlencoded,提交的数据会按照key value的方式,jquery的ajax默认的也是这种content-type。当然在post方式中添加querystring一定是可以接收的到,但是在get方式中加body参数就不一定能成功接收到了。

2.3 误区三

“post比get安全性要高”

这里的安全是相对性,并不是真正意义上的安全,通过get提交的数据都将显示到url上,页面会被浏览器缓存,其他人查看历史记录会看到提交的数据,而post不会。另外get提交数据还可能会造成CSRF攻击。

2.4 误区四:“GET产生一个TCP数据包;POST产生两个TCP数据包。”

这一点理解起来还是有一定难度的,实际上,不论哪一种浏览器,在发送 POST 的时候都没有带 Expect 头,server 也自然不会发 100 continue。通过抓包发现,尽管会分两次,body 就是紧随在 header 后面发送的,根本不存在『等待服务器响应』这一说。
从另一个角度说,TCP 是传输层协议。别人问你应用层协议里的 GET 和 POST 有啥区别,你回答说这俩在传输层上发送数据的时候不一样,确定别人不抽你?
参考资料:https://zhuanlan.zhihu.com/p/25028045

3 http状态码附录

3.1 状态码1xx

  • 100 Continue:
    服务器仅接收到部分请求,但是一旦服务器并没有拒绝该请求,客户端应该继续发送其余的请求。
  • 101 Switching Protocols:
    服务器转换协议:服务器将遵从客户的请求转换到另外一种协议。
  • 102: 由WebDAV(RFC 2518):
    扩展的状态码,代表处理将被继续执行

3.2 状态码2xx:成功

  • 200 OK:
    请求成功(其后是对GET和POST请求的应答文档。)
  • 201 Created:
    请求被创建完成,同时新的资源被创建。
  • 202 Accepted:
    供处理的请求已被接受,但是处理未完成。
  • 203 Non-authoritative Information:
    文档已经正常地返回,但一些应答头可能不正确,因为使用的是文档的拷贝。
  • 204 No Content:
    没有新文档。浏览器应该继续显示原来的文档。如果用户定期地刷新页面,而Servlet可以确定用户文档足够新,这个状态代码是很有用的。
  • 205 Reset Content:
    没有新文档。但浏览器应该重置它所显示的内容。用来强制浏览器清除表单输入内容。
  • 206 Partial Content:
    客户发送了一个带有Range头的GET请求,服务器完成了它。

3.3 状态码3xx:重定向

  • 300 Multiple Choices:
    多重选择。链接列表。用户可以选择某链接到达目的地。最多允许五个地址。
  • 301 Moved Permanently:
    所请求的页面已经转移至新的url
  • 302 Found:
    所请求的页面已经临时转移至新的url。
  • 303 See Other:
    所请求的页面可在别的url下被找到。
  • 304 Not Modified:
    未按预期修改文档。客户端有缓冲的文档并发出了一个条件性的请求(一般是提供If-Modified-Since头表示客户只想比指定日期更新的文档)。服务器告诉客户,原来缓冲的文档还可以继续使用。
  • 305 Use Proxy:
    客户请求的文档应该通过Location头所指明的代理服务器提取。
  • 306 Unused:
    此代码被用于前一版本。目前已不再使用,但是代码依然被保留。
  • 307 Temporary Redirect:
    被请求的页面已经临时移至新的url。

3.4 状态码4xx:客户端错误

  • 400 Bad Request:
    服务器未能理解请求。
  • 401 Unauthorized:
    被请求的页面需要用户名和密码。
  • 401.1:
    登录失败。
  • 401.2:
    服务器配置导致登录失败。
  • 401.3:
    由于 ACL 对资源的限制而未获得授权。
  • 401.4:
    筛选器授权失败。
  • 401.5:
    ISAPI/CGI 应用程序授权失败。
  • 401.7:
    访问被 Web 服务器上的 URL 授权策略拒绝。这个错误代码为 IIS 6.0 所专用。
  • 402 Payment Required:
    此代码尚无法使用。
  • 403 Forbidden:
    对被请求页面的访问被禁止。
  • 404 Not Found:
    服务器无法找到被请求的页面。
  • 405 Method Not Allowed:
    请求中指定的方法不被允许。
  • 406 Not Acceptable:
    服务器生成的响应无法被客户端所接受。
  • 407 Proxy Authentication Required:
    用户必须首先使用代理服务器进行验证,这样请求才会被处理。
  • 408 Request Timeout:
    请求超出了服务器的等待时间。
  • 409 Conflict:
    由于冲突,请求无法被完成。
  • 410 Gone:
    被请求的页面不可用。
  • 411 Length Required:
    “Content-Length” 未被定义。如果无此内容,服务器不会接受请求。
  • 412 Precondition Failed:
    请求中的前提条件被服务器评估为失败。
  • 413 Request Entity Too Large:
    由于所请求的实体的太大,服务器不会接受请求。
  • 414 Request-url Too Long:
    由于url太长,服务器不会接受请求。当post请求被转换为带有很长的查询信息的get请求时,就会发生这种情况。
  • 415 Unsupported Media Type:
    由于媒介类型不被支持,服务器不会接受请求。
  • 416 Requested Range Not Satisfiable:
    服务器不能满足客户在请求中指定的Range头。
  • 417 Expectation Failed:
    执行失败。
  • 423:
    锁定的错误。

3.5 状态码5** 服务端错误

  • 500 Internal Server Error:
    请求未完成。服务器遇到不可预知的情况。
  • 501 Not Implemented:
    请求未完成。服务器不支持所请求的功能。
  • 502 Bad Gateway:
    请求未完成。服务器从上游服务器收到一个无效的响应。
  • 503 Service Unavailable:
    请求未完成。服务器临时过载或宕机。
  • 504 Gateway Timeout:
    网关超时。
  • 505 HTTP Version Not Supported:
    服务器不支持请求中指明的HTTP协议版本。

作者信息
【文章信息】:作者-张林:原文链接-https://blog.csdn.net/kebi007/article/details/103175193
【原创公众号】:dotNet全栈开发。好文目录
版权声明:本文为CSDN博主「dotNet全栈开发」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。

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

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

相关文章

chatgpt赋能python:Python通过IP连接同一局域网中的电脑

Python通过IP连接同一局域网中的电脑 在日常工作中,我们常常需要在本地局域网内进行电脑之间的通信,这时候就需要借助一些工具来进行IP连接。而对于Python编程来说,实现这个过程也非常简单。 什么是IP连接 IP连接指的是使用IP地址和端口号…

chatgpt赋能python:Python获取电脑IP地址方法与实例

Python获取电脑IP地址方法与实例 什么是IP地址 IP地址是一个数字标识符,是指在Internet协议中用作网络接口标识和定位地址的32位二进制数,通常表现为四个十进制数,每个数用“.”分隔,如192.168.0.1。在不同的网络协议中&#xf…

win10计算机ip如何更改,Win10本地连接ip怎么更改_Win10怎么更改ip地址?-192路由网...

问:Win10本地连接IP地址怎么更改? 本人是电脑小白,新买的电脑,是Win10系统;请问Win10电脑中的IP地址在哪里更改? 答:Win10系统IP地址需要在“本地连接”的 属性 中进行更改的。所以,…

chatgpt赋能python:Python获得电脑IP地址

Python获得电脑IP地址 在进行网络编程时,通常需要获取本机的IP地址。对于Python开发者来说,获取电脑IP地址可能是开发过程中常见需求之一。本文将介绍如何使用Python获取电脑IP地址,以及其中的一些常见问题和解决方案。 什么是IP地址&#…

万字长文 | ChatGPT的工作原理(二)

— 6 — 嵌入的概念 神经网络 —— 至少在它们目前的设置中 —— 从根本上说是基于数字的。因此,如果我们要用它们来处理像文本这样的东西,我们就需要一种方法来用数字表示我们的文本。 当然,我们可以开始(基本上就像 ChatGPT 那…

You don't have permission to access 权限问题

修改pip.ini配置文件如下: 综合搜索案例如下: 我遇到的情况是修改了,第一张图的配置,还是不行,那就是其他情况,虽然第二张图的这种写法,在线上是可以用的,但是在线下是不能用的&…

网络错误:windows无法访问\\,你没有权限访问\\

网络错误:windows无法访问\\,你没有权限访问\\ 电脑突然不能网络访问。 客户端:win10 服务器端:win2003 处理办法: 设置/控制面板/用户帐户/管理windows凭证 检查是否存在登录过的ip信息: 如果存在,删除…

关于访问权限控制问题

实际上Java中是有访问权限控制的,就是我们个人的隐私的一样,我不允许别人随便来查看我们的隐私,只有我们自己同意的情况下,才能告诉别人我们的名字、年龄等隐私信息。 所以说Java中引入了访问权限控制(可见性),我们可…

解决“你没有权限访问,请与网络管理员联系”

局域网共享时提示你"没有权限访问,请与网络管理员联系请求访问权限".局域网共享无法访问被共享的文件夹。 方法/步骤 1 找到你要共享的文件夹,选中并且右键,选中属性,选择安全选项卡 2 点击安全选项卡下面的编辑&#x…

解决局域网共享文件时提示“没有权限访问,请与网络管理员联系请求访问权限“

在两台或者多台装有Windows中的PC之间进行大文件传输时,如何比较快速、便捷的传输呢?当时是Windows局域网共享! 右击想要共享的文件或文件夹,在弹出的菜单栏选择“属性”: 在弹出的文档“属性”选项卡中,点…

智能感知编码优化与落地实践

作者 | XHF 导读 基于人眼视觉特性出发的感知编码优化技术,成为互联网短视频、OTT 等 UGC 场景的重点优化手段,可以在降低视频码率的同时,提升视频的观看体验。 今天主要有 4 个方面的内容。首先给大家介绍一下感知编码的技术背景&#xff1b…

诺基亚与微软完成交易 | 历史上的今天

整理 | 王启隆 透过「历史上的今天」,从过去看未来,从现在亦可以改变未来。 今天是 2023 年 4 月 25 日,在 2005 年的今天,网易 CEO 丁磊确认,《环球企业家》原总经理兼执行主编李甬将在 5 月 1 日后正式出任网易副总裁…

英特尔锐炫™ 显卡运行类 ChatGPT 的开源大语言模型(LLM) Dolly 2.0 | 开发者实战...

点击蓝字 关注我们,让开发变得更有 前言 以下为当前一代大型语言模型(LLM)的基石说明。 人类偏好强化学习Reinforcement learning with human preferences(RLHF)和 InstructGPT 等技术一直是 ChatGPT 和 GPT-4 等突破的核心基础。…

对比Google翻译、百度翻译和有道翻译

上周,关于有道翻译出现了一则新闻。 网易有道上线神经网络翻译,质量提升超过去十年总和 我个人经常使用Google翻译(Google翻译没有被墙)。然后便对Google翻译、百度翻译和有道翻译做了个对比。 测试了句子,一个问号便说明了问题。

2023下半场,成为首批彻底搞懂支付的人

为什么在2023年的下半场,你需要彻底搞懂支付? 纵观人类发展的历史,每一次支付手段的演变,都给社会经济发展和商品流通带来了巨大的动力和新的发展机会。支付手段在一定程度上影响着社会生产力的发展,是关乎国计民生的重…

小白放心看|简单聊聊Chat-GPT和大模型

今年, Chat-GPT问世之后,国内外诸多知名公司,如百度、阿里和谷歌等纷纷加入到大模型研发优化的行列中来。短时间内,GPT不仅成为科技圈新宠,还频频“破圈”在人们的日常学习办公生活中得到广泛应用。无论是业内人员还是…

免费送书!深度强化学习实战

你听说了吗?微软市值一夜暴涨5450亿美元! 难道是出现了什么颠覆人类的“黑科技”吗? 图1:微软股价变动 没错,就是这个令AI界发生震动的ChatGPT! ChatGPT因其可以逼真地模拟人类语言、与用户可以自然地交互而…

微软市值暴涨千亿,就靠这个技术!

你听说了吗?微软市值一夜暴涨5450亿美元! 难道是出现了什么颠覆人类的“黑科技”吗? 图1:微软股价变动 没错,就是这个令AI界发生震动的ChatGPT! ChatGPT因其可以逼真地模拟人类语言、与用户可以自然地交互而…

小白都看明白的「大模型」科普文

自2022年11月ChatGPT正式上线开始,引发了新一轮人工智能热潮,百度发布 “文心一言”、OpenAI发布ChatGPT-4等据中国移动的不完全统计,目前国内包括百度、阿里、华为在内至少19家大型科技公司、科研院校和初创科技团队涉足人工智能大模型训练。…