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

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=""
                                οnclick="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);
    }
    
}
 



                            

 

转载于:https://my.oschina.net/youngit/blog/1510666

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值