码迷,mamicode.com
首页 > 微信 > 详细

微博登录、微信登录、qq登录java技术实现

时间:2016-10-05 01:08:33      阅读:574      评论:0      收藏:0      [点我收藏+]

标签:qq登录   java技术   开发者   public   第三方   

为了增加用户体验,用户能够快速的注册登录,第三方账号进行登录注册的的需求也就由此而诞生


技术分享


1、微信

 1) 微信登录也是最坑人的,需要花300大洋成为开发者账户,没办法谁让微信用户群体大呢所以也就只好认了;然后登录网站后台需要创建网站应用,填写授权回调域(登录网站的域名)只填写域名即可

申请地址: https://open.weixin.qq.com/cgi-bin/index?t=home/index&lang=zh_CN

 2)查看微信提供的接口,写java代码

	public void wx() {
		try {
			response.sendRedirect("https://open.weixin.qq.com/connect/qrconnect?appid="
					+ ShareLoginDict.WEIXINKEY.getState()
					+ "&redirect_uri="
					+ URLEncoder.encode(ShareLoginDict.WEIXINURL.getState()) 
					+ "&response_type=code&scope=snsapi_login&state=66666#wechat_redirect");
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}

@Override
	public Result userwx(String return_code) {
		Result result = new Result();
		Map<String, Object> token = (Map<String, Object>) WeiXinAPI
				.getToken(return_code);
		if (token != null && token.get("access_token") != null) {
			Map<String, Object> user = (Map<String, Object>) WeiXinAPI
					.getWxUser(token.get("access_token").toString(),
							token.get("openid").toString());
			if (user != null) {
				result.addModel("openid", user.get("openid"));
				result.addModel("nickname", user.get("nickname"));
				result.addModel("headimgurl", user.get("headimgurl"));
				result.addModel("data", "data_success");
			}else{
				result.addModel("data", "data_null");
			}
		}else{
			result.addModel("data", "data_null");
		}
		return result;
	}

当用户通过微信登录时,调用微信接口获取用户接口返回微信端的openid,昵称,头像;然后将此信息存入到浏览器的cookie中,当用户浏览其他信息时,辨别如果是用户是用微信登录的,拦截器直接从cookie中获取用户的信息显示昵称和头像,并同时判断该openid是否和数据库中用户做绑定,如果没有绑定提示用户注册。


2、qq登录

 1)qq互联创建应用

接入QQ登录前,网站需首先进行申请,获得对应的appid与appkey,以保证后续流程中可正确对网站与用户进行验证与授权。

申请appid和appkey的用途

 appid :应用的唯一标识。在OAuth2.0认证过程中,appid的值即为oauth_consumer_key的值。

appkey:appid对应的密钥,访问用户资源时用来验证应用的合法性。在OAuth2.0认证过程中,appkey的值即为oauth_consumer_secret的值。

申请地址: http://connect.qq.com/intro/login/

 2)查看QQ提供的接口,写java代码

public void qq() {
		try {
			response.sendRedirect("https://graph.qq.com/oauth2.0/authorize?response_type=code&client_id="
					+ ShareLoginDict.QQKEY.getState()
					+ "&redirect_uri="
					+ ShareLoginDict.QQURL.getState() + "&scope=get_user_info");
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}

@Override
	public Result userqq(String return_code) {
		Result result = new Result();
		Map<String, Object> token = (Map<String, Object>) QQAPI
				.getToken(return_code);
		if (token != null && token.get("access_token") != null) {
			Map<String, Object> tokenme = (Map<String, Object>) QQAPI
					.getTokenMeOpenId(token.get("access_token").toString());
			if (tokenme != null && tokenme.get("openid") != null) {
				Map<String, Object> user = (Map<String, Object>) QQAPI
						.getQqUser(token.get("access_token").toString(),
								tokenme.get("openid").toString());
				if (user != null) {
					result.addModel("openid", tokenme.get("openid"));
					result.addModel("nickname", user.get("nickname"));
					result.addModel("figureurl", user.get("figureurl"));
					result.addModel("data", "data_success");
				}else{
					result.addModel("data", "data_null");
				}
			}else{
				result.addModel("data", "data_null");
			}

		}else{
			result.addModel("data", "data_null");
		}
		return result;
	}	


当用户通过QQ登录时,调用QQ接口获取用户接口返回QQ端的openid,昵称,头像;然后将此信息存入到浏览器的cookie中,当用户浏览其他信息时,辨别如果是用户是用微信登录的,拦截器直接从cookie中获取用户的信息显示昵称和头像,并同时判断该openid是否和数据库中用户做绑定,如果没有绑定提示用户注册。

3 微博登录

 1)微博创建应用

  申请地址:http://open.weibo.com/authentication

 2)查看微博提供的接口,写java代码

  

public void wb() {
		try {
			response.sendRedirect("https://api.weibo.com/oauth2/authorize?client_id="
					+ ShareLoginDict.WEIBOKEY.getState()
					+ "&redirect_uri="
					+ ShareLoginDict.WEIBOURL.getState()
					+ "&response_type=code");
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}

@Override
	public Result userwb(String return_url, String return_code) {
		Result result = new Result();
		Map<String, Object> token = (Map<String, Object>) WeiBoAPI.getToken(
				return_url, return_code);
		if (token != null && token.get("access_token") != null) {
			Map<String, Object> user = (Map<String, Object>) WeiBoAPI
					.getWbUser(token.get("access_token").toString(),
							token.get("uid").toString());
			if (user != null) {
				result.addModel("name", user.get("screen_name"));
				result.addModel("pic", user.get("avatar_large"));
				result.addModel("idstr", user.get("idstr"));
				result.addModel("data", "data_success");
			}else{
				result.addModel("data", "data_null");
			}
		}else{
			result.addModel("data", "data_null");
		}
		return result;
	}

当用户通过微博登录时,调用微博接口获取用户接口返回微博端的idstr,昵称,头像;然后将此信息存入到浏览器的cookie中,当用户浏览其他信息时,辨别如果是用户是用微信登录的,拦截器直接从cookie中获取用户的信息显示昵称和头像,并同时判断该openid是否和数据库中用户做绑定,如果没有绑定提示用户注册。

本文出自 “精忠报国” 博客,谢绝转载!

微博登录、微信登录、qq登录java技术实现

标签:qq登录   java技术   开发者   public   第三方   

原文地址:http://xinsir.blog.51cto.com/5038915/1858721

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!