文档章节

QQ的第三方登陆,操作步骤

Lance_IT
 Lance_IT
发布于 2017/08/15 18:36
字数 821
阅读 128
收藏 1

#程序员薪资揭榜#你做程序员几年了?月薪多少?发量还在么?>>>

1,到 https://connect.qq.com QQ互联管理中心的"应用管理"申请QQ的app_id和app_key,提前提交你需要回调的地址.

2,配置申请下来的的appid和appkey,及回调地址

3,获取配置文件中appid和appkey,机会掉地址,代码如下:

package com.yst.wallet.common;

import java.util.Properties;

import org.apache.log4j.Logger;
import org.jcoreplus.util.properties.PropertiesUtil;

/**
 * 接口配置类
 */
public class Config {

    private static final Logger logger = Logger.getLogger(Config.class.getName());
    // 配置文件名称
    public static final String config_filename = "system_config.properties";

    public static String qq_app_id;
    public static String qq_app_key;
    public static String qq_redirect_uri;
    /**
     * 更新配置文件
     */
    public static void refreshConfig() {
        Config.loadConfig();
    }

    /**
     * 加载配置文件
     */
    private static void loadConfig() {
        try {
            // 得到系统配置对象
            Properties properties = PropertiesUtil.loadProperties(Config.config_filename);
            
            qq_app_id = properties.getProperty("qq.app_id");
            qq_app_key = properties.getProperty("qq.app_key");
            qq_redirect_uri = properties.getProperty("qq.redirect_uri");
        } catch (Exception ex) {
            logger.fatal("加载配置文件异常!", ex);
        }
    }

    /**
     * 打印本类所有的属性值
     */
    public static void toStringPrint() {

        logger.info("            qq_app_id=" + qq_app_id);
        logger.info("            qq_app_key=" + qq_app_key);
        logger.info("           qq_redirect_uri=" + qq_redirect_uri);
    }
}

 

4,编写controller代码(回调地址),通过appid,appkey和回调地址获取access_token,open_id然后获取qq的用户信息

/**
     * 采用QQ三方登陆之后的回调地址
     * @param login_token
     * @return
     * @throws Exception
     */
    @RequestMapping(value="/isajax/OAuth2Login/QQLoginResponseProcess")
    public ModelAndView qqLoginCallBack(@RequestParam(required=false) String code,
            @RequestParam(required=false) String state){
        String path = CLASS_PATH + "/" + Thread.currentThread().getStackTrace()[1].getMethodName();
        LogUtils.putRequestLog("qq第三方登录的回调", path,this.getPageData());
        ModelAndView mv = this.getModelAndView();
        if(StringUtils.isNotBlank(code)){
            try {
                //1,获取access_token
                String token =  QQLoginUtil.getAccessToken(code);
                //2,获取openId
                String openId = QQLoginUtil.getOpenid(token);
                
                if(StringUtils.isNotBlank(openId)){
                    
                    //3.根据openid判断是不是绑定了,没有绑定,跳转到绑定页面
                    PageData pd = new PageData();
                    pd.put("login_type", "05");// 登录类型 05  国美在线
                    pd.put("login_name", openId);// 登录名
                
                    pd = new Epay_api_security().user_login(pd);
                    if (Const.RETURN_SUCCESS.equals(pd.get("code"))) {// 请求成功,登录shiro,跳转到index页面
                        UserInfo user = (UserInfo) pd.get("data");
                        if (user != null) {
                            user.setLast_login_time(DateFormatUtil.to_normal(user.getLast_login_time()));
                            // 把用户信息放session中
                            Jurisdiction.getSession().setAttribute(Const.SESSION_USER, user);
                            Jurisdiction.getSession().setAttribute(Const.LOGIN_TOKEN, user.getLogin_token());
                            //shiro加入身份验证
                            Subject subject = SecurityUtils.getSubject(); 
                            CaptchaUsernamePasswordToken logintoken = new CaptchaUsernamePasswordToken(token, token,"","","","",token,openId,""); 
                             try { 
                                    subject.login(logintoken); 
                                } catch (Exception e){
                                    e.printStackTrace();
                                    mv.setViewName("redirect:/login_toLogin");
                                }
                            
                            mv.setViewName("redirect:/index");//跳转到首页
                        }else{
                            mv.setViewName("error");
                            mv.addObject("msg","用户信息为空,请稍后重试");
                        }
                        
                    }else{
                        String userInfo = QQLoginUtil.getQQUser(token, openId);
                        mv.setViewName("redirect:/gomebangding");//跳转到首页
                        Jurisdiction.getSession().setAttribute(Const.GOME_OPENID, openId);
                        Jurisdiction.getSession().setAttribute(Const.GOME_USER, userInfo);
                        
                    }
                }else{//{"error_code":3019,"error_description":"code值错误"}
                    mv.setViewName("error");
                    mv.addObject("msg","腾讯QQ授权登录返回信息:"+openId);
                }
                
            } catch (ClientProtocolException e) {
                e.printStackTrace();
                mv.setViewName("error");
                mv.addObject("msg",e.getMessage());
            } catch (IOException e) {
                e.printStackTrace();
                mv.setViewName("error");
                mv.addObject("msg",e.getMessage());
            }
            
        }else{
            mv.setViewName("error");
            mv.addObject("msg","code值为空");
        }
        
        return mv;
    }

5,html页面调取qq的链接

<li class="qq_sign"><span title="QQ账号" href=""
                                onclick="javascript:document.location='https://graph.qq.com/oauth/show?which=ConfirmPage&display=pc&response_type=code&client_id=${qq_app_id}&redirect_uri=${qq_redirect_uri}&state=test'"></span></li>

6,QQLoginUtil.java

package com.yst.wallet.common.util;

import java.io.IOException;
import java.util.Arrays;

import org.apache.http.client.ClientProtocolException;

import com.yst.wallet.common.Config;

public class QQLoginUtil {

    //获得AccessToken的url
    private static String getAccessTokenUrl = "https://graph.qq.com/oauth2.0/token";
    //获得openid的url
    private static String getOpenIdUrl = "https://graph.qq.com/oauth2.0/me";
                                          
    //得到QQ用户信息的url
    private static String getQQUserUrl = "https://graph.qq.com/user/get_user_info";
    /**
     * 得到access_token
     * @return
     * @throws ClientProtocolException
     * @throws IOException
     */
    public static String getAccessToken(String code) throws ClientProtocolException, IOException{
        String qq_url = getAccessTokenUrl+"?grant_type=authorization_code&client_id="+Config.qq_app_id+
                "&client_secret="+Config.qq_app_key+
                "&code="+code+
                "&redirect_uri="+Config.qq_redirect_uri;
        
        String token =  AuthUtil.doGetJson(qq_url);
        if(token.indexOf("&") != -1){
            String[] tokenStr = token.split("&");
            return tokenStr[0];
        }
        return token;
    }
    /**
     * 得到QQ openid
     * @return
     * @throws ClientProtocolException
     * @throws IOException
     */
    public static String getOpenid(String access_token) throws ClientProtocolException, IOException{
        String qq_url = getOpenIdUrl+"?access_token="+access_token;
        String openid =  AuthUtil.doGetJson(qq_url);
        if(openid.indexOf("&") != -1){
            String[] str = openid.split("&");
            return str[1];
        }
        return AuthUtil.doGetJson(qq_url);
    }
    /**
     * 得到QQ用户信息
     * @param code
     * @return
     * @throws IOException 
     * @throws ClientProtocolException 
     */
    public static String getQQUser(String token,String openId) throws ClientProtocolException, IOException {
        /*String paramurl = "access_token="+token+"&oauth_consumer_key=YOUR_APP_ID&openId="+openId
                +"&timestamp="+String.valueOf(System.currentTimeMillis())+"&client_id="+
                Config.qq_app_id+"&version=1.0&sign_method=MD5";*/
        String paramurl = getOpenIdUrl+"?access_token="+token+"&oauth_consumer_key="+Config.qq_app_id+"&openid="+openId;
        String[] params = paramurl.split("&");
        //对参数按照顺序排序
        Arrays.sort(params);
        StringBuffer sb = new StringBuffer();
        for (String param : params) {
            param = param.replace("=", "").replace("null", "");
            sb.append(param);
        }
        String sign = MD5.MD5(sb.toString()+Config.qq_app_key).toLowerCase();        
        //Collections.sort(list);
        
        return AuthUtil.doGetJson(getQQUserUrl+"?"+paramurl+"&sign="+sign);
    }
    
}
 



                            

 

© 著作权归作者所有

Lance_IT
粉丝 0
博文 15
码字总数 23333
作品 0
昌平
高级程序员
私信 提问
加载中

评论(0)

Oauth2.0 QQ&微信&微博实现第三方登陆

一、写在前面 目前对于大多数的App或Web网站都支持有第三方登陆这个功能,用户可使用 QQ/ 微信/ 微博 帐号快速登录你的网站,降低注册门槛,为你的网站带来海量新用户。最近在新项目上刚好用...

osc_5s0xzojq
2018/01/13
4
0
小功能丨ShareSDK从零开始

版权声明:欢迎转载,转载请注明出处 https://blog.csdn.net/weixin_38239050/article/details/86493435 因为ShareSDK的功能众多,因此我将一条一条的实现每个功能,并将操作步骤记录下来。 ...

橙子va
2019/01/15
0
0
JavaWeb_gy博客网站_系统实现

  目录      1、com.jiguiyan.blog  启动层   2、com.jiguiyan.blog.config  配置层   3、com.jiguiyan.blog.controller  控制器层   4、com.jiguiyan.blog.domain  实体...

osc_7ei0ce8w
2019/12/15
2
0
第三方登录

最近项目中需要实现微信登录,记录在这里,以备以后需要. http://wiki.mob.com/简洁版第三方登陆/ 一.第三方登录的定义 第三方登录,就是利用用户在第三方平台上已有的账号来快速完成自己应用...

我爱觉觉
2015/11/25
228
1
第三方版本严重影响正版微信,马化腾:微信双开就封号!

  最近腾讯接连的“发飙”,广大网友们是不是都深感其受。单是微信支付、QQ钱包开始收费,也许就让各位亲心理咯噔一下了,接着又是大量的QQ账号被封杀,严厉打击多开软件等第三方登陆软件。...

火星科技美少女
2017/12/26
0
0

没有更多内容

加载失败,请刷新页面

加载更多

基于Centos7系统一键部署EFK服务

最近平台EFK版本均作了升级,平台采用EFK(ElasticSearch-7.6.2 + FileBeat-7.6.2 + Kibana-7.6.2)架构。这里建议三个组件主次版本保持一致。考虑到服务器比较多,所以写成脚本来批量部署。 ...

linuxprobe2020
29分钟前
19
0
检查键是否存在于JavaScript对象中? - Checking if a key exists in a JavaScript object?

问题: How do I check if a particular key exists in a JavaScript object or array? 如何检查JavaScript对象或数组中是否存在特定键? If a key doesn't exist, and I try to access it, ......

fyin1314
54分钟前
21
0
jasypt-spring-boot提示Failed to bind properties

1 问题描述 在Spring Boot中使用jasypt-spring-boot进行加密,但是提示: Description:Failed to bind properties under 'spring.datasource.password' to java.lang.String: Reason:......

氷泠
今天
29
0
在git 2.13之前,只保存多个已更改的文件中的一个文件

问题: 如何在我的分支上只隐藏多个已更改文件中的一个? 解决方案: 参考一: https://stackoom.com/question/Cl3h/在git-之前-只保存多个已更改的文件中的一个文件 参考二: https://oldb...

技术盛宴
今天
30
0
SQL笔记:把Excel的数据导入MySQL中作运算

很多Excel用户都知道,Excel单个工作簿单张表存储的数据量很有限(旧版本月60多万条记录,新版本也才104万条不到),而且Excel中,因为自带各种格式与公式,兼之高度封装性等原因,导致Excel...

tengyulong
今天
15
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部