RFC是什么

如果从RFC规范定义的语义来看:

GET方法就是安全且幂等的,因为它是「只读」操作,无论操作多少次,服务器上的数据都是安全的,

且每次的结果都是相同的。所以,可以对GET请求的数据做缓存,这个缓存可以做到浏览器本身上

(彻底避免浏览器发请求),也可以做到代理上(如nginx),而且在浏览器中GET请求可以保存为书

签。

POST因为是「新增或提交数据」的操作,会修改服务器上的资源,所以是不安全的,且多次提交数据

就会创建多个资源,所以不是幂等的。所以,浏览器一般不会缓存POST请求,也不能把POST请求保

存为书签。

但是实际过程中,开发者不一定会按照RFC规范定义的语义来实现GET和POST方法。

上面提到的RFC是什么

RFC是 Request for Comments (请求意见稿)的缩写,是一系列由互联网工程任务组(IETF)发布的技术文档,用于 定义和规范化互联网协议、标准和技术规范


关于RFC的关键点:

1. 本质作用

  • 互联网的"技术宪法":从TCP/IP、HTTP到Email格式,所有基础协议都由RFC定义
  • 每个RFC都有唯一编号(如RFC 7231定义了HTTP/1.1的语义)
  • 一旦发布,内容永不修改;若需更新,会发布新编号的RFC

2. 权威性

  • 文中提到的GET/POST的"安全"、"幂等"等语义,正是来源于RFC 7231的严格定义
  • 开发者理论上必须遵循RFC规范,否则不同系统间的互操作性会崩溃

3. 为什么实际开发会"违背"RFC?

  • 历史包袱:早期不规范的实现已形成事实标准(如用GET提交表单数据)
  • 便利性:开发者可能为图方便而"滥用"(如用POST实现查询接口,避免缓存问题)
  • 认知偏差:并非所有开发者都深入研读过RFC规范

4. 典型例子

  • GET:RFC规定用于"获取资源",参数应在URL中,长度受限
  • POST:RFC规定用于"提交数据",数据应在请求体中
  • 但现实中有开发者用GET提交大量数据,或用POST做删除操作,这些在RFC看来都是"不规范"的

简单说:RFC是技术标准的"官方定义书",但实际开发中可能出现"方言"式的变通用法。

相关推荐
@encryption13 小时前
计算机网络 --- NAT
运维·服务器·计算机网络
如君愿13 小时前
考研复习 Day 26 | 习题--计算机网络第三章(数据链路层 下)、数据结构 多维数组与广义表
数据结构·计算机网络·考研·记录考研
如君愿2 天前
考研复习 Day 25 | 习题--计算机网络第三章(数据链路层 上)、数据结构(串)
数据结构·计算机网络·考研
仍然.2 天前
初识计算机网络
网络·计算机网络
rannn_1112 天前
【中北大学计网实验报告】|《计算机网络实验:从Packet Tracer入门到交换机配置》
计算机网络·实验报告·中北大学
wefg12 天前
【计算机网络】传输层协议(UDP/TCP)
tcp/ip·计算机网络·udp
Mrlxl.cn2 天前
计算机网络——网络层
c语言·数据结构·计算机网络·考研
向往着的青绿色2 天前
Java反序列化漏洞(持续更新中)
java·开发语言·计算机网络·安全·web安全·网络安全·网络攻击模型
Mrlxl.cn2 天前
计算机网络——传输层
c语言·计算机网络·考研·排序算法
国冶机电安装2 天前
计算机网络系统安装的结构逻辑、施工重点与运维价值
运维·网络·计算机网络