开发者社区> 技术小甜> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

关于接入新浪微博第三方登录

简介:
+关注继续查看

 近期,做一个关于联合第三方平台的登录接入,初次接触开放平台,在此做个笔记

  开发之前的准备如下:

  1、注册新浪微博

  2、访问新浪微博开发平台http://open.weibo.com,如果是企业,申请企业接入,并提交相关资料进行审核;如果是个人开发者,就请申请个人开发者应用,一下以开发者为例

  3、使用新浪微博的开放API,就需要跟新浪申请一个appkey和App Secret,这个是入口,必须获取到这两个才能进行接下来的接入工作

  4、进入http://open.weibo.com完善个人信息之后,必须还要做完身份认证审核,审核完成之后,新浪开放平台就会给出appkey和App Secret

  5、接下来就是如何使用appkey和App Secret了,需要去下载开放平台中文档或者是demo代码,其实提供的文档基本都是技术文档,很多东西没有讲清楚,对于初次接触的人,还是会遇到很多麻烦

  6、新浪开放平台提供了很多不同开发语言的sdk,这里我选择java sdk,下载一个(包含新版接口及OAuth2.0)的zip文件,解压之后可以直接import到eclipse中去,结构如下,包括weibo4j源代码和example代   码

  

  这里有一个config配置文件,打开如下:

  

  之前我们申请的appkey和App Secret就派上用场了,这里的client_ID就是appkey,client_SERCRET就是App Secret,把相应的内容填上去,另外redirect_URI这就是回调地址,

  点击“第三方”——》跳转微博登陆——》登录ok,授权——》回调自己的应用,这里就是回调地址的意思了。

  7、开始去运行测试程序,测试程序在example下,包weibo4j.examples.oauth2下的类OAuth4Code,这里我们需要做一些修改,修改程序中的

  oauth.authorize("code",args[0],args[1]),将这段改成oauth.authorize("code","","all"),至于为什么这么改,这里请阅读接口文档oauth.authorize的使用说明

  假设这里我们还没有回调地址,配置文件中的redirect_URI为空,运行之后,他会自动打开浏览器运行测试,显示如下:

  

  此时的URL地址为:https://api.weibo.com/oauth2/authorize?client_id=3613929600&redirect_uri=&response_type=code&state=&scope=all

  这里说明我的appkey和App Secret是有效的,这里由于我们没有创建正式的应用,新浪无法识别我的来源

  8、在开放平台上创建应用,如下图所示

  

  这里有三类应用,网站接入、站内应用、移动应用,如果是企业行为,有公开的域名可以访问,并且应用程序是通过域名进行访问,这里任何一种方式都可以用,但如果我们只是简单开发者,没有公用域名,比如是内  部局域网模式,ip为内网地址192.168.1.*开头,本地127.0.0.1之类的,这里就只能选择创建站内应用,填写如下

  

  这里红色框标记的地方就是回调地址,如果我没有公网ip和域名,局域网玩玩就这么填写就ok了,不过这里不能用localhost代替127.0.0.1,这里按照配置要求完成,这个配置里面的要求是很严谨的,

  特别是下面的几个应用图标,总之比较麻烦,这里结束了之后,就可以提交审核了。

  9、提交审核之后,第一次大约1天时间,新浪开放平台就会发邮件到你的邮箱,告知你审核结果,不过这里审核结果失败与否没有关系,关键就是要提交审核,没有审核成功,这里照常可以用

  

  10、完成测试工程中的配置文件redirect_URI,这里必须与创建应用时填写的【应用实际地址】保持一致,这就是回调地址!完成配置之后,再次运行OAuth4Code.java,如图所示

  

  这里就跳转到新浪微博的登录页面,登录新浪微博的账户之后,就需要点击授权,表示你的微博帐号相关内容可以被接入的平台分享你的信息等等,授权结束之后,

  会返回一个code,这个code非常重要,就是我们整个接入第三方平台的开门钥匙,有这个code之后,我们就可以获取用户的access_token,UID等内容,就相当于整个接入过程打通了,

  11、调用新浪微博的开放API

  这里就需要研读这些API了,从而满足接入要实现的需求了,首先要熟悉的就是OAuth 2.0授权接口,http://open.weibo.com上都可以查,如下:

  

  12、通过一个Servlet程序调用开放API获取新浪微博的UID、微博名称示例  

复制代码
response.setContentType("text/html;charset=UTF-8");
        String accessToken = null ;
        String uid = null ;
        String screenName = null ;        
        String username = null ;
        AccessToken accessTokenObj = null ;
        Oauth oauth2 = new Oauth();
        try {
            out = response.getWriter();
            accessTokenObj = oauth2.getAccessTokenByCode(code) ;
            logger.info(accessTokenObj);
            accessToken = accessTokenObj.getAccessToken() ;
            oauth2.setToken(accessToken) ;
            Account account = new Account() ;
            account.client.setToken(accessToken) ;
            JSONObject uidJson = account.getUid() ;
            uid = uidJson.getString("uid") ;
            
            Users users = new Users() ;
            users.client.setToken(accessToken) ;
            User weiboUser = users.showUserById(uid) ;
            username = weiboUser.getName() ;
            screenName = weiboUser.getScreenName() ;
            
            
        } catch (WeiboException | IOException | JSONException e) {
            e.printStackTrace();
        }
        out.println("微博访问Token_Info:" + accessTokenObj + "\t");
        out.println("微博访问Token:" + accessToken + "\t");
        out.println("微博用户-Uid:" + uid + "\t");
        out.println("微博用户-名称:" + screenName + "\t");
        out.flush();
        out.close();*/
复制代码

 










本文转自一米一阳光博客园博客,原文链接:  http://www.cnblogs.com/candle806/p/3600956.html  ,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
应用速递 | 可接入天猫精灵的多功能无线按钮
应用速递是面向IoT厂商推荐芯片开放社区(OCC)上的典型应用案例,便于IoT厂商精准获取方案,快速实现产品落地。
75 0
应用速递 | 可接入天猫精灵的多功能无线按钮
该方案可实现无线门铃、一键通话、播放音乐、控制智能家电、执行天猫精灵组合命令等多种功能。
244 0
【微信】第三方登录接口流程
微信登录介绍: 微信OAuth2.0授权登录让微信用户使用微信身份安全登录第三方应用或网站,在微信用户授权登录已接入微信OAuth2.0的第三方应用后,第三方可以获取到用户的接口调用凭证(access_token),通过access_token可以进行微信开放平台授权关系接口调用,从而可实现获取微信用户基本开放信息和帮助用户实现基础开放功能等。
3204 0
[PHP] Laravel 5.1 实现第三方登录认证
Socialite Laravel 提供了简单易用的方式,使用 Laravel Socialite 进行OAuth认证(支持OAuth1 和 OAuth2)。 Socialite 目前支持的认证有 Facebook、Google、GitLab、Bitbucket、微信、QQ、微博等。 Soci
8141 0
定向爬虫 - Python模拟新浪微博登录
当我们试图从新浪微博抓取数据时,我们会发现网页上提示未登录,无法查看其他用户的信息。 模拟登录是定向爬虫制作中一个必须克服的问题,只有这样才能爬取到更多的内容。 实现微博登录的方法有很多,一般我们在模拟登录时首选WAP版。
1552 0
微信的平台黏性远大于直达号 第三方开发者依旧会选择微信公众平台
  “再小的个体,也有自己的品牌”微信公众号走的是粉丝为王的路线,而直达号的slogan“随时随地 直达所需”与微信公众号相比显得更加直接粗暴。    众所周知,腾讯成于社交,百度成于搜索;腾讯的付费用户大多数是个人,而百度针对更多的是企业。
1252 0
+关注
10136
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载