新浪微博开放平台深度历险


作者:蒋宇捷(hfahe)
版权声明:原创作品,欢迎转载,转载时请务必以超链接形式标明文章原始出处 、作者信息和本声明。
 
10月21日补充
解决Ajax跨域的方法
可通过新浪提供的JS SDK解决,详情参考http://open.t.sina.com.cn/wiki/index.php/JS-SDK,需要在服务器嵌入xd.html文件。
 
简介
         新浪微博开放平台的体系参考了Twitter,两者
摘要由CSDN通过智能技术生成

作者:蒋宇捷(hfahe)

版权声明:原创作品,欢迎转载,转载时请务必以超链接形式标明文章原始出处 、作者信息和本声明。

 

10月21日补充

解决Ajax跨域的方法

可通过新浪提供的JS SDK解决,详情参考http://open.t.sina.com.cn/wiki/index.php/JS-SDK,需要在服务器嵌入xd.html文件。

 

简介

         新浪微博开放平台的体系参考了Twitter,两者非常类似,包括接口、参数的定义,请求方式等等,如果熟悉TwitterAPI,基本可以同样的适用到新浪微博开放平台上,同时此文档技术部分的信息也可以同样适用于Twitter

         新浪微博开放平台的网站为http://open.t.sina.com.cn/,目前只部分页面对匿名用户开放。新浪微博开放平台的官方微博为http://t.sina.com.cn/openapi,可以在此申请API试用权限。

注册

         在开放平台登录后可以看到的界面如下所示:

 

         可以选择创建一个应用,需要设置应用名称、应用地址等。

         创建后可以在“我的应用”菜单里看到该应用和使用用户数,系统会为此应用分配一个APP KEYAPP SECRET,这两个字串非常重要,将会在以后认证或者信息交互时用到。

 

某应用的详细信息页面

         应用分为多个授权级别,分别为普通授权、中级授权、高级授权、合作伙伴授权,可以在http://open.t.sina.com.cn/wiki/index.php/Rate-limiting这里看到详细的权限信息。使用合作伙伴授权是没有请求限制的,而普通授权可能一不小心就会Server Limit了。

认证

         开放平台有两种认证方式,一种是Basic Auth,一种是OAuth

         1Basic AuthHTTP Auth

         Basic Auth简单点说明就是每次请求API时都提供用户的usernamepassword。例如:

curl -u user:password -d "source=10001&status=api test" http://api.t.sina.com.cn/update.xml

。这种方式优点和缺点都很明显。

         优点:

u  使用非常简单,

u  开发和调试工作简单,

u  没有复杂的页面跳转逻辑和交互过程;

u  更利于发起方控制;

         缺点:

u  安全性低,每次都需要传递用户名和密码,用户名和密码很大程度上存在被监听盗取的可能;

u  同时应用本地还需要保存用户名和密码,在应用本身的安全性来说,也存在很大问题;

u  开放平台服务商出于自身安全性的考虑(第三方可以得到该服务商用户的账号密码,对于服务商来说是一种安全隐患),未来也会限制此认证方式(Twitter就计划在6月份停止Basic Auth的支持)

u  用户如果更改了用户名和密码,还需要重新进行密码校验的过程。

         2OAuth

         OAuth为用户资源的授权提供了一个安全、开放的标准,将会是以后开发平台普遍遵守的,目前TwitterSina微博、豆瓣、Google等都提供对它的支持。它分为几个交互过程:

         1)应用用APP KEYAPP SECRET换取OAuth_token

         2)应用将用户引导到服务商的页面对该OAuth_token进行授权(可能需要输入用户名和密码);

         3)服务商的页面跳转回应用,应用再根据参数去服务商获得Access Token

         4)使用这个Access Token就可以访问API了。

         上述过程如下图所示:

 

    

OAuth认证过程

         OAuth的优点:

u  安全性高,用户的账户和密码只需要提供一次,而且是在服务商的页面上提供,防止了Basic Auth反复传输密码带来的安全隐患;

u  Access Token访问权限仅限于应用,被窃取不会影响用户在该服务商的其他服务;

u  Access Token即使被监听丢失了随时可以撤销,不像密码丢失可能就被别人篡改了;

u  用户修改了密码也不会影响该应用的正常使用。

         具体OAuth的分析详见这篇文章:

  • 0
    点赞
  • 49
    收藏
    觉得还不错? 一键收藏
  • 27
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 27
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值