QQ互联登陆(Java)

一、准备部分

1、账户注册

腾讯开放平台网址: https://connect.qq.com/index.html

首先需要到开放平台注册QQ互联开发者身份。注册之后创建一个网站应用,注意,需要备案成功的域名才可申请。

2、应用审核

审核通过后如下图所示,审核通过后可以得到 appid 和 appkey,用于开发中使用。

二、实现思路

相信大家都用过QQ登陆第三方网站,但是在开发之前我们需要先了解一下QQ互联的开发流程:

  1. 生成QQ授权链接
  2. 获取授权码,使用授权码获取用户的openid
  3. 使用openid可以查询到用户信息

openid作用:相当于QQ用户的 userid,身份唯一标识。

看完这三步是不是觉得很熟悉?没错,跟微信一个路子,毕竟都是 OAuth协议嘛。如果还不是特别清楚的小伙伴可以去看官方文档:腾讯开放平台文档 —http://wiki.connect.qq.com/

为了方便开发,我们再整理一下代码实现思路:

  1. 编写授权链接接口
  2. 编写授权回调接口,拿到用户openid
    -- 获取到授权码;
    -- 使用授权码获取accessToken;
    -- 使用accessToken获取用户openid。
  3. 使用openid查询数据库user信息表中是否有关联
    -- 如果使用openid能够查询用户信息,说明用户已经绑定成功,自动实现登陆;’
    -- 如果使用openid没有查询到用户信息的话,说明用户没有绑定账信息,跳转到关联账号页面;
    -- 关联成功账号之后,将openid修改为对应的账号信息。

三、代码部分

1、引入sdk

QQ互连提供了用户开发的SDK,下载链接:https://files.cnblogs.com/files/niceyoo/Sdk4J.zip

由于我们的项目大部分都是 maven 管理的,但提供的是个 jar 文件,所以我们可以打入本地 maven 中:

mvn install:install-file -Dfile=jar包的位置(参数一) -DgroupId=groupId(参数二) 
-DartifactId=artifactId(参数三) -Dversion=version(参数四) -Dpackaging=jar


mvn install:install-file -Dfile="F:\Sdk4J.jar" -DgroupId=com.tengxun 
-DartifactId=sdk4j  -Dversion=1.0 -Dpackaging=jar

项目中引入依赖:

<dependency>
    <groupId>com.tengxun</groupId>
    <artifactId>sdk4j</artifactId>
    <version>1.0</version>
</dependency>

项目中引入配置文件

app_ID = APP_ID
app_KEY = 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_addr
baseURL = https://graph.qq.com/
getUserInfoURL = https://graph.qq.com/user/get_user_info
accessTokenURL = https://graph.qq.com/oauth2.0/token
authorizeURL = https://graph.qq.com/oauth2.0/authorize
getOpenIDURL = https://graph.qq.com/oauth2.0/me
addTopicURL = https://graph.qq.com/shuoshuo/add_topic
addBlogURL = https://graph.qq.com/blog/add_one_blog
addAlbumURL = https://graph.qq.com/photo/add_album
uploadPicURL = https://graph.qq.com/photo/upload_pic
listAlbumURL = https://graph.qq.com/photo/list_album
addShareURL = https://graph.qq.com/share/add_share
checkPageFansURL = https://graph.qq.com/user/check_page_fans
addTURL = https://graph.qq.com/t/add_t
addPicTURL = https://graph.qq.com/t/add_pic_t
delTURL = https://graph.qq.com/t/del_t
getWeiboUserInfoURL = https://graph.qq.com/user/get_info
getWeiboOtherUserInfoURL = https://graph.qq.com/user/get_other_info
getFansListURL = https://graph.qq.com/relation/get_fanslist
getIdolsListURL = https://graph.qq.com/relation/get_idollist
addIdolURL = https://graph.qq.com/relation/add_idol
delIdolURL = https://graph.qq.com/relation/del_idol
getTenpayAddrURL = https://graph.qq.com/cft_info/get_tenpay_addr
getRepostListURL = https://graph.qq.com/t/get_repost_list
version = 2.0.0.0
2、生成QQ联合登陆授权链接
https://graph.qq.com/oauth2.0/authorize?response_type=code&client_id=[YOUR_APPID]&redirect_uri=[YOUR_REDIRECT_URI]&state=[THE_STATE]

接口以及参数详细说明地址:https://wiki.connect.qq.com/%E4%BD%BF%E7%94%A8authorization_code%E8%8E%B7%E5%8F%96access_token#Step1.EF.BC.9A.E8.8E.B7.E5.8F.96AuthorizationCode

代码实现:

/**
 * 生成授权链接
 * 
 * @param request
 * @return
 */

@RequestMapping("/qqAuth")
public String qqAuth(HttpServletRequest request) {
    try {
        String authorizeURL = new Oauth().getAuthorizeURL(request);
        log.info("authorizeURL:{}", authorizeURL);
        return "redirect:" + authorizeURL;
    } catch (Exception e) {
        return ERROR_500_FTL;
    }
}
3、QQ授权回调

在上边生成授权方法里进行了一次重定向,重定向地址即为本方法。

private static final String MB_QQ_QQLOGIN = "member/qqlogin";

/**
 * 重定向到首页
 */

private static final String REDIRECT_INDEX = "redirect:/";

@RequestMapping("/qqLoginBack")
public String qqLoginBack(HttpServletRequest request, HttpServletResponse response, HttpSession httpSession) {
    try {
        AccessToken accessTokenObj = (new Oauth()).getAccessTokenByRequest(request);
        if (accessTokenObj == null) {
            return ERROR_500_FTL;
        }
        String accessToken = accessTokenObj.getAccessToken();
        if (StringUtils.isEmpty(accessToken)) {
            return ERROR_500_FTL;
        }
        /* 获取用户openid */
        OpenID openIDObj = new OpenID(accessToken);

        String openId = openIDObj.getUserOpenID();
        if (StringUtils.isEmpty(openId)) {
            return ERROR_500_FTL;
        }
        BaseResponse<JSONObject> findByOpenId = qqAuthoriFeign.findByOpenId(openId);
        if (!isSuccess(findByOpenId)) {
            return ERROR_500_FTL;
        }
        Integer resultCode = findByOpenId.getCode();
        /* 如果使用openid没有查询到用户信息,则跳转到绑定用户信息页面 */
        if (resultCode.equals(Constants.HTTP_RES_CODE_NOTUSER_203)) {
            /* 使用openid获取用户信息 */
            UserInfo qzoneUserInfo = new UserInfo(accessToken, openId);
            UserInfoBean userInfoBean = qzoneUserInfo.getUserInfo();
            if (userInfoBean == null) {
                return ERROR_500_FTL;
            }
            String avatarURL100 = userInfoBean.getAvatar().getAvatarURL100();
            /* 返回用户头像页面展示 */
            request.setAttribute("avatarURL100", avatarURL100);
            httpSession.setAttribute(WebConstants.LOGIN_QQ_OPENID, openId);
            return MB_QQ_QQLOGIN;
        }
        /* 自动实现登陆 */
        JSONObject data = findByOpenId.getData();
        String token = data.getString("token");
        CookieUtils.setCookie(request, response, WebConstants.LOGIN_TOKEN_COOKIENAME, token);
        return REDIRECT_INDEX;
    } catch (Exception e) {
        return ERROR_500_FTL;
    }

}
4、测试环节

访问生成授权链接的方法地址:

http://shop.sscai.club/qqAuth

我创建了一个java相关的公众号,用来记录自己的学习之路,感兴趣的小伙伴可以关注一下微信公众号哈:niceyoo

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/414249.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

动静分离-静态资源缓存控制

一、静态资源服务与动态资源服务的区别 首先动静分离非前后端分离&#xff0c;关于两者的介绍如下&#xff1a; 动静分离&#xff1a;动态资源(jsp、ftl)与静态资源(js、img、css)分开前后端分离&#xff1a;接口与视图分开独立开发部署二、为什么静态资源需要实现CDN内容加速 …

分布式session共享

一、前言 为什么会出现session共享问题&#xff1f; 客户端与服务器交互时会产生唯一的sessionid用于标记用户&#xff0c;但是在分布式架构中&#xff0c;如果还是采用 session 的方式&#xff0c;用户发起请求&#xff0c;通过 nginx 做请求转发时&#xff0c;并不知道是转发…

InnoDB锁问题

InnoDB锁问题 InnoDB与MyISAM的最大不同有两点&#xff1a;一是支持事务&#xff08;TRANSACTION&#xff09;&#xff1b;二是采用了行级锁。行级锁与表级锁本来就有许多不同之处&#xff0c;另外&#xff0c;事务的引入也带来了一些新问题。下面我们先介绍一点背景知识&#…

phpsduty环境下,使用composer安装报错

1.首先要下载composer进行安装 点击下载 &#xff0c;最新的composer要求的php版本都比较高&#xff0c;安装之后&#xff0c;将composer的安装路径加入环境变量&#xff0c;我的参考路径&#xff1a;D:\composer&#xff1b; 2.我的环境使用的php版本是php7.0.12-nts&#xf…

SPU、SKU、ARPU

在涂涂商城开发之前&#xff0c;发现一篇关于电商中 SPU、SKU、ARPU 的介绍&#xff0c;转至博客&#xff0c;原文地址&#xff1a;http://www.ikent.me/blog/3017 什么是SPU、SKU、ARPU 首先&#xff0c;搞清楚商品与单品的区别。例如&#xff0c;iphone 是一个单品&#xff0…

NOIP2011提高组day2

NOIP 2011 提高组 Day 2 T1 &#xff1a; 题意&#xff1a; 这道题题意很显然&#xff0c;方法就是利用数学中的二项式定理 &#xff1a; ( x y ) ^ n C ( i , n ) * x ^ i * y ^ ( n - i )&#xff0c;i ∈ [ 0 , n ]&#xff0c;所以求x ^ n * y ^ m的系数&#xff0c;就是…

react+redux+node报错Tapable.plugin is deprecated. Use new API on `.h ooks` instead

npm run hot运行 报错(node:5372) DeprecationWarning: Tapable.plugin is deprecated. Use new API on .h ooks instead 原因是内网的IP变了&#xff0c;所以启动报错&#xff0c;修改webpack.dev.js里的host&#xff0c;解决。

什么是单点登录

前言&#xff1a; 是时候了解一下SSO相关的知识了&#xff0c;本篇主要是概念篇&#xff0c;发现网上两篇不错的文章&#xff0c;简单整合了一下&#xff0c;原文链接&#xff1a;https://www.cnblogs.com/Java3y/p/10877465.htmlhttps://www.cnblogs.com/EzrealLiu/p/5559255.…

支付宝H5支付,ISV权限不足

报错如下&#xff1a; 登录支付宝商户平台&#xff0c;发现签约产品已失效&#xff1a; 重新申请&#xff0c;修改网址之后就成功了&#xff1a;

我们为何需要单点登录系统

SSO&#xff0c;Single Sign On&#xff0c;也就是单点登录&#xff0c;保证一个账户在多个系统上实现单一用户的登录 现在随着网站的壮大&#xff0c;很多服务会进行拆分&#xff0c;会做SOA服务&#xff0c;会使用dubbo做微服务&#xff0c;或者简单的小型分布式&#xff0c…

微信JSAPI支付,报错当前页面的URL未注册

调用微信统一支付的接口&#xff0c;支付时报错&#xff1a; 解决方案&#xff1a; 打开微信商户平台&#xff0c;将当前页面的URL配置到JSAPI域名。

借助xxl-sso实现SSO

前言 市场上一下主流的SSO技术搭配方案&#xff1a; SpringSecurity OAuth2 SpringSecurity CAS 功能较弱&#xff0c;对前后端分离的项目支持不是很好Shiro CAS JWT 可以自定义需求&#xff0c;灵活扩展鉴权方式 本篇主要是单点登录&#xff0c;不涉及鉴权&#xff0c;后面…

C语言数组初始化的问题

转载于:https://www.cnblogs.com/chulin/p/8880184.html

blocked by CORS policy,是否跨域?

经排查不是跨域的问题&#xff0c;代码报错&#xff0c;改好就解决了 2021.10.20 项目上线又报错&#xff0c;测试环境一直没问题&#xff0c;上线了就报这个错&#xff0c;如果是前端代码的问题&#xff0c;那么使用测试接口的时候肯定也会报这个错&#xff0c;所以排除前端代…

那些一眼就被看出包装过的简历

本文作者&#xff1a;Coody原文链接&#xff1a;https://my.oschina.net/hooker/blog/3014656 前言 在互联网极速膨胀的社会背景下&#xff0c;各行各业涌入互联网的IT民工日益增大。 早在2016年&#xff0c;我司发布了Java、Ios工程师的招聘信息&#xff0c;就Java工程师单个岗…