OAuth2 登陆授权代码示例


现如今各大互联网公司都提供了自己的开放平台,这给第三方开发者提供了不少机会,这些平台为了让开发者访问平台内部被保护的特定资源,使用了OAuth2作为登陆授权协议,第三方应用需要获取accessToken才能访问特定资源。  
 
当用户访问第三方应用后,将会看到类似于下图的授权页面:



他被引导至认证服务器,访问了如下的链接:
https://oauth.taobao.com/authorize?response_type=code&client_id=100270989&redirect_uri=http://www.example.cn/demo/auth.do

其中client_id是appKey,创建应用时获得,redirect_uri指回调地址,一般指向第三方应用处理登陆授权请求功能的链接,response_type为code,表示通过授权码授权。

认证服务器生成授权码,将用户请求导向redirect_uri指向的地址,第三方应用收到请求后,作如下处理:

1、获取授权码     String code = request.getParameter("code");

2、通过授权码和其他参数,向平台获取accessToken
 
  List<NameValuePair> params = new ArrayList<NameValuePair>();

  params.add(new BasicNameValuePair("client_id", Constant.APP_KEY));

  params.add(new BasicNameValuePair("client_secret",				Constant.APP_SECRET));			

  params.add(new BasicNameValuePair("grant_type", "authorization_code"));

  params.add(new BasicNameValuePair("code", code));

  params.add(new BasicNameValuePair("redirect_uri",				"http://www.example.cn/demo/auth.do"));//这里redirect_uri与上面一致  

String content = HttpUtils.getPageContent(				"https://oauth.taobao.com/token", params);

  然后就可以解析content,获取accessToken及其他用户信息,只要accessToken未过期,而且第三方应用有相应的权限,后续都可以通过accessToken访问平台的其他api接口:   

   String accessToken = user.getAccessToken();

   List<NameValuePair> params = new ArrayList<NameValuePair>();

   params.add(new BasicNameValuePair("method", "user.otherinfo.get"));

   params.add(new BasicNameValuePair("v", "3.0"));

   params.add(new BasicNameValuePair("fields", "name,id,address"));

   params.add(new BasicNameValuePair("access_token", accessToken));

   params.add(new BasicNameValuePair("uid", uid));

   String content = HttpUtils.getPageContent(params);

深入理解,请看这篇:
http://www.ruanyifeng.com/blog/2014/05/oauth_2_0.html           

java达人

ID:java_daren

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值