SpringBoot引入微博第三方登录

什么是第三方登录?

用户登录操作不是基于自身建设账号体系,而是基于用户在第三方平台上已有的账号和密码来快速完成登录的过程。下面我列举了几点第三方登录的优点。
极大的简化登录注册的流程。

方便用户快捷登录,降低用户的登录流失率,第三方大厂的用户某种意义上都可以是你用户。传统的登录注册,如果网站较小或者用户不经常使用,可能时间长了,用户就把登录的用户名和密码忘记了。

第三方登录接入后,应用可直接获取用户昵称、头像、用户ID等信息,方便产品获取用户的基本资料。

国内比较广泛使用的第三方登录方式为微博、微信、QQ,天翼账号等。

国外广泛使用的登录方式为Facebook,Twitter等。

微博第三方登录

接入微博的第三方登录有两种方式,分别为移动端接入和网站接入。

这次教大家怎么在你开发的web网站整合微博的第三方登录,微博登录包括身份认证、用户关系以及内容传播。允许用户使用微博帐号登录访问你的网站,分享内容,同步信息。

官网地址:https://open.weibo.com/

认证开发者信息

进入上面提供的官网地址并登录自己的微博账号,点击右上角头像,编辑开发者信息,填写基本信息并且进行身份认证。

之后需要等待身份认证信息通过审核,有点慢…

一周后…

经过漫长的等待,审核终于通过了!

之后我们就可以点击网站接入,创建应用了。

https://open.weibo.com/connect

创建完成之后需要完善信息,之后再次提交进入审核…

其实提交审核之后过个一会就可以进行微博第三方登录了,只是应用信息是处于审核状态。

上面图中的应用地址是非常重要的,可以把它理解成你网站的登录页面(必须有微博登录的组件或者超链接),其他的信息大家可以模仿我这个随便写一下。

之后我们需要进入我的应用高级信息中,把回调地址配置一下,也就是登录返回的用户信息。这些其实和QQ第三方登录是差不多的。后端需要编写一个请求来处理

@Slf4j
@Controller
public class WeiBoLoginController {

    @Value("${weibo.client_id}")
    private String clientId;

    @Value("${weibo.secret}")
    private String secret;

    @Value("${weibo.redirect}")
    private String redirect;

    @RequestMapping("/weibo")
    public String weiBo(String code, Map<String, Object> map) {
        String url = "https://api.weibo.com/oauth2/access_token?client_id=" + clientId + "&client_secret=" + secret + "&grant_type=authorization_code&redirect_uri=" + redirect + "&code=" + code;
        log.info("accessTokenUrl = {}", url);

        String resp = HttpUtil.post(url, "");
        log.info("accessTokenResp = {}", resp);

        JSON json = JSONUtil.parse(resp);
        String token = json.getByPath("access_token").toString();
        String uid = json.getByPath("uid").toString();
        log.info("token = {}", token);
        log.info("uid = {}", uid);

        String userInfoUrl = "https://api.weibo.com/2/users/show.json?uid=" + uid + "&access_token=" + token;
        String userInfo = HttpUtil.get(userInfoUrl);
        log.info("userInfo = {}", userInfo);
        JSON info = JSONUtil.parse(userInfo);
        map.put("uId", uid);
        map.put("name", info.getByPath("name"));
        map.put("imgUrl", info.getByPath("profile_image_url"));
        return "success";
    }
}

还需要在配置文件中配置微博登录的信息

# 应用ID
weibo.client_id=1556869902
# 密钥
weibo.secret=ddbf4544bf8856ffcd2e7d97761eb33f
# 回调地址
weibo.redirect=http://xuewei.world/test/weibo

之后还需要引导需要授权的用户到如下地址:

https://api.weibo.com/oauth2/authorize?client_id=你的应用ID&response_type=code&redirect_uri=你的回调地址

我这里只在前端放置了一个<a>标签

<a href="https://api.weibo.com/oauth2/authorize?client_id=1556869902&response_type=code&redirect_uri=http://xuewei.world/test/weibo"></a>

然后再稍微美化一下页面,得到的登录页面就是下面这个样子

点击微博登录之后就会跳转到微博登录的页面,可以选择扫码登录、账号密码登录、手机号等登录方式

登录成功之后可以拿到非常多的用户信息,并跳转到回调地址

我取出比较关键的信息放在前端进行显示,就是下面这个效果


这次我把微博第三方登录、QQ第三方登录整合到了一起。之后打算整合更多的第三方登录案例,登录注册这块拿捏的死死的!

代码已经打包,获取完整案例前往微信公众号【薛伟同学】回复【三方登录】。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
史上最全的整合第三方登录的工具,目前已支持Github、Gitee、微博、钉钉、百度、Coding、腾讯云开发者平台、OSChina、支付宝、QQ、微信、淘宝、Google、Facebook、抖音、领英、小米、微软和今日头条等第三方平台的授权登录。 Login, so easy!JustAuth,如你所见,它仅仅是一个第三方授权登录的工具类库,它可以让我们脱离繁琐的第三方登录SDK,让登录变得So easy!项目开源地址:gitee | github特点废话不多说,就俩字:全:已集成十多家第三方平台(国内外常用的基本都已包含),后续依然还有扩展计划!简:API就是奔着最简单去设计的(见后面快速开始),尽量让您用起来没有障碍感!快速开始引入依赖     me.zhyd.oauth     JustAuth     1.8.0 调用api// 创建授权request AuthRequest authRequest = new AuthGiteeRequest(AuthConfig.builder()         .clientId("clientId")         .clientSecret("clientSecret")         .redirectUri("redirectUri")         .state("state")         .build()); // 生成授权页面 authRequest.authorize(); // 授权登录后会返回code(auth_code(仅限支付宝))、state,1.8.0版本后,可以用AuthCallback类作为回调接口的参数 authRequest.login(callback);注:1.8.0版本后,增加了state参数校验,用于防止CSRF。强烈建议,保证单次流程内state的唯一性,且每个state只可用一次。配套Demo:JustAuth-demo具体的例子可以参考:实现Gitee授权登录实现Github授权登录API列表平台API类 SDKAuthGiteeRequest参考文档AuthGithubRequest参考文档AuthWeiboRequest参考文档AuthDingTalkRequest参考文档AuthBaiduRequest参考文档AuthCodingRequest参考文档AuthTencentCloudRequest参考文档AuthOschinaRequest参考文档AuthAlipayRequest参考文档AuthQqRequest参考文档AuthWeChatRequest参考文档AuthTaobaoRequest参考文档AuthGoogleRequest参考文档AuthFacebookRequest参考文档AuthDouyinRequest参考文档AuthLinkedinRequest参考文档AuthMicrosoftRequest参考文档AuthMiRequest参考文档AuthToutiaoRequest参考文档AuthCsdnRequest无请知悉:经咨询CSDN官方客服得知,CSDN的授权开放平台已经下线。如果以前申请过的应用,可以继续使用,但是不再支持申请新的应用。so, 本项目中的CSDN登录只能针对少部分用户使用了后续开发计划参考:[开发计划] 待扩展的第三方平台另外,期待您和我一起完善这个项目!贡献代码fork本项目到自己的repo把fork过去的项目也就是你仓库中的项目clone到你的本地修改代码commit后push到自己的库发起PR(pull request) 请求等待作者合并致谢在项目立项初期,也对当前开源圈的一些相同类型的项目作过调研,同时本项目也参考过这些项目,再次感谢开源圈内的朋友。YurunOAuthLogin: PHP 第三方登录授权 SDK阿里妈妈MUX倾力打造的矢量图标库-iconfont: 本文档中的图标大部分取自该平台

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值