HTTP中的GET、POST方法
HTTP
超文本传输协议(HTTP)的设计目的是保证客户端与服务器之间的通信。
HTTP 的工作方式是客户端与服务器之间的请求-应答协议。
在客户机和服务器之间进行请求-响应时,两种最常被用到的方法是:GET 和 POST。
GET - 从指定的资源请求数据。用于请求服务器发送某个资源。(查询)
POST - 向指定的资源提交要被处理的数据。用于向服务器提交数据,比如完成表单数据的提交,将数据提交给服务器处理。(修改)
GET
GET请求的数据会附在URL之后(就是把数据放置在HTTP协议头中),以?分割URL和传输数据,参数之间以&相连,如:
login.action?name=admin&password=123456&verify=%E4%BD%A0%E5%A5%BD
如果数据是英文字母或数字,则原样发送;如果是空格,转换为+;如果是中文或其他字符,则直接把字符串用BASE64加密,得出如:%E4%BD%A0%E5%A5%BD,其中%XX中的XX为该符号以16进制表示的ASCII码值。
- 使用GET方法时,浏览器会缓存你的地址等信息,留下历史记录和Cookie。
- GET是安全(安全仅仅指非修改信息)的。仅仅是获取资源信息,就像数据库查询一样,不会修改和增加数据,不会影响资源的状态。
- GET是幂等的。幂等是指对同一个URL的多个请求应该返回同样的结果。
POST
Post 是将表单中的数据放在 form 的数据体中,按照变量和值相对应的方式,传递到 action 所指向 URL。
POST请求方式是既不幂等又不安全,首先POST请求方式往数据库中提交数据的,因此会改变数据库中的数据。其次,POST请求方式每次获得的结果都有可能不一样,因为POST请求是作用在上一级的URL上的,则每一次请求都会添加一份新资源(这也是POST和PUT方式的最大区别,PUT方式是幂等的)。
Idempotent(幂等)
如果一个方法重复执行多次,产生的效果是一样的,那就是idempotent的。在HTTP中,PUT被定义为idempotent的方法,POST则不是。
example:
一个博客系统提供一个Web API,模式是 http://superblogging/blogs/post/{blog-name} 。很简单,将{blog-name}替换为我们的blog名字,往这个URI发送一个HTTP PUT或者POST请求,HTTP的body部分就是博文,这是一个很简单的REST API例子。我们应该用PUT方法还是POST方法?取决于这个REST服务的行为是否是idempotent的,假如我们发送两个http://superblogging/blogs/post/Sample请求,服务器端是什么样的行为?如果产生了两个博客帖子,那就说明这个服务不是idempotent的,因为多次使用产生了副作用;如果后一个请求把第一个请求覆盖掉了,那这个服务就是idempotent的。前一种情况,应该使用POST方法,后一种情况,应该使用PUT方法。
参考:
https://www.runoob.com/tags/html-httpmethods.html
https://www.cnblogs.com/williamjie/p/9099940.html