欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

新浪微博登录

程序员文章站 2022-07-12 13:28:15
...

     last modified:2013-10-08 13:38:41

     *********************************************

 

开发之前的准备:

开发应用的第一步是在这里申请AppKey,开放平台使用AppKey确定是哪个应用在请求API调用,所以请开发者申请了AppKey以后妥善保管AppKeyApp Secret(有了AppKey,我们就可以访问开放平台里的数据了)。 具体流程请参考:应用开发流程

 

 第三方登录流程:

 

         简单来说就是访问连接:

 

https://api.weibo.com/oauth2/authorize?client_id=YOUR_CLIENT_ID&response_type=code&redirect_uri=YOUR_REGISTERED_REDIRECT_URI

 

其中:client_id:你申请的appKey

 

           redirect_uri:你的回调url

 

以上是两个主要的参数,也可以带上state(用于验证),scope(确定授权的的范围,通常为all)等。

 

         访问以上连接后就会进入微博登录的引导页。在输入用户名和密码并登录成功后;浏览器就会重定向到你起初设定的redirect_uri,并携带一个参数,参数的namecode

 

         形如:http://www.xxx.com/loginBySina?code=xxxxxxxxxxxxxx

 

         获得了新浪返回的code值,我们就可以通过code获取AccessToken,通过AccessToken和新浪提供的接口,就可以访问该登录用户的信息了。

 

         流程图:http://www.sinaimg.cn/blog/developer/wiki/oAuth2_02.gif

 

         更多内容可以查看:

 http://open.weibo.com/wiki/%E6%8E%88%E6%9D%83%E6%9C%BA%E5%88%B6%E8%AF%B4%E6%98%8E

 

        

 

使用java SDK进行开发:

 

         各种版本的SDK下载:http://open.weibo.com/wiki/SDK

 

         我们选用java SDK完成一个简单的新浪微博第三方登录:

 

         1,下载java SDK,下载以后是一个java工程,我们可以打成一个jar以供我们的项目使用,下面有我提供的jar以供下载

 

         2,在项目的src目录下添加配置文件:config.properties

 

# sina weibo login configuration
# Last Modify : 2013-09-29 10:03:34
client_ID = xxxxxxxxx
client_SERCRET = xxxxxxxxxxxxxxxxxx
#下面填写你自己的回调URL
redirect_URI = http://www.xxxxx.com/login/loginBySinaWeibo.do

baseURL=https://api.weibo.com/2/
accessTokenURL=https://api.weibo.com/oauth2/access_token
authorizeURL=https://api.weibo.com/oauth2/authorize
rmURL=https://rm.api.weibo.com/2/

     3,获取code值:你可以在页面直接拼接相应的访问URL,也可以通过访问后台资源返回。

 

 

             A, 通过访问后台资源返回:当客户端发送微博登陆的请求(/sinaWeibo)时,后台处理代码:

 

        @RequestMapping(value = "/sinaWeibo")
	@ResponseBody
	public String sinaWeibo() {
		String authorizationUrl = "";
		try {
			authorizationUrl = new Oauth().authorize("code", null, "all");
		} catch (WeiboException e) {
			log.error("获取sina微博code值失败!exception:{}", e.getMessage());
			e.printStackTrace();
		}
		return authorizationUrl;
	}

       通过ajax发送请求,返回authorizationUrl(新浪的登录引导页的URL),以上使用的是springMVC

通过js打开authorizationUrl就能进入引导页面:

<script type="text/javascript">
		$(function(){
			$("#sinaWeiboLogin").click(function(){
				$.getJSON(
                               "${pageContext.request.contextPath}/login/sinaWeibo.do",
                                function(data){
				     window.location.href = data;
				});
			 });
		});
</script>

             B, 如果在页面直接拼接,只要符合这样的格式就可以:

   //请求

       https://api.weibo.com/oauth2/authorize?client_id=123050457758183&redirect_uri=http://www.example.com/response&response_type=code

 

//同意授权后会重定向

      http://www.example.com/response&code=CODE

 

4,获取AccessToken值:

 

         我的回调URI是:/login/loginBySinaWeibo.do;所以登录成功后会访问它。当访问该资源时,执行以下代码可以获取到AccessToken

 

Oauth oauth = new Oauth();
	AccessToken accessTokenObj = oauth.getAccessTokenByCode(code);
	String accessToken = accessTokenObj.getAccessToken();
	

      5,获取用户当前登录用户的信息:

 

 

        //A,获取当前用户的uid:
	Account am = new Account();
	am.client.setToken(accessToken);
	JSONObject uidObj = am.getUid();
	String uid = uidObj.getString("uid");

	//B,获取当前用户信息:
	Users um = new Users();
	um.client.setToken(accessToken);
	User weiboUser = um.showUserById(uid);

	//C,以上weiboUser封装了当前用户的用户信息,例如:
	String gender = weiboUser.getGender();//获取性别
	String avatarLarge = weiboUser.getavatarLarge();//获取新浪微博头像
	String screenName = weiboUser.getScreenName();//获取新浪微博的微博名称
	//具体可以看一下SDK中User的源码,里面有注释。

 

好了以上就可以获得用户在新浪的用户信息,一般用于web网站的快速注册功能,免去了用户重复填用户信息表单的时间,由web服务器自动从新浪微博服务器获取。

 

注意:

1,回调URL必须是你在新浪申请的网站域名下的URL,因为新浪对回调URL做了过滤,如果不是你在新浪开发者中申请的域名下的URL,新浪会提示URL匹配错误。

 

2,如果是在开发阶段,可以通过修改本地的hosts文件,将申请的域名指向本机就可以了。

Hosts文件中加一句:

 127.0.0.1  www.example.com 

这样该以后你的回调URL也得改一下:

www.example.com/(你的web工程名称)/login/loginBySinaWeibo.do

这样就不用将程序发布到线上也可以在本地测试了。

 

3,用户授权后出现applications over the unaudited use restrictions错误,原因:未审核应用只有应用创建者和测试用户能调用接口。

测试用户添加办法:

登录开发者帐号,点击进入 http://open.weibo.com/apps/308710000/info/advanced (308710000替换成你应用的AppKey),在底部添加测试用户即可,最多只能添加15位且添加后不能修改。注意:修改后约半小时左右时间生效

 

4,关于新浪提供的API大家可以参看javaSDK中的examples文件夹,里面的例子一看就明白了!