原文链接:http://yifei.me/note/540

HTTP 中常用的方法有 GET/POST/PUT/DELETE 等,在设计API或者表单的时候我们需要选择合适的方法。一般有两种方案:

  1. 只使用 GET 和 POST,GET 主要用来读取数据,POST 用来创建或者更新数据。
  2. RESTful的方法,GET/POST/PUT/DELETE 分别用来增删改查。

URL 的设计

为了探讨两种方案,首先我们来看一下 URL 的设计。URL 是 Universal Resource Locator 的缩写,也就是一个 URL 表示的是唯一的一个资源,所以这个资源的 id 或者说主键应该是放在 URL 路径中的。

比如一个好的设计:

http://example.com/post/1234

不好的设计

http://example.com/post?id=1234

而控制这个资源展示方式的其他字段可以作为参数:

http://exmaple.com/post/1234?lang=zh&utm_source=google

HTTP 方法的含义

好多人对于 http 方法的理解是 GET 是参数在url里,而POST是参数在 body 里面,这样理解是不对的。

在上述的两种方案中,GET 都是用来读取资源的,一般来说不要对资源进行任何更新操作,也就是没有副作用。比如说

不好的设计:

GET http://example.com/post/1234?action=delete

上面的设计意图通过GET操作来删除一个资源,这样非常不好。比如说如果浏览器具有预缓存页面的功能,那么预先读取这个链接的时候就把对应的资源删掉了。

一般来说,GET 方法还要求幂等性,也就是无论多少次操作,最终结果和操作一次都是一样的。GET 操作的参数受到 url 长度的限制,当参数超过 1k 的时候,可以使用 POST 代替。不过这时候你首先应该想一下这么多参数是不是都有用,是不是设计有问题。

POST 方法可以用来创建资源,比如说:

POST http://example.com/post/

content=xxxxxxx&author=xxxx&date=xxxx

POST 操作具有副作用,也就是说会更改服务器上的状态。另外 POST 操作一般不是幂等的,每次 POST 操作都应该创建一个新的资源。

PUT 操作用来更新资源,也是幂等的。

PUT http://example.com/post/1234

content=yyyyyy

DELETE 用来删除资源,值得注意的是,根据规范 DELETE 方法不能带有 body。

DELETE http://example.com/post/1234

最新文章

  1. 移动前端开发之viewport的深入理解
  2. js中this的用法
  3. PLSQL数据导入导出问题解决(空表、大字段表、表空间错误等)
  4. 36个炫丽的html5 canvas展示
  5. 八大排序算法的 Python 实现
  6. php像新浪微博一样生成短域名
  7. App自适应
  8. 解决Java版CKFinder无法显示缩略图问题
  9. Centos7源码安装mysql及读写分离,互为主从
  10. 简单登录案例(SharedPreferences存储账户信息)&联网请求图片并下载到SD卡(文件外部存储)
  11. C与C++中的const
  12. 2015第10周四-CSS小结
  13. XML实例入门2
  14. Indy的TCPServer到底能支持多少个连接
  15. Spring的字符编码过滤器CharacterEncodingFilter
  16. HDU 2209 翻纸牌游戏(DFS)
  17. 【Beta阶段】测试与发布
  18. Cesium 中两种添加 model 方法的区别
  19. Oracle Ora 错误解决方案合集
  20. Codeforces 555D Case of a Top Secret

热门文章

  1. 26.Remove Duplicates from Sorted Array(Array)
  2. for 续3
  3. info信息总结
  4. lombok 介绍及基本使用方法
  5. Photoshop中的高斯模糊、高反差保留和Halcon中的rft频域分析研究
  6. python 3 print function
  7. Android 集成支付宝第三方登录
  8. docker 关于volumns的总结(转)
  9. platform总线驱动代码分析
  10. python二叉树染色-有严重BUG