在项目中,需要为APP撰写API。刚开始【转载请注明来源】【版权所有,侵权必究】接触的时候,并没有考虑太多,就想提供UR本文作者:唐霜,转载请注明出处。未经授权,禁止复制转载。L,APP端通过该URL进行查询、创建、未经授权,禁止复制转载。【版权所有】唐霜 www.tangshuang.net更新等操作即可。但再对相关规范进行了解后本文作者:唐霜,转载请注明出处。【本文首发于唐霜的博客】,才发现,API的设计并没有那么简单,远转载请注明出处:www.tangshuang.net著作权归作者所有,禁止商业用途转载。远不是URL的问题,而是一个通信协议的整【本文受版权保护】【原创不易,请尊重版权】体架构。因此,我写这篇文章,用来记录自己【转载请注明来源】【原创不易,请尊重版权】的一些心得,并不断完善。并提供关于RES著作权归作者所有,禁止商业用途转载。【访问 www.tangshuang.net 获取更多精彩内容】Tful API的一些参考文献。
转载请注明出处:www.tangshuang.net著作权归作者所有,禁止商业用途转载。1. 使用SSL(https)来提供URL
首先,使用https可以在数据包被抓取时【本文受版权保护】【未经授权禁止转载】多一层加密。我们现在的APP使用环境大部著作权归作者所有,禁止商业用途转载。原创内容,盗版必究。分都是在路由器WIFI环境下,一旦路由器【转载请注明来源】【转载请注明来源】被入侵,那么黑客可以非常容易的抓取到用户著作权归作者所有,禁止商业用途转载。著作权归作者所有,禁止商业用途转载。通过路由器传输的数据,如果使用http未【原创内容,转载请注明出处】本文版权归作者所有,未经授权不得转载。经加密,那么黑客可以很轻松的获取用户的信【转载请注明来源】原创内容,盗版必究。息,甚至是账户信息。
本文版权归作者所有,未经授权不得转载。【转载请注明来源】其次,即使使用https,也要在API数【作者:唐霜】【未经授权禁止转载】据传输设计时,正确的采用加密。例如直接将【原创不易,请尊重版权】转载请注明出处:www.tangshuang.nettoken信息放在URL中的做法,即使你转载请注明出处:www.tangshuang.net未经授权,禁止复制转载。使用了https,黑客抓不到你具体传输的【原创内容,转载请注明出处】【未经授权禁止转载】数据,但是可以抓到你请求的URL啊!因此【本文首发于唐霜的博客】【版权所有,侵权必究】,使用https进行请求时,要采用POS未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。T、PUT或者HEAD的方式传输必要的数【版权所有】唐霜 www.tangshuang.net【原创不易,请尊重版权】据。
著作权归作者所有,禁止商业用途转载。【版权所有】唐霜 www.tangshuang.net本文作者:唐霜,转载请注明出处。【关注微信公众号:wwwtangshuangnet】2. 使用GET、POST、PUT、DELETE、HEAD这几种请求模式
请求模式也可以说是动作、数据传输方式,通本文版权归作者所有,未经授权不得转载。【版权所有】唐霜 www.tangshuang.net常我们在web中的form有GET、PO【未经授权禁止转载】【本文首发于唐霜的博客】ST两种,而在HTTP中,存在下发这几种原创内容,盗版必究。本文版权归作者所有,未经授权不得转载。。
本文版权归作者所有,未经授权不得转载。本文作者:唐霜,转载请注明出处。本文作者:唐霜,转载请注明出处。- GET (选择):从服务器上获取一个具体的资源【版权所有】唐霜 www.tangshuang.net【版权所有】唐霜 www.tangshuang.net或者一个资源列表。 【版权所有】唐霜 www.tangshuang.net【本文首发于唐霜的博客】原创内容,盗版必究。【作者:唐霜】
- POST (创建): 在服务器上创建一个新的资源【版权所有,侵权必究】【原创不易,请尊重版权】。 【本文首发于唐霜的博客】本文版权归作者所有,未经授权不得转载。
- PUT (更新):以整体的方式更新服务器上的一【未经授权禁止转载】【未经授权禁止转载】个资源。 本文版权归作者所有,未经授权不得转载。未经授权,禁止复制转载。著作权归作者所有,禁止商业用途转载。
- PATCH (更新):只更新服务器上一个【本文首发于唐霜的博客】【转载请注明来源】资源的一个属性。 未经授权,禁止复制转载。原创内容,盗版必究。
- DELETE (删除):删除服务器上的一个资源。 本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。【本文首发于唐霜的博客】本文作者:唐霜,转载请注明出处。
- HEAD : 获取一个资源的元数据,如数【访问 www.tangshuang.net 获取更多精彩内容】原创内容,盗版必究。据的哈希值或最后的更新时间。 【访问 www.tangshuang.net 获取更多精彩内容】著作权归作者所有,禁止商业用途转载。【版权所有,侵权必究】【原创内容,转载请注明出处】
- OPTIONS:获取客户端能对资源做什么原创内容,盗版必究。【本文受版权保护】操作的信息。 【转载请注明来源】【版权所有,侵权必究】转载请注明出处:www.tangshuang.net
3. 在URI中体现资源,而非动作
阅读RESTful架构的参考文献之后,你转载请注明出处:www.tangshuang.net转载请注明出处:www.tangshuang.net会了解什么是资源的概念,以及REST的确【版权所有,侵权必究】著作权归作者所有,禁止商业用途转载。切含义。再构建API的URL的时候,UR【原创内容,转载请注明出处】本文作者:唐霜,转载请注明出处。I中应该仅包含资源(对象),而不要加入动本文作者:唐霜,转载请注明出处。【原创内容,转载请注明出处】作。比如 /user/1/update 【版权所有】唐霜 www.tangshuang.net【未经授权禁止转载】,其中update就是一个动作,虽然我们【本文首发于唐霜的博客】【本文受版权保护】希望通过这个URI来实现用户ID为1的用【版权所有】唐霜 www.tangshuang.net【原创不易,请尊重版权】户进行信息更新,但是按照RESTful的本文版权归作者所有,未经授权不得转载。未经授权,禁止复制转载。规范,作为动作,应该用上面的PUT来表示原创内容,盗版必究。【版权所有】唐霜 www.tangshuang.net,所以请求更新用户信息,应该使用 PUT未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。 /user/1 来表示更新用户ID为1未经授权,禁止复制转载。原创内容,盗版必究。的用户信息。
转载请注明出处:www.tangshuang.net【未经授权禁止转载】如果去对应上面的请求模式,GET表示显示【访问 www.tangshuang.net 获取更多精彩内容】原创内容,盗版必究。、列出、展示,POST表示提交、创建,P转载请注明出处:www.tangshuang.net【转载请注明来源】UT表示更新,DELETE表示删除。
【版权所有,侵权必究】未经授权,禁止复制转载。【版权所有】唐霜 www.tangshuang.net本文作者:唐霜,转载请注明出处。<?php
$ch = curl_init();
$url = 'http://api.xxx.com/user';
$data = "name=姓名&email=xxx@xxx.com"; // 添加参数
curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); // 执行HTTP请求
curl_setopt($ch , CURLOPT_URL , $url);
$res = curl_exec($ch);
var_dump(json_decode($res));
?>
上面这段代码中$url仅仅是提供到了us【版权所有】唐霜 www.tangshuang.net【版权所有,侵权必究】er,而并没有提供add,服务端通过识别【访问 www.tangshuang.net 获取更多精彩内容】原创内容,盗版必究。POST请求来确定,这是一个创建用户的操本文版权归作者所有,未经授权不得转载。本文作者:唐霜,转载请注明出处。作。但是还有一些数据并没有用以处理数据,【版权所有】唐霜 www.tangshuang.net【版权所有,侵权必究】而是用以验证的,比如下文的鉴权,可以将这著作权归作者所有,禁止商业用途转载。未经授权,禁止复制转载。些信息通过header进行传输,下方详细【转载请注明来源】【版权所有】唐霜 www.tangshuang.net展示。
转载请注明出处:www.tangshuang.net转载请注明出处:www.tangshuang.net未经授权,禁止复制转载。4. 版本
API的开发直接关系了APP是否可以正常转载请注明出处:www.tangshuang.net未经授权,禁止复制转载。使用,如果原本运行正常的API,突然改动【版权所有】唐霜 www.tangshuang.net著作权归作者所有,禁止商业用途转载。,那么之前使用这个API的APP可能无法【原创内容,转载请注明出处】原创内容,盗版必究。正常运行。APP是不可能强迫用户主动升级原创内容,盗版必究。【版权所有,侵权必究】的,因此,通过API版本来解决这个问题。【转载请注明来源】【版权所有】唐霜 www.tangshuang.net也就是说,API的多个版本是同时运行的,本文作者:唐霜,转载请注明出处。原创内容,盗版必究。而且都要保证可以正常使用。
【转载请注明来源】【原创不易,请尊重版权】未经授权,禁止复制转载。按照RESTful的规范,不同的版本也应本文作者:唐霜,转载请注明出处。本文版权归作者所有,未经授权不得转载。该用相同的API URL,通过heade原创内容,盗版必究。未经授权,禁止复制转载。r信息来判断版本,再调用不同版本的程序进【转载请注明来源】【作者:唐霜】行处理。但是这明显会给开发带来巨大的成本【访问 www.tangshuang.net 获取更多精彩内容】转载请注明出处:www.tangshuang.net。解决办法有两种:1.新版本兼容旧版本,【本文首发于唐霜的博客】转载请注明出处:www.tangshuang.net所有旧版本的动作、字段、操作,都在新版本【转载请注明来源】著作权归作者所有,禁止商业用途转载。中可以被实现,但明显这样的维护成本很大;本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshuang.net2.不同的版本,用不同的URL来提供服务【本文受版权保护】【关注微信公众号:wwwtangshuangnet】,比如再URL中通过v1、v2来区分版本【转载请注明来源】未经授权,禁止复制转载。号,我则更喜欢采用子域名的方式,比如v2【版权所有】唐霜 www.tangshuang.net【版权所有,侵权必究】.api.xxx.com/user的方式【本文受版权保护】本文作者:唐霜,转载请注明出处。。
【原创不易,请尊重版权】原创内容,盗版必究。原创内容,盗版必究。【原创不易,请尊重版权】5. HTTP响应码
在用户发出请求,服务端对请求进行响应时,【版权所有,侵权必究】未经授权,禁止复制转载。给予正确的HTTP响应状态码,有利于让客【版权所有,侵权必究】【作者:唐霜】户端正确区分遇到的情况。
【版权所有】唐霜 www.tangshuang.net【本文受版权保护】【未经授权禁止转载】本文作者:唐霜,转载请注明出处。- 200 OK – [GET]【访问 www.tangshuang.net 获取更多精彩内容】本文作者:唐霜,转载请注明出处。:服务器成功返回用户请求的数据,该操作是未经授权,禁止复制转载。【作者:唐霜】幂等的(Idempotent)。 原创内容,盗版必究。【访问 www.tangshuang.net 获取更多精彩内容】未经授权,禁止复制转载。【原创不易,请尊重版权】
- 201 CREATED – 【关注微信公众号:wwwtangshuangnet】【版权所有】唐霜 www.tangshuang.net[POST/PUT/PATCH]:用户新【版权所有】唐霜 www.tangshuang.net未经授权,禁止复制转载。建或修改数据成功。 本文作者:唐霜,转载请注明出处。【关注微信公众号:wwwtangshuangnet】转载请注明出处:www.tangshuang.net
- 202 Accepted –【本文受版权保护】【版权所有】唐霜 www.tangshuang.net [*]:表示一个请求已经进入后台排队(【版权所有,侵权必究】著作权归作者所有,禁止商业用途转载。异步任务) 【原创内容,转载请注明出处】本文版权归作者所有,未经授权不得转载。转载请注明出处:www.tangshuang.net【原创不易,请尊重版权】
- 204 NO CONTENT ̵【关注微信公众号:wwwtangshuangnet】【本文受版权保护】1; [DELETE]:用户删除数据成功转载请注明出处:www.tangshuang.net【转载请注明来源】。 【原创内容,转载请注明出处】【版权所有,侵权必究】【本文受版权保护】【未经授权禁止转载】
- 400 INVALID REQUEST 【原创内容,转载请注明出处】【未经授权禁止转载】– [POST/PUT/PA【转载请注明来源】【转载请注明来源】TCH]:用户发出的请求有错误,服务器没原创内容,盗版必究。【未经授权禁止转载】有进行新建或修改数据的操作,该操作是幂等【访问 www.tangshuang.net 获取更多精彩内容】【原创不易,请尊重版权】的。 原创内容,盗版必究。【作者:唐霜】
- 401 Unauthorized 【版权所有】唐霜 www.tangshuang.net【原创不易,请尊重版权】211; [*]:表示用户没有权限(令牌转载请注明出处:www.tangshuang.net原创内容,盗版必究。、用户名、密码错误)。 【原创内容,转载请注明出处】转载请注明出处:www.tangshuang.net【版权所有,侵权必究】本文作者:唐霜,转载请注明出处。
- 403 Forbidden –本文作者:唐霜,转载请注明出处。【关注微信公众号:wwwtangshuangnet】; [*] 表示用户得到授权(与401错【未经授权禁止转载】【本文受版权保护】误相对),但是访问是被禁止的。 本文版权归作者所有,未经授权不得转载。【访问 www.tangshuang.net 获取更多精彩内容】
- 404 NOT FOUND –原创内容,盗版必究。未经授权,禁止复制转载。; [*]:用户发出的请求针对的是不存在本文版权归作者所有,未经授权不得转载。转载请注明出处:www.tangshuang.net的记录,服务器没有进行操作,该操作是幂等本文作者:唐霜,转载请注明出处。原创内容,盗版必究。的。 【未经授权禁止转载】【未经授权禁止转载】本文作者:唐霜,转载请注明出处。
- 406 Not Acceptable &本文版权归作者所有,未经授权不得转载。【本文首发于唐霜的博客】#8211; [GET]:用户请求的格式转载请注明出处:www.tangshuang.net著作权归作者所有,禁止商业用途转载。不可得(比如用户请求JSON格式,但是只【版权所有】唐霜 www.tangshuang.net原创内容,盗版必究。有XML格式)。 【本文受版权保护】【版权所有,侵权必究】
- 410 Gone -[GET]:用户请求【未经授权禁止转载】【作者:唐霜】的资源被永久删除,且不会再得到的。 【原创不易,请尊重版权】【本文首发于唐霜的博客】【版权所有,侵权必究】
- 422 Unprocesable ent原创内容,盗版必究。【版权所有,侵权必究】ity – [POST/PU本文作者:唐霜,转载请注明出处。【作者:唐霜】T/PATCH] 当创建一个对象时,发生本文版权归作者所有,未经授权不得转载。【原创不易,请尊重版权】一个验证错误。 【本文受版权保护】原创内容,盗版必究。
- 500 INTERNAL SERVER 原创内容,盗版必究。【未经授权禁止转载】ERROR – [*]:服务本文版权归作者所有,未经授权不得转载。本文作者:唐霜,转载请注明出处。器发生错误,用户将无法判断发出的请求是否【关注微信公众号:wwwtangshuangnet】转载请注明出处:www.tangshuang.net成功。 本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshuang.net
6. 返回值结构
在完成了上面的URL部署之后,接下来我们未经授权,禁止复制转载。原创内容,盗版必究。来看看返回结果应该怎么样来确定。我看到大本文作者:唐霜,转载请注明出处。【原创内容,转载请注明出处】部分文献中指出,最好使用JSON进行返回【版权所有】唐霜 www.tangshuang.net【版权所有】唐霜 www.tangshuang.net,而非xml。我认为原因可能有两点:1.未经授权,禁止复制转载。原创内容,盗版必究。 JSON可以很好的被很多程序支持,ja【访问 www.tangshuang.net 获取更多精彩内容】【本文首发于唐霜的博客】vascript的ajax可以直接将JS【本文受版权保护】本文版权归作者所有,未经授权不得转载。ON转换为对象。2. JSON的格式在容转载请注明出处:www.tangshuang.net未经授权,禁止复制转载。量上比xml小很多,可以减低宽带占用,提转载请注明出处:www.tangshuang.net转载请注明出处:www.tangshuang.net高传输效率。
【原创不易,请尊重版权】【访问 www.tangshuang.net 获取更多精彩内容】【原创不易,请尊重版权】本文版权归作者所有,未经授权不得转载。那么,返回值应该怎么去部署呢?
本文作者:唐霜,转载请注明出处。【原创内容,转载请注明出处】【版权所有】唐霜 www.tangshuang.net【本文受版权保护】首先,字段的合理返回,数据的包裹。因为返【本文首发于唐霜的博客】【原创不易,请尊重版权】回值中,我们常常要对数据进行区分分组,或转载请注明出处:www.tangshuang.net本文作者:唐霜,转载请注明出处。者按照从属关系打包,所以,我们再返回时,转载请注明出处:www.tangshuang.net【原创内容,转载请注明出处】最好有包裹的思想,把数据存放在不同的包裹【作者:唐霜】【访问 www.tangshuang.net 获取更多精彩内容】中进行返回。
【原创内容,转载请注明出处】【访问 www.tangshuang.net 获取更多精彩内容】本文版权归作者所有,未经授权不得转载。{
'error_code' : 0,
'data' : {
'user_id' : 1,
'username' : 'xiaomin'
},
'server_time': 14939939
}
上面返回的JSON中,使用data来作为本文版权归作者所有,未经授权不得转载。【原创不易,请尊重版权】数据包,将所有数据统一以这个字段进行包裹【原创内容,转载请注明出处】【关注微信公众号:wwwtangshuangnet】。除了data,也可以用list等其他形【版权所有】唐霜 www.tangshuang.net【作者:唐霜】式的包裹,命名都是自己来根据自己的需要确【本文受版权保护】【转载请注明来源】定的。
【未经授权禁止转载】【访问 www.tangshuang.net 获取更多精彩内容】【版权所有】唐霜 www.tangshuang.net【原创不易,请尊重版权】{
'error_code' : 0,
'list' : [
{'user_id':1,'username':'xiaoming'},
{'user_id':2,'username':'goudan'}
],
'server_time': 14939939
}
总之,不要不分包,直接把所有数据和一些你转载请注明出处:www.tangshuang.net【本文受版权保护】想返回的全局数据混在一起进行返回。
【原创不易,请尊重版权】本文作者:唐霜,转载请注明出处。【未经授权禁止转载】其次,错误码。错误码的作用是方便查找错误【版权所有】唐霜 www.tangshuang.net【关注微信公众号:wwwtangshuangnet】原因,通常情况下,我喜欢用error_c【版权所有】唐霜 www.tangshuang.net本文版权归作者所有,未经授权不得转载。ode来表示,当error_code=0转载请注明出处:www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】时,表示没有发生错误,当error_co【版权所有】唐霜 www.tangshuang.net【转载请注明来源】de>0时,发生了错误,并且提供较【本文首发于唐霜的博客】【本文受版权保护】为详细的文档,告诉客户端对应的error本文作者:唐霜,转载请注明出处。原创内容,盗版必究。_code值所产生的错误的原因和位置。
【作者:唐霜】原创内容,盗版必究。本文版权归作者所有,未经授权不得转载。未经授权,禁止复制转载。最后,空白压缩和字符转换。也就是返回的J【作者:唐霜】【原创不易,请尊重版权】SON结果不要换行和空格,用一行返回结果【访问 www.tangshuang.net 获取更多精彩内容】【访问 www.tangshuang.net 获取更多精彩内容】,使整个结果文本容量最小。同时,中文等字【关注微信公众号:wwwtangshuangnet】【作者:唐霜】符或结果中有引号,都进行字符转换,防止结【版权所有】唐霜 www.tangshuang.net【版权所有】唐霜 www.tangshuang.net果无法被正确识别。
转载请注明出处:www.tangshuang.net【关注微信公众号:wwwtangshuangnet】著作权归作者所有,禁止商业用途转载。本文版权归作者所有,未经授权不得转载。7. 鉴权
其实也就是客户端的权限控制。一般而言,我原创内容,盗版必究。【版权所有,侵权必究】会采用给客户端分发一个token来确定该【作者:唐霜】本文作者:唐霜,转载请注明出处。客户端的唯一身份。客户端在请求时,通过这原创内容,盗版必究。【本文受版权保护】个token,判断发出请求的客户端所对应本文版权归作者所有,未经授权不得转载。原创内容,盗版必究。的用户,及其相关信息和权限。
原创内容,盗版必究。【转载请注明来源】前文已经提到了,token信息不是用来进【版权所有】唐霜 www.tangshuang.net转载请注明出处:www.tangshuang.net行处理的数据,虽然可以通过POST、PU原创内容,盗版必究。【本文受版权保护】T等进行数据提交或传输,但是从RESTf转载请注明出处:www.tangshuang.net原创内容,盗版必究。ul规范来讲,它不属于操作数据,在服务端【原创不易,请尊重版权】本文作者:唐霜,转载请注明出处。进行处理时,仅是利用token进行鉴权处【本文受版权保护】【原创内容,转载请注明出处】理,所以,我的建议是通过header来发著作权归作者所有,禁止商业用途转载。本文作者:唐霜,转载请注明出处。送token。
【原创不易,请尊重版权】【访问 www.tangshuang.net 获取更多精彩内容】著作权归作者所有,禁止商业用途转载。<?php $ch = curl_init(); $url = 'http://api.xx.com/user'; $header = array( 'token: xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx', 'X-HTTP-Method-Override: PUT' ); $data = array( 'user_name' => 'xiaoming', 'user_email' => 'xx@sfa.com' ); // 添加apikey到header curl_setopt($ch, CURLOPT_HTTPHEADER, $header); curl_setopt($ch, CURLOPT_CUSTOMREQUEST, 'PUT'); curl_setopt($ch, CURLOPT_POSTFIELDS, $data); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); // 执行HTTP请求 curl_setopt($ch , CURLOPT_URL , $url); $res = curl_exec($ch); var_dump(json_decode($res)); ?>
上面的代码中,通过将CURLOPT_CU【版权所有,侵权必究】本文作者:唐霜,转载请注明出处。STOMREQUEST设置为PUT,就可【版权所有,侵权必究】本文作者:唐霜,转载请注明出处。以发出PUT请求,发出的PUT请求,仍然【作者:唐霜】转载请注明出处:www.tangshuang.net需要通过CURLOPT_POSTFIEL【本文受版权保护】本文版权归作者所有,未经授权不得转载。DS来传输数据。服务端接受PUT请求时,【关注微信公众号:wwwtangshuangnet】本文作者:唐霜,转载请注明出处。首先要对发出请求的客户端进行token验著作权归作者所有,禁止商业用途转载。【访问 www.tangshuang.net 获取更多精彩内容】证,通过对token的处理,查找到拥有该本文作者:唐霜,转载请注明出处。著作权归作者所有,禁止商业用途转载。token的实际用户,从而确定了将对哪一本文版权归作者所有,未经授权不得转载。本文作者:唐霜,转载请注明出处。个用户进行信息更新操作。
【作者:唐霜】著作权归作者所有,禁止商业用途转载。国内大部分API对PUT、DELETE请著作权归作者所有,禁止商业用途转载。【关注微信公众号:wwwtangshuangnet】求进行了阉割,更不用提HEAD、PACT【作者:唐霜】未经授权,禁止复制转载。H、OPTIONS请求。实际上,国内大部转载请注明出处:www.tangshuang.net【关注微信公众号:wwwtangshuangnet】分开放API仅支持GET和POST两种,【转载请注明来源】本文版权归作者所有,未经授权不得转载。部分API支持将app key信息通过h【本文首发于唐霜的博客】本文版权归作者所有,未经授权不得转载。eader进行发送。在面对这种情况下,我著作权归作者所有,禁止商业用途转载。本文作者:唐霜,转载请注明出处。们不得不抛弃标准的RESTful规范,在【版权所有】唐霜 www.tangshuang.net【本文受版权保护】url中加入get、add、update【本文首发于唐霜的博客】未经授权,禁止复制转载。、delete等动作词汇,以补充由于请求【版权所有,侵权必究】【本文首发于唐霜的博客】支持不完善带来的动作区分问题。如果仅支持【未经授权禁止转载】【版权所有】唐霜 www.tangshuang.netGET和POST,那么所有需要保密的数据转载请注明出处:www.tangshuang.net原创内容,盗版必究。,绝对不可以用GET来进行请求,而必须用转载请注明出处:www.tangshuang.net原创内容,盗版必究。POST。
本文作者:唐霜,转载请注明出处。【访问 www.tangshuang.net 获取更多精彩内容】【关注微信公众号:wwwtangshuangnet】【本文首发于唐霜的博客】参考文献:
《理解RESTful架构》《RESTful API 设计指南》
未经授权,禁止复制转载。【转载请注明来源】 【原创内容,转载请注明出处】未经授权,禁止复制转载。《我所理解的RESTful Web API本文版权归作者所有,未经授权不得转载。【版权所有,侵权必究】 [设计篇]》
【未经授权禁止转载】【原创内容,转载请注明出处】 著作权归作者所有,禁止商业用途转载。本文版权归作者所有,未经授权不得转载。【访问 www.tangshuang.net 获取更多精彩内容】2015-11-25 18361


