社交登陆成功回调

news/2024/5/17 18:02:50 标签: gitee

1. 点击跳转至第三方授权

在这里插入图片描述

gitee_4">2. 这是使用gitee作为第三方授权进行验证

在这里插入图片描述

3. 授权成功则跳转至 redirect_url

在这里插入图片描述

4. 社交登陆回调逻辑

一、根据第三方授权提供的方式获取token

(1)发送请求获取code码(每次发送请求,code码会改变)

https://gitee.com/oauth/authorize?client_id={client_id}&redirect_uri={redirect_uri}&response_type=code

(2)根据获取的code码拼装url,发送POST请求获取token信息

https://gitee.com/oauth/token?grant_type=authorization_code&code={code}&client_id={client_id}&redirect_uri={redirect_uri}&client_secret={client_secret}

(3)获取access_token

二、判断token信息是否获取成功,获取成功代码第三方授权登陆成功,可以直接跳转至主页,获取失败则刷新登陆页

(1)获取token信息成功,则取出access_token
(2)判断是否是第一次登陆
通过判断会员数据库是否存在uid(uid需要使用access_token查询第三方授权的用户信息)
如果uid已存在数据库中则表示不是第一次登陆,则只需更新access_token即可(token每登录一次会改变,并且过期时间为1天)
如果uid不存在,则表示第一次登陆,直接进行注册,注册信息从第三方授权用户信息中获取

/**
 * 处理社交登陆
 */
@Slf4j
@Controller
public class OAuth2Controller {

    @Autowired
    MemberFeignService memberFeignService;

    //http://auth.gulimall.com/oauth2.0/gitee/success?code=b43c71db8f207af30474f8331d76789c7cf705899ef7b276b7e60bb35c83cabd
    @GetMapping("/oauth2.0/gitee/success")
    public String oauth2(@RequestParam("code") String code) throws Exception {

        HttpResponse post = null;
        try {
            //https://gitee.com/oauth/token?grant_type=authorization_code&code={code}&client_id={client_id}&redirect_uri={redirect_uri}&client_secret={client_secret}
            Map<String,String> map = new HashMap<>();
            map.put("grant_type",Oauth2Constant.OAUTH2_GRANT_TYPE);
            map.put("code",code);
            map.put("client_id", Oauth2Constant.OAUTH2_CLIENT_ID);
            map.put("redirect_uri",Oauth2Constant.OAUTH2_RIDIRECT_URI);
            map.put("client_secret",Oauth2Constant.OAUTH2_CLIENT_SECRET);
            //String host, String path, String method,
            //Map<String, String> headers,
            //Map<String, String> querys,
            //Map<String, String> bodys
            post = HttpUtils.doPost("https://gitee.com", "/oauth/token", "POST", new HashMap<>(), map, new HashMap<>());
        } catch (Exception e) {
            e.printStackTrace();
        }

        //取出token
        //获取状态行的响应码,如果是200就代表响应成功
        if (post.getStatusLine().getStatusCode() == 200){
            HttpEntity entity = post.getEntity();
            //将HttpEntity转换成String类型
            String entityJsonString = EntityUtils.toString(entity);
            //Json字符串 -> java对象  参数必须是String类型Json串
            SocialUser socialUser = JSON.parseObject(entityJsonString,SocialUser.class);

            //判断账号是否是第一次登陆,如果是第一次登陆就直接注册到会员服务
            R<MemberOAuthVo> r = memberFeignService.oauth2Login(socialUser);
            if (r.getCode() == 0){
                MemberOAuthVo memberOAuthVo = r.getData(new TypeReference<MemberOAuthVo>() {});
                log.info("用户信息:{}",memberOAuthVo);
                return "redirect:http://gulimall.com";
            }
        }else {
            //获取失败 -> 重定向到登录页
            return "redirect:http://auth.gulimall.com/login.html";
        }

        //第三方授权成功 -> 跳转至登陆页
        return "redirect:http://gulimall.com";

    }

}

会员注册

/**
     * 判断账号是否是第一次登陆
     */
    @PostMapping("/oauth2Login")
    public R<MemberEntity> oauth2Login(@RequestBody SocialUser socialUser) throws Exception {
        MemberEntity member = memberService.oauth2Login(socialUser);
        if(member != null){
            return R.ok().setData(member);
        }else {
            return R.error(BizCodeEnum.LOGINACCT_PASSWORD_INVALID_EXCEPTION.getCode(), BizCodeEnum.LOGINACCT_PASSWORD_INVALID_EXCEPTION.getMsg());
        }

    }
/**
     * 判断账号是否是第一次登陆
     * 1.查询uid(created_at) 是否存在,uid存在则表示不是第一次登陆,只需要更新access_token即可
     * 2.如果uid不存在,则查询第三方授权的用户信息,将用户信息、uid、access_token存入member服务
     * 3.返回MemberEntity
     */
    @Override
    public MemberEntity oauth2Login(SocialUser socialUser) throws Exception {
        //获取gitee授权用户的资料 https://gitee.com/api/v5/user
        //String host, String path, String method,
        //Map<String, String> headers,
        //Map<String, String> quer
        MemberEntity oatuthMemberEntity = null;
        String giteeId = null;
        String giteeName = null;
        try {
            Map<String,String> map = new HashMap<>();
            map.put("access_token",socialUser.getAccess_token());
            HttpResponse response = HttpUtils.doGet("https://gitee.com", "/api/v5/user", "GET", new HashMap<>(), map);
            oatuthMemberEntity = new MemberEntity();
            giteeId = "";
            giteeName = "";
            if (response.getStatusLine().getStatusCode() == 200){
                HttpEntity entity = response.getEntity();
                String s = EntityUtils.toString(entity);
                JSONObject jsonObject = JSON.parseObject(s);
                giteeId = jsonObject.getString("id");
                giteeName = jsonObject.getString("name");
            }
        } catch (Exception e) {
            e.printStackTrace();
        }

        //判断账号是否是第一次登陆
        MemberEntity memberEntity = this.baseMapper.selectOne(new QueryWrapper<MemberEntity>().eq("social_uid", giteeId));
        if (memberEntity != null){
            //uid存在,表示不是第一次登陆,则更新token即可
            MemberEntity member = new MemberEntity();
            member.setId(memberEntity.getId());
            member.setAccessToken(socialUser.getAccess_token());
            member.setExpiresIn(Long.toString(socialUser.getExpires_in()));
            this.baseMapper.updateById(member);
            //返回MemberEntity
            return memberEntity;
        }else {
            //查询为空表示是第一次登陆,根据第三方提供的api查询用户信息,然后注册
            oatuthMemberEntity.setSocialUid(giteeId);
            oatuthMemberEntity.setUsername(giteeName);
            oatuthMemberEntity.setCreateTime(new Date());
            oatuthMemberEntity.setAccessToken(socialUser.getAccess_token());
            oatuthMemberEntity.setExpiresIn(Long.toString(socialUser.getExpires_in()));
            this.baseMapper.insert(oatuthMemberEntity);
            return oatuthMemberEntity;
        }
    }

http://www.niftyadmin.cn/n/461075.html

相关文章

找bug号召

我的博客是为了完成这个找 bug 号召&#xff1a; https://bbs.csdn.net/topics/614134877。 文章目录 测试场景之三&#xff1a; 选择你的身份 测试场景之三&#xff1a; 选择你的身份 同样在个人中心的最下面&#xff0c;你可以看到身份选择的界面。 注意&#xff0c;你要把鼠…

【算法】Maximum Value of a String in an Array 数组中字符串的最大值

文章目录 Maximum Value of a String in an Array 数组中字符串的最大值问题描述&#xff1a;分析代码 Tag Maximum Value of a String in an Array 数组中字符串的最大值 问题描述&#xff1a; 一个由字母和数字组成的字符串的 值 定义如下&#xff1a; 如果字符串 只 包含…

【算法题解】41. 二叉树的中序遍历

这是一道 简单 题 https://leetcode.cn/problems/binary-tree-inorder-traversal/ 题目 给定一个二叉树的根节点 root &#xff0c;返回 它的 中序 遍历 。 示例 1&#xff1a; 输入&#xff1a;root [1,null,2,3] 输出&#xff1a;[1,3,2] 示例 2&#xff1a; 输入&#…

【C++入门第五期】类和对象(中)

这里写目录标题 类的6个默认成员函数构造函数特征 析构函数概念特性 拷贝构造特征拷贝构造如何自定义 运算符重载赋值运算符重载赋值运算符重载前置和后置重载 取地址及const取地址操作符重载 类的6个默认成员函数 如果一个类中什么成员都没有&#xff0c;简称为空类。 class…

【数据分享】1929-2022年全球站点的逐月平均海平面压力数据(Shp\Excel\12000个站点)

气象数据是在各项研究中都经常使用的数据&#xff0c;气象指标包括气温、风速、降水、能见度等指标&#xff0c;说到气象数据&#xff0c;最详细的气象数据是具体到气象监测站点的数据&#xff01; 对于具体到监测站点的气象数据&#xff0c;之前我们分享过1929-2022年全球气象…

算法习题之有序表

有序表 搜索二叉树搜索二叉树查询key&#xff08;查询某个key存在还是不存在&#xff09;搜索二叉树插入新的key搜索二叉树删除key搜索二叉树特别不讲究AVL树、SB树、红黑树的共性AVL树、SB树、红黑树的不同AVL树AVL数 搜索二叉树 搜索二叉树一定要说明以什么标准来排序 经典的…

剑指 Offer 41. 数据流中的中位数 / LeetCode 295. 数据流的中位数(优先队列,二叉堆)

题目&#xff1a; 链接&#xff1a;剑指 Offer 41. 数据流中的中位数&#xff1b;LeetCode 295. 数据流的中位数 难度&#xff1a;困难 如何得到一个数据流中的中位数&#xff1f;如果从数据流中读出奇数个数值&#xff0c;那么中位数就是所有数值排序之后位于中间的数值。如…

Redis进阶 - Redis持久化

原文首更地址&#xff0c;阅读效果更佳&#xff01; Redis进阶 - Redis持久化 | CoderMast编程桅杆https://www.codermast.com/database/redis/redis-advance-persistence.html 单点Redis的问题 数据丢失问题&#xff1a;Redis 是内存存储&#xff0c;服务重启可能会丢失数据。…