基于HTTPS的REST API设计初探

广告位招租
扫码页面底部二维码联系

在项目中,需要为APP撰写API。刚开始转载请注明出处:www.tangshuang.net著作权归作者所有,禁止商业用途转载。接触的时候,并没有考虑太多,就想提供UR【作者:唐霜】【关注微信公众号:wwwtangshuangnet】L,APP端通过该URL进行查询、创建、原创内容,盗版必究。【未经授权禁止转载】更新等操作即可。但再对相关规范进行了解后【本文首发于唐霜的博客】【本文首发于唐霜的博客】,才发现,API的设计并没有那么简单,远【原创不易,请尊重版权】本文作者:唐霜,转载请注明出处。远不是URL的问题,而是一个通信协议的整【版权所有】唐霜 www.tangshuang.net【本文首发于唐霜的博客】体架构。因此,我写这篇文章,用来记录自己转载请注明出处:www.tangshuang.net著作权归作者所有,禁止商业用途转载。的一些心得,并不断完善。并提供关于RES【版权所有,侵权必究】本文版权归作者所有,未经授权不得转载。Tful API的一些参考文献。

本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。【作者:唐霜】【原创内容,转载请注明出处】

1. 使用SSL(https)来提供UR本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshuang.netL

转载请注明出处:www.tangshuang.net【版权所有】唐霜 www.tangshuang.net【版权所有】唐霜 www.tangshuang.net【关注微信公众号:wwwtangshuangnet】

首先,使用https可以在数据包被抓取时【作者:唐霜】【版权所有】唐霜 www.tangshuang.net多一层加密。我们现在的APP使用环境大部【未经授权禁止转载】本文作者:唐霜,转载请注明出处。分都是在路由器WIFI环境下,一旦路由器【关注微信公众号:wwwtangshuangnet】【版权所有,侵权必究】被入侵,那么黑客可以非常容易的抓取到用户【未经授权禁止转载】未经授权,禁止复制转载。通过路由器传输的数据,如果使用http未【作者:唐霜】【本文受版权保护】经加密,那么黑客可以很轻松的获取用户的信转载请注明出处:www.tangshuang.net原创内容,盗版必究。息,甚至是账户信息。

【原创不易,请尊重版权】未经授权,禁止复制转载。【版权所有】唐霜 www.tangshuang.net【作者:唐霜】【原创内容,转载请注明出处】

其次,即使使用https,也要在API数本文作者:唐霜,转载请注明出处。【作者:唐霜】据传输设计时,正确的采用加密。例如直接将著作权归作者所有,禁止商业用途转载。【本文受版权保护】token信息放在URL中的做法,即使你本文版权归作者所有,未经授权不得转载。原创内容,盗版必究。使用了https,黑客抓不到你具体传输的原创内容,盗版必究。【转载请注明来源】数据,但是可以抓到你请求的URL啊!因此【原创内容,转载请注明出处】转载请注明出处:www.tangshuang.net,使用https进行请求时,要采用POS本文版权归作者所有,未经授权不得转载。未经授权,禁止复制转载。T、PUT或者HEAD的方式传输必要的数本文版权归作者所有,未经授权不得转载。【访问 www.tangshuang.net 获取更多精彩内容】据。

【原创内容,转载请注明出处】转载请注明出处:www.tangshuang.net原创内容,盗版必究。著作权归作者所有,禁止商业用途转载。

2. 使用GET、POST、PUT、DE【关注微信公众号:wwwtangshuangnet】著作权归作者所有,禁止商业用途转载。LETE、HEAD这几种请求模式

著作权归作者所有,禁止商业用途转载。【访问 www.tangshuang.net 获取更多精彩内容】本文作者:唐霜,转载请注明出处。

请求模式也可以说是动作、数据传输方式,通未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。常我们在web中的form有GET、PO【转载请注明来源】【原创内容,转载请注明出处】ST两种,而在HTTP中,存在下发这几种【转载请注明来源】本文作者:唐霜,转载请注明出处。

【作者:唐霜】著作权归作者所有,禁止商业用途转载。【转载请注明来源】【关注微信公众号:wwwtangshuangnet】
  • GET【未经授权禁止转载】 (选择):从服务器上获取一个具体的资源【访问 www.tangshuang.net 获取更多精彩内容】本文作者:唐霜,转载请注明出处。或者一个资源列表。
  • 本文版权归作者所有,未经授权不得转载。著作权归作者所有,禁止商业用途转载。【本文受版权保护】
  • POST【本文首发于唐霜的博客】 (创建): 在服务器上创建一个新的资源【版权所有,侵权必究】【转载请注明来源】
  • 本文作者:唐霜,转载请注明出处。本文版权归作者所有,未经授权不得转载。【未经授权禁止转载】本文作者:唐霜,转载请注明出处。【版权所有,侵权必究】
  • PUT【原创不易,请尊重版权】 (更新):以整体的方式更新服务器上的一本文版权归作者所有,未经授权不得转载。原创内容,盗版必究。个资源。
  • 【关注微信公众号:wwwtangshuangnet】转载请注明出处:www.tangshuang.net著作权归作者所有,禁止商业用途转载。本文作者:唐霜,转载请注明出处。原创内容,盗版必究。
  • PATCH (更新):只更新服务器上一个【未经授权禁止转载】【版权所有】唐霜 www.tangshuang.net资源的一个属性。
  • 著作权归作者所有,禁止商业用途转载。【本文受版权保护】【访问 www.tangshuang.net 获取更多精彩内容】【本文受版权保护】
  • DELETE本文作者:唐霜,转载请注明出处。 (删除):删除服务器上的一个资源。未经授权,禁止复制转载。
  • 【版权所有】唐霜 www.tangshuang.net著作权归作者所有,禁止商业用途转载。【本文首发于唐霜的博客】【未经授权禁止转载】
  • HEAD : 获取一个资源的元数据,如数【本文受版权保护】【本文受版权保护】据的哈希值或最后的更新时间。
  • 【本文受版权保护】【未经授权禁止转载】【访问 www.tangshuang.net 获取更多精彩内容】【作者:唐霜】
  • OPTIONS:获取客户端能对资源做什么本文作者:唐霜,转载请注明出处。本文版权归作者所有,未经授权不得转载。操作的信息。
  • 未经授权,禁止复制转载。【未经授权禁止转载】转载请注明出处:www.tangshuang.net【本文首发于唐霜的博客】

3. 在URI中体现资源,而非动作【原创内容,转载请注明出处】

本文作者:唐霜,转载请注明出处。【原创不易,请尊重版权】【版权所有】唐霜 www.tangshuang.net【本文首发于唐霜的博客】【关注微信公众号:wwwtangshuangnet】

阅读RESTful架构的参考文献之后,你原创内容,盗版必究。【版权所有】唐霜 www.tangshuang.net会了解什么是资源的概念,以及REST的确【版权所有】唐霜 www.tangshuang.net著作权归作者所有,禁止商业用途转载。切含义。再构建API的URL的时候,UR【版权所有】唐霜 www.tangshuang.net本文版权归作者所有,未经授权不得转载。I中应该仅包含资源(对象),而不要加入动【本文受版权保护】本文版权归作者所有,未经授权不得转载。作。比如 /user/1/update 【原创不易,请尊重版权】【原创不易,请尊重版权】,其中update就是一个动作,虽然我们转载请注明出处:www.tangshuang.net【本文受版权保护】希望通过这个URI来实现用户ID为1的用著作权归作者所有,禁止商业用途转载。本文作者:唐霜,转载请注明出处。户进行信息更新,但是按照RESTful的【原创内容,转载请注明出处】【版权所有,侵权必究】规范,作为动作,应该用上面的PUT来表示【本文受版权保护】本文版权归作者所有,未经授权不得转载。,所以请求更新用户信息,应该使用 PUT【关注微信公众号:wwwtangshuangnet】未经授权,禁止复制转载。 /user/1 来表示更新用户ID为1【关注微信公众号:wwwtangshuangnet】【原创不易,请尊重版权】的用户信息。

【版权所有,侵权必究】【原创内容,转载请注明出处】原创内容,盗版必究。本文版权归作者所有,未经授权不得转载。

如果去对应上面的请求模式,GET表示显示本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshuang.net、列出、展示,POST表示提交、创建,P【转载请注明来源】原创内容,盗版必究。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【关注微信公众号:wwwtangshuangnet】本文作者:唐霜,转载请注明出处。er,而并没有提供add,服务端通过识别本文版权归作者所有,未经授权不得转载。【原创内容,转载请注明出处】POST请求来确定,这是一个创建用户的操【本文受版权保护】转载请注明出处:www.tangshuang.net作。但是还有一些数据并没有用以处理数据,转载请注明出处:www.tangshuang.net本文作者:唐霜,转载请注明出处。而是用以验证的,比如下文的鉴权,可以将这原创内容,盗版必究。著作权归作者所有,禁止商业用途转载。些信息通过header进行传输,下方详细【版权所有】唐霜 www.tangshuang.net【版权所有】唐霜 www.tangshuang.net展示。

【版权所有】唐霜 www.tangshuang.net著作权归作者所有,禁止商业用途转载。本文版权归作者所有,未经授权不得转载。【原创内容,转载请注明出处】【版权所有,侵权必究】

4. 版本【作者:唐霜】

【原创内容,转载请注明出处】【作者:唐霜】著作权归作者所有,禁止商业用途转载。【关注微信公众号:wwwtangshuangnet】本文作者:唐霜,转载请注明出处。

API的开发直接关系了APP是否可以正常【原创不易,请尊重版权】【原创内容,转载请注明出处】使用,如果原本运行正常的API,突然改动【原创内容,转载请注明出处】【原创内容,转载请注明出处】,那么之前使用这个API的APP可能无法【未经授权禁止转载】原创内容,盗版必究。正常运行。APP是不可能强迫用户主动升级【版权所有】唐霜 www.tangshuang.net未经授权,禁止复制转载。的,因此,通过API版本来解决这个问题。转载请注明出处:www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】也就是说,API的多个版本是同时运行的,【版权所有】唐霜 www.tangshuang.net未经授权,禁止复制转载。而且都要保证可以正常使用。

转载请注明出处:www.tangshuang.net转载请注明出处:www.tangshuang.net【未经授权禁止转载】【转载请注明来源】原创内容,盗版必究。

按照RESTful的规范,不同的版本也应【版权所有,侵权必究】著作权归作者所有,禁止商业用途转载。该用相同的API URL,通过heade【版权所有】唐霜 www.tangshuang.net【未经授权禁止转载】r信息来判断版本,再调用不同版本的程序进【版权所有,侵权必究】本文作者:唐霜,转载请注明出处。行处理。但是这明显会给开发带来巨大的成本本文作者:唐霜,转载请注明出处。本文作者:唐霜,转载请注明出处。。解决办法有两种:1.新版本兼容旧版本,【原创内容,转载请注明出处】著作权归作者所有,禁止商业用途转载。所有旧版本的动作、字段、操作,都在新版本【本文首发于唐霜的博客】【本文受版权保护】中可以被实现,但明显这样的维护成本很大;【原创内容,转载请注明出处】【未经授权禁止转载】2.不同的版本,用不同的URL来提供服务本文作者:唐霜,转载请注明出处。原创内容,盗版必究。,比如再URL中通过v1、v2来区分版本未经授权,禁止复制转载。【本文受版权保护】号,我则更喜欢采用子域名的方式,比如v2未经授权,禁止复制转载。【本文首发于唐霜的博客】.api.xxx.com/user的方式原创内容,盗版必究。原创内容,盗版必究。

【原创不易,请尊重版权】未经授权,禁止复制转载。转载请注明出处:www.tangshuang.net【作者:唐霜】

5. HTTP响应码未经授权,禁止复制转载。

【版权所有】唐霜 www.tangshuang.net转载请注明出处:www.tangshuang.net【版权所有】唐霜 www.tangshuang.net

在用户发出请求,服务端对请求进行响应时,【关注微信公众号:wwwtangshuangnet】本文版权归作者所有,未经授权不得转载。给予正确的HTTP响应状态码,有利于让客本文作者:唐霜,转载请注明出处。本文作者:唐霜,转载请注明出处。户端正确区分遇到的情况。

著作权归作者所有,禁止商业用途转载。【作者:唐霜】【本文受版权保护】
  • 200 OK – [GET]【版权所有,侵权必究】著作权归作者所有,禁止商业用途转载。:服务器成功返回用户请求的数据,该操作是【版权所有,侵权必究】【版权所有,侵权必究】幂等的(Idempotent)。
  • 【原创不易,请尊重版权】原创内容,盗版必究。【关注微信公众号:wwwtangshuangnet】本文作者:唐霜,转载请注明出处。
  • 201 CREATED – 【版权所有,侵权必究】原创内容,盗版必究。[POST/PUT/PATCH]:用户新【访问 www.tangshuang.net 获取更多精彩内容】【转载请注明来源】建或修改数据成功。
  • 【访问 www.tangshuang.net 获取更多精彩内容】未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。著作权归作者所有,禁止商业用途转载。未经授权,禁止复制转载。
  • 202 Accepted –【原创不易,请尊重版权】【原创不易,请尊重版权】 [*]:表示一个请求已经进入后台排队(【本文首发于唐霜的博客】【转载请注明来源】异步任务)
  • 【本文受版权保护】本文作者:唐霜,转载请注明出处。【原创不易,请尊重版权】【作者:唐霜】【关注微信公众号:wwwtangshuangnet】
  • 204 NO CONTENT ̵【关注微信公众号:wwwtangshuangnet】【本文首发于唐霜的博客】1; [DELETE]:用户删除数据成功【作者:唐霜】【访问 www.tangshuang.net 获取更多精彩内容】
  • 【未经授权禁止转载】【本文首发于唐霜的博客】原创内容,盗版必究。
  • 400 INVALID REQUEST 【原创不易,请尊重版权】转载请注明出处:www.tangshuang.net– [POST/PUT/PA本文作者:唐霜,转载请注明出处。【转载请注明来源】TCH]:用户发出的请求有错误,服务器没【版权所有】唐霜 www.tangshuang.net未经授权,禁止复制转载。有进行新建或修改数据的操作,该操作是幂等【版权所有】唐霜 www.tangshuang.net转载请注明出处:www.tangshuang.net的。
  • 【访问 www.tangshuang.net 获取更多精彩内容】【作者:唐霜】本文作者:唐霜,转载请注明出处。原创内容,盗版必究。
  • 401 Unauthorized 未经授权,禁止复制转载。本文作者:唐霜,转载请注明出处。211; [*]:表示用户没有权限(令牌【版权所有】唐霜 www.tangshuang.net转载请注明出处:www.tangshuang.net、用户名、密码错误)。
  • 著作权归作者所有,禁止商业用途转载。转载请注明出处:www.tangshuang.net【未经授权禁止转载】
  • 403 Forbidden –【原创内容,转载请注明出处】原创内容,盗版必究。; [*] 表示用户得到授权(与401错【版权所有,侵权必究】【原创内容,转载请注明出处】误相对),但是访问是被禁止的。
  • 本文版权归作者所有,未经授权不得转载。【访问 www.tangshuang.net 获取更多精彩内容】著作权归作者所有,禁止商业用途转载。【本文受版权保护】
  • 404 NOT FOUND –原创内容,盗版必究。本文版权归作者所有,未经授权不得转载。; [*]:用户发出的请求针对的是不存在【转载请注明来源】【原创内容,转载请注明出处】的记录,服务器没有进行操作,该操作是幂等著作权归作者所有,禁止商业用途转载。【版权所有,侵权必究】的。
  • 【本文受版权保护】【原创内容,转载请注明出处】【关注微信公众号:wwwtangshuangnet】原创内容,盗版必究。
  • 406 Not Acceptable &本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshuang.net#8211; [GET]:用户请求的格式原创内容,盗版必究。著作权归作者所有,禁止商业用途转载。不可得(比如用户请求JSON格式,但是只本文作者:唐霜,转载请注明出处。【作者:唐霜】有XML格式)。
  • 未经授权,禁止复制转载。转载请注明出处:www.tangshuang.net【原创内容,转载请注明出处】【未经授权禁止转载】
  • 410 Gone -[GET]:用户请求未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。的资源被永久删除,且不会再得到的。
  • 【本文受版权保护】【原创内容,转载请注明出处】【原创不易,请尊重版权】【关注微信公众号:wwwtangshuangnet】转载请注明出处:www.tangshuang.net
  • 422 Unprocesable ent【原创不易,请尊重版权】本文版权归作者所有,未经授权不得转载。ity – [POST/PU未经授权,禁止复制转载。【未经授权禁止转载】T/PATCH] 当创建一个对象时,发生【版权所有,侵权必究】著作权归作者所有,禁止商业用途转载。一个验证错误。
  • 本文作者:唐霜,转载请注明出处。【原创内容,转载请注明出处】著作权归作者所有,禁止商业用途转载。
  • 500 INTERNAL SERVER 原创内容,盗版必究。著作权归作者所有,禁止商业用途转载。ERROR – [*]:服务原创内容,盗版必究。本文作者:唐霜,转载请注明出处。器发生错误,用户将无法判断发出的请求是否【原创不易,请尊重版权】本文版权归作者所有,未经授权不得转载。成功。
  • 【本文首发于唐霜的博客】著作权归作者所有,禁止商业用途转载。【本文受版权保护】

6. 返回值结构【关注微信公众号:wwwtangshuangnet】

【转载请注明来源】【未经授权禁止转载】【本文受版权保护】

在完成了上面的URL部署之后,接下来我们【本文受版权保护】【作者:唐霜】来看看返回结果应该怎么样来确定。我看到大转载请注明出处:www.tangshuang.net原创内容,盗版必究。部分文献中指出,最好使用JSON进行返回著作权归作者所有,禁止商业用途转载。【转载请注明来源】,而非xml。我认为原因可能有两点:1.转载请注明出处:www.tangshuang.net【原创内容,转载请注明出处】 JSON可以很好的被很多程序支持,ja【原创不易,请尊重版权】【本文受版权保护】vascript的ajax可以直接将JS【版权所有】唐霜 www.tangshuang.net著作权归作者所有,禁止商业用途转载。ON转换为对象。2. JSON的格式在容著作权归作者所有,禁止商业用途转载。原创内容,盗版必究。量上比xml小很多,可以减低宽带占用,提原创内容,盗版必究。【作者:唐霜】高传输效率。

未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。【访问 www.tangshuang.net 获取更多精彩内容】【转载请注明来源】

那么,返回值应该怎么去部署呢?【版权所有,侵权必究】

本文版权归作者所有,未经授权不得转载。【作者:唐霜】【未经授权禁止转载】未经授权,禁止复制转载。【作者:唐霜】

首先,字段的合理返回,数据的包裹。因为返【访问 www.tangshuang.net 获取更多精彩内容】【版权所有】唐霜 www.tangshuang.net回值中,我们常常要对数据进行区分分组,或转载请注明出处:www.tangshuang.net本文版权归作者所有,未经授权不得转载。者按照从属关系打包,所以,我们再返回时,【版权所有,侵权必究】【版权所有,侵权必究】最好有包裹的思想,把数据存放在不同的包裹【原创不易,请尊重版权】【关注微信公众号:wwwtangshuangnet】中进行返回。

【关注微信公众号:wwwtangshuangnet】【本文首发于唐霜的博客】【本文受版权保护】转载请注明出处:www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】
{
  'error_code' : 0,
  'data' : {
    'user_id' : 1,
    'username' : 'xiaomin'
  },
  'server_time': 14939939
}

上面返回的JSON中,使用data来作为转载请注明出处:www.tangshuang.net著作权归作者所有,禁止商业用途转载。数据包,将所有数据统一以这个字段进行包裹著作权归作者所有,禁止商业用途转载。【本文受版权保护】。除了data,也可以用list等其他形【版权所有】唐霜 www.tangshuang.net原创内容,盗版必究。式的包裹,命名都是自己来根据自己的需要确著作权归作者所有,禁止商业用途转载。【未经授权禁止转载】定的。

转载请注明出处:www.tangshuang.net转载请注明出处: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想返回的全局数据混在一起进行返回。

本文版权归作者所有,未经授权不得转载。【版权所有,侵权必究】本文版权归作者所有,未经授权不得转载。本文作者:唐霜,转载请注明出处。原创内容,盗版必究。

其次,错误码。错误码的作用是方便查找错误【本文首发于唐霜的博客】【转载请注明来源】原因,通常情况下,我喜欢用error_c本文作者:唐霜,转载请注明出处。未经授权,禁止复制转载。ode来表示,当error_code=0转载请注明出处:www.tangshuang.net【原创内容,转载请注明出处】时,表示没有发生错误,当error_co【未经授权禁止转载】转载请注明出处:www.tangshuang.netde>0时,发生了错误,并且提供较原创内容,盗版必究。【原创不易,请尊重版权】为详细的文档,告诉客户端对应的error未经授权,禁止复制转载。转载请注明出处:www.tangshuang.net_code值所产生的错误的原因和位置。

未经授权,禁止复制转载。【本文首发于唐霜的博客】本文版权归作者所有,未经授权不得转载。转载请注明出处:www.tangshuang.net

最后,空白压缩和字符转换。也就是返回的J本文版权归作者所有,未经授权不得转载。【访问 www.tangshuang.net 获取更多精彩内容】SON结果不要换行和空格,用一行返回结果【作者:唐霜】【本文受版权保护】,使整个结果文本容量最小。同时,中文等字【版权所有,侵权必究】【本文受版权保护】符或结果中有引号,都进行字符转换,防止结本文版权归作者所有,未经授权不得转载。转载请注明出处:www.tangshuang.net果无法被正确识别。

转载请注明出处:www.tangshuang.net原创内容,盗版必究。【原创不易,请尊重版权】

7. 鉴权【未经授权禁止转载】

原创内容,盗版必究。【未经授权禁止转载】【访问 www.tangshuang.net 获取更多精彩内容】【版权所有】唐霜 www.tangshuang.net

其实也就是客户端的权限控制。一般而言,我原创内容,盗版必究。【访问 www.tangshuang.net 获取更多精彩内容】会采用给客户端分发一个token来确定该未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。客户端的唯一身份。客户端在请求时,通过这【本文受版权保护】【本文受版权保护】个token,判断发出请求的客户端所对应【访问 www.tangshuang.net 获取更多精彩内容】【本文受版权保护】的用户,及其相关信息和权限。

【未经授权禁止转载】转载请注明出处:www.tangshuang.net著作权归作者所有,禁止商业用途转载。【本文首发于唐霜的博客】

前文已经提到了,token信息不是用来进【关注微信公众号:wwwtangshuangnet】未经授权,禁止复制转载。行处理的数据,虽然可以通过POST、PU【版权所有,侵权必究】转载请注明出处:www.tangshuang.netT等进行数据提交或传输,但是从RESTf【版权所有,侵权必究】【本文首发于唐霜的博客】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【版权所有,侵权必究】【关注微信公众号:wwwtangshuangnet】STOMREQUEST设置为PUT,就可原创内容,盗版必究。【版权所有,侵权必究】以发出PUT请求,发出的PUT请求,仍然本文版权归作者所有,未经授权不得转载。【未经授权禁止转载】需要通过CURLOPT_POSTFIEL【转载请注明来源】本文作者:唐霜,转载请注明出处。DS来传输数据。服务端接受PUT请求时,著作权归作者所有,禁止商业用途转载。【关注微信公众号:wwwtangshuangnet】首先要对发出请求的客户端进行token验【关注微信公众号:wwwtangshuangnet】【版权所有】唐霜 www.tangshuang.net证,通过对token的处理,查找到拥有该【访问 www.tangshuang.net 获取更多精彩内容】未经授权,禁止复制转载。token的实际用户,从而确定了将对哪一转载请注明出处:www.tangshuang.net【作者:唐霜】个用户进行信息更新操作。

未经授权,禁止复制转载。【版权所有】唐霜 www.tangshuang.net【转载请注明来源】著作权归作者所有,禁止商业用途转载。

国内大部分API对PUT、DELETE请【本文首发于唐霜的博客】【关注微信公众号:wwwtangshuangnet】求进行了阉割,更不用提HEAD、PACT【版权所有,侵权必究】著作权归作者所有,禁止商业用途转载。H、OPTIONS请求。实际上,国内大部【原创内容,转载请注明出处】【版权所有,侵权必究】分开放API仅支持GET和POST两种,【访问 www.tangshuang.net 获取更多精彩内容】【原创内容,转载请注明出处】部分API支持将app key信息通过h【转载请注明来源】【原创不易,请尊重版权】eader进行发送。在面对这种情况下,我著作权归作者所有,禁止商业用途转载。转载请注明出处:www.tangshuang.net们不得不抛弃标准的RESTful规范,在【转载请注明来源】本文作者:唐霜,转载请注明出处。url中加入get、add、update本文作者:唐霜,转载请注明出处。【关注微信公众号:wwwtangshuangnet】、delete等动作词汇,以补充由于请求【本文首发于唐霜的博客】原创内容,盗版必究。支持不完善带来的动作区分问题。如果仅支持转载请注明出处:www.tangshuang.net未经授权,禁止复制转载。GET和POST,那么所有需要保密的数据【版权所有,侵权必究】【原创不易,请尊重版权】,绝对不可以用GET来进行请求,而必须用【版权所有】唐霜 www.tangshuang.net著作权归作者所有,禁止商业用途转载。POST。

【版权所有,侵权必究】原创内容,盗版必究。【本文受版权保护】【作者:唐霜】

参考文献:【版权所有】唐霜 www.tangshuang.net

【转载请注明来源】【本文首发于唐霜的博客】【版权所有,侵权必究】

【访问 www.tangshuang.net 获取更多精彩内容】理解RESTful架构【本文受版权保护】》《本文版权归作者所有,未经授权不得转载。RESTful API 设计指南【未经授权禁止转载】【未经授权禁止转载】

未经授权,禁止复制转载。【原创不易,请尊重版权】原创内容,盗版必究。【转载请注明来源】原创内容,盗版必究。

【本文首发于唐霜的博客】好RESTful API的设计原则【本文首发于唐霜的博客】本文版权归作者所有,未经授权不得转载。

本文作者:唐霜,转载请注明出处。【原创内容,转载请注明出处】【版权所有,侵权必究】原创内容,盗版必究。【关注微信公众号:wwwtangshuangnet】

著作权归作者所有,禁止商业用途转载。我所理解的RESTful Web API【本文受版权保护】本文作者:唐霜,转载请注明出处。 [设计篇]转载请注明出处:www.tangshuang.net

【版权所有】唐霜 www.tangshuang.net未经授权,禁止复制转载。著作权归作者所有,禁止商业用途转载。【关注微信公众号:wwwtangshuangnet】本文版权归作者所有,未经授权不得转载。

本文版权归作者所有,未经授权不得转载。https工作原理转载请注明出处:www.tangshuang.net【作者:唐霜】

未经授权,禁止复制转载。原创内容,盗版必究。【本文首发于唐霜的博客】著作权归作者所有,禁止商业用途转载。本文作者:唐霜,转载请注明出处。

2015-11-25 18021

为价值买单,打赏一杯咖啡

本文价值180.21RMB