java实现支付宝第三方登录_Java 实现QQ第三方登录(附赠:完整代码)

老铁,转发+关注+私信 获取完整代码

前言:很多时候我们都需要如下的第三方登录,用QQ帐号快速登录你的网站,降低注册门槛,为你的网站带来海量新用户。

9addbae9ade0c366a4f0da3fab0bfd33.gif

下面让我们来实现吧,可以参考官网文档,也可以看我下面的操作说明 QQ第三方登录接入指南

开发者通过以下几个步骤,即可接入QQ互联开放平台: 注册开发者→创建应用→通过审核并获取接口权限

第一步:注册成为开发者 http://open.qq.com/regv2/

903419df2eebc61066454a3fe2a9b401.png
fee7d954ebc75ccee3dc8af646457bb5.png

最后等待审核通过... (我是上午申请的,下午才通过审核,这段时间可以先了解下文档,熟悉熟悉哦~)

f7455728cd4547a302cea0d62feb112e.png
020bb65640ac176b795c1f8be4eb9457.png

第二步:创建应用 https://connect.qq.com/manage.html#/

这里我选的是网站应用

4688b6d29491c427431760c8875b700f.png
be360a10214efcb16240ebea6f766ff8.png

下面是填写时需要注意的!! (温馨小提示:回调地址是之后会使用到的哦~)

33ad9a2f06bce77515a2308ed49b44cf.png

等待审核通过之后就可以进行下一步操作了哦~ (温馨小提示:APP ID和APP Key是之后要使用到的哦!)

66ea44efa26a337344dd8a1f2a80a675.png

如下全部审核通过 (快的话 一会儿就通过了哦)

a15931fc25b77124aaac5d0f1d5a2a51.png

注意:申请appid时,登录的QQ号码将与申请到的appid绑定,后续维护均需要使用该号码。

注意:对appid和appkey信息进行保密,不要随意泄漏。

注意保证连接畅通

接入QQ登录时,网站需要不停的和Qzone进行交互,发送请求和接受响应。

1. 对于PC网站:

请在你的服务器上ping graph.qq.com ,保证连接畅通。

2.移动应用无需此步骤

第三步:可下载官网sdk参考 http://wiki.open.qq.com/wiki/website/SDK%E4%B8%8B%E8%BD%BD

(当然也可跳过这步看我下面的实现)

2880737a642fb75a3e7a8756bdccff50.png

第四步:配置

b52241c8b07d4ac0e976131989a55013.png

①拷贝下载的sdk后解压包中的qqconnectconfig.properties配置文件到自己的项目中,也可以直接拷我下面分享的

app_ID = 100****(请修改此处)app_KEY = ******(请修改此处)redirect_URI = ***********(请修改此处)scope = get_user_info,add_topic,add_one_blog,add_album,upload_pic,list_album,add_share,check_page_fans,add_t,add_pic_t,del_t,get_repost_list,get_info,get_other_info,get_fanslist,get_idollist,add_idol,del_ido,get_tenpay_addrbaseURL = https://graph.qq.com/getUserInfoURL = https://graph.qq.com/user/get_user_infoaccessTokenURL = https://graph.qq.com/oauth2.0/tokenauthorizeURL = https://graph.qq.com/oauth2.0/authorizegetOpenIDURL = https://graph.qq.com/oauth2.0/meaddTopicURL = https://graph.qq.com/shuoshuo/add_topicaddBlogURL = https://graph.qq.com/blog/add_one_blogaddAlbumURL = https://graph.qq.com/photo/add_albumuploadPicURL = https://graph.qq.com/photo/upload_piclistAlbumURL = https://graph.qq.com/photo/list_albumaddShareURL = https://graph.qq.com/share/add_sharecheckPageFansURL = https://graph.qq.com/user/check_page_fansaddTURL = https://graph.qq.com/t/add_taddPicTURL = https://graph.qq.com/t/add_pic_tdelTURL = https://graph.qq.com/t/del_tgetWeiboUserInfoURL = https://graph.qq.com/user/get_infogetWeiboOtherUserInfoURL = https://graph.qq.com/user/get_other_infogetFansListURL = https://graph.qq.com/relation/get_fanslistgetIdolsListURL = https://graph.qq.com/relation/get_idollistaddIdolURL = https://graph.qq.com/relation/add_idoldelIdolURL = https://graph.qq.com/relation/del_idolgetTenpayAddrURL = https://graph.qq.com/cft_info/get_tenpay_addrgetRepostListURL = https://graph.qq.com/t/get_repost_listversion = 2.0.0.0

②将app_ID,app_KEY,redirect_URI三个参数的值改成自己的,也就是在注册开发者用户和创建应用通过后返回的参数值,其中redirect_URI是授权成功后的回调地址,这个是在创建应用的时候配置的。

3b173c1c434a557ca48e0dcb00647cd1.png

第五步:代码实现

①引入所需依赖包(maven项目的引入方式):【温馨小提示:下载的sdk资源中也有Sdk4J.jar

7d3ebc534c5079ce71f30e54a9c275a7.png

 net.gplatform Sdk4J 2.0

②编写登录时跳转事件

 @RequestMapping(value = "/qqLogin") public void qqLogin(HttpServletRequest request, HttpServletResponse response) throws Exception { response.setContentType("text/html;charset=utf-8"); try { response.sendRedirect(new Oauth().getAuthorizeURL(request));//将页面重定向到qq第三方的登录页面 } catch (QQConnectException e) { e.printStackTrace(); } }

这个代码可让我们在前台设置跳转路径,点击QQ登录时跳转到如下我们熟悉的页面

fb1cd0ce545ce63efd0c1e56100486fc.png

③编写回调controller,用户在第三方登录页面登录成功后,我们可以进行登录信息获取,这个时候页面会自动跳转到我们上面配置的redirect_URI的地址

//获取登录者的基础信息@RequestMapping("/afterlogin.do")public void QQAfterlogin(HttpServletRequest request, HttpServletResponse response) throws Exception { System.out.println("AfterLogin======================================================="); response.setContentType("text/html; charset=utf-8"); // 响应编码 PrintWriter out = response.getWriter();  Enumeration parameterNames = request.getParameterNames(); while(parameterNames.hasMoreElements()){ String parameterName = parameterNames.nextElement();//code System.out.println(parameterName+":"+request.getParameter(parameterName));//state } System.out.println("qq_connect_state:"+request.getSession().getAttribute("qq_connect_state"));  try { // 获取AccessToken(AccessToken用于获取OppendID) AccessToken accessTokenObj = (new Oauth()).getAccessTokenByRequest(request);  System.out.println("accessTokenObj:"+accessTokenObj); // 用于接收AccessToken String accessToken = null, openID = null; long tokenExpireIn = 0L; // AccessToken有效时长  if (accessTokenObj.getAccessToken().equals("")) { // 我们的网站被CSRF攻击了或者用户取消了授权 // 做一些数据统计工作 System.out.print("没有获取到响应参数"); } else { accessToken = accessTokenObj.getAccessToken(); // 获取AccessToken tokenExpireIn = accessTokenObj.getExpireIn();  request.getSession().setAttribute("demo_access_token", accessToken); request.getSession().setAttribute("demo_token_expirein", String.valueOf(tokenExpireIn));  // 利用获取到的accessToken 去获取当前用的openid -------- start OpenID openIDObj = new OpenID(accessToken); // 通过对象获取[OpendId](OpendID用于获取QQ登录用户的信息) openID = openIDObj.getUserOpenID();  out.println("欢迎你,代号为 " + openID + " 的用户!"); request.getSession().setAttribute("demo_openid", openID); out.println("去看看发表说说的demo吧"); // 利用获取到的accessToken 去获取当前用户的openid --------- end  out.println("

start -----------------------------------利用获取到的accessToken,openid 去获取用户在Qzone的昵称等信息 ---------------------------- start

"); // 通过OpenID获取QQ用户登录信息对象(Oppen_ID代表着QQ用户的唯一标识) UserInfo qzoneUserInfo = new UserInfo(accessToken, openID); // 获取用户信息对象(只获取nickename与Gender) UserInfoBean userInfoBean = qzoneUserInfo.getUserInfo(); out.println("
"); if (userInfoBean.getRet() == 0) { out.println(userInfoBean.getNickname() + "
"); out.println(userInfoBean.getGender() + "
"); out.println("黄钻等级: " + userInfoBean.getLevel() + "
"); out.println("会员 : " + userInfoBean.isVip() + "
"); out.println("黄钻会员: " + userInfoBean.isYellowYearVip() + "
"); out.println("
"); out.println("
"); out.println("
"); } else { out.println("很抱歉,我们没能正确获取到您的信息,原因是: " + userInfoBean.getMsg()); } out.println("

end -----------------------------------利用获取到的accessToken,openid 去获取用户在Qzone的昵称等信息 ---------------------------- end

"); out.println("

start ----------------------------------- 验证当前用户是否为认证空间的粉丝------------------------------------------------ start

"); PageFans pageFansObj = new PageFans(accessToken, openID); PageFansBean pageFansBean = pageFansObj.checkPageFans("97700000"); if (pageFansBean.getRet() == 0) { out.println("

验证您" + (pageFansBean.isFans() ? "是" : "不是") + "QQ空间97700000官方认证空间的粉丝

"); } else { out.println("很抱歉,我们没能正确获取到您的信息,原因是: " + pageFansBean.getMsg()); } out.println("

end ----------------------------------- 验证当前用户是否为认证空间的粉丝------------------------------------------------ end

"); out.println("

start -----------------------------------利用获取到的accessToken,openid 去获取用户在微博的昵称等信息 ---------------------------- start

"); com.qq.connect.api.weibo.UserInfo weiboUserInfo = new com.qq.connect.api.weibo.UserInfo(accessToken, openID); com.qq.connect.javabeans.weibo.UserInfoBean weiboUserInfoBean = weiboUserInfo.getUserInfo(); if (weiboUserInfoBean.getRet() == 0) { //获取用户的微博头像----------------------start out.println("
"); out.println("
"); out.println("
"); //获取用户的微博头像 ---------------------end //获取用户的生日信息 --------------------start out.println("

尊敬的用户,你的生日是: " + weiboUserInfoBean.getBirthday().getYear() + "年" + weiboUserInfoBean.getBirthday().getMonth() + "月" + weiboUserInfoBean.getBirthday().getDay() + "日"); //获取用户的生日信息 --------------------end StringBuffer sb = new StringBuffer(); sb.append("

所在地:" + weiboUserInfoBean.getCountryCode() + "-" + weiboUserInfoBean.getProvinceCode() + "-" + weiboUserInfoBean.getCityCode() + weiboUserInfoBean.getLocation()); //获取用户的公司信息---------------------------start ArrayList companies = weiboUserInfoBean.getCompanies(); if (companies.size() > 0) { //有公司信息 for (int i=0, j=companies.size(); i曾服役过的公司:公司ID-" + companies.get(i).getID() + " 名称-" + companies.get(i).getCompanyName() + " 部门名称-" + companies.get(i).getDepartmentName() + " 开始工作年-" + companies.get(i).getBeginYear() + " 结束工作年-" + companies.get(i).getEndYear()); } } else { //没有公司信息 } //获取用户的公司信息---------------------------end out.println(sb.toString()); } else { out.println("很抱歉,我们没能正确获取到您的信息,原因是: " + weiboUserInfoBean.getMsg()); } out.println("

end -----------------------------------利用获取到的accessToken,openid 去获取用户在微博的昵称等信息 ---------------------------- end

"); } } catch (QQConnectException e) { }}
0a64badfe651efe0bb29832f869d1c1e.png

剩下的就是一些API的使用了,可以参考官网文档http://wiki.connect.qq.com/%E4%BD%BF%E7%94%A8authorization_code%E8%8E%B7%E5%8F%96access_token

温馨小提示:

我QQ互联上设置的回调域是127.0.0.1:8080,但我本地刚开始使用的localhost:8080访问导致最后2个地址的session值不一致,就没有授权成功跳转到回调地址,因此我们访问的地址必须要有回调域设置的地址是同一个服务器地址访问的哦~~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值