当前位置: 首页 >文章 > 没错,用三方 Github 做授权登录就是这么简单!(OAuth2.0实战)
收藏
分享

没错,用三方 Github 做授权登录就是这么简单!(OAuth2.0实战)

举报小虎转载君小虎转载君发布于 2020-07-14638阅读0点赞
从整个GitHub授权登录的过程来看,OAuth2.0的授权码模式还是比较简单的...

最近在做自己的开源项目(fire),Springboot + vue 的前后端分离框架才搭建完,刚开始做登录功能,做着做着觉得普通账户密码登录太简单了没啥意思,思来想去为显得逼格高一点,决定再加上 GitHub授权 和 人脸识别等多种登录方式。

在这里插入图片描述

而GitHub授权登录正好用到了OAuth2.0中最复杂的授权码模式,正好拿我这个案例给大家分享一下OAuth2.0的授权过程,我把项目已经部署到云服务,文末有预览地址,小伙伴们可以体验一下,后续项目功能会持续更新。



一、授权流程

在具体做GitHub授权登录之前,咱们再简单回顾一下OAuth2.0授权码模式的授权流程,如果 fire 网站允许 用GitHub 账号登录,流程大致如下图。

在这里插入图片描述

用户想用GitHub 账号去登录 fire 网站:

fire 网站先让用户跳转到 GitHub 进行授权,会弹出一个授权框。
用户同意后,GitHub 会根据redirect_uri 重定向回 fire 网站,同时返回一个授权码code。

fire 网站使用授权码和客户端密匙client_secret,向 GitHub 请求令牌token,检验通过返回令牌。

最后fire 网站向GitHub 请求数据,每次调用 GitHub 的 API 都要带上令牌。



二、身份注册

梳理完授权逻辑,接下来我们还有一些准备工作。

要想得到一个网站的OAuth授权,必须要到它的网站进行身份注册,拿到应用的身份识别码 ClientID 和 ClientSecret。

注册 传送门

 https://github.com/settings/applications/1334665,有几个必填项。

Application name:我们的应用名;

Homepage URL:应用主页链接;

Authorization callback URL:这个是github 回调我们项目的地址,用来获取授权码和令牌。


提交后会看到就可以看到客户端ClientID 和客户端密匙ClientSecret,到这我们的准备工作就完事了。

在这里插入图片描述



三、授权开发

1、获取授权码

为了更好的看效果,获取授权码我处理的比较粗暴,直接在JS里拼装好了授权链接,但实际工作开发中一定要考虑到安全问题。

前端 vue 的逻辑也非常简单,只需要 window.location.href 重定向一下。

<script>

export default {

methods: {

loginByGithub: function () {

window.location.href = 'https://github.com/login/oauth/authorize?client_id=ad41c05c211421c659db&redirect_uri=http://47.93.6.5:8080/authorize/redirect'

}

}

}

</script>

请求后会提示让我们授权,同意授权后会重定向到authorize/redirect,并携带授权码code;如果之前已经同意过,会跳过这一步直接回调。

在这里插入图片描述


2、获取令牌

授权后紧接着就要回调 fire 网站接口,拿到授权码以后拼装获取令牌 access_token的请求链接,这时会用到客户端密匙client_secret。

access_token 会作为请求响应返回,结果是个串字符,需要我们截取一下。

有了令牌以后开始获取用户信息,在 API 中要带上access_token。

返回的用户信息是 JSON 数据格式,如果想把数据传递给前端,可以通过 url 重定向到前端页面,将数据以参数的方式传递。

下边是 GitHub 回调我们 fire网站后端处理流程的部分代码,写的比较糙,后续继续优化吧!

/**

* @param code

* @author xiaofu

* @description 授权回调

* @date 2020/7/10 15:42

*/

@RequestMapping("/authorize/redirect")

public ModelAndView authorize(@NotEmpty String code) {
log.info("授权码code: {}", code);

/**

* 重新到前端主页

*/

String redirectHome = "http://47.93.6.5/home";
try {

/**

* 1、拼装获取accessToken url

*/

String accessTokenUrl = gitHubProperties.getAccesstokenUrl()

.replace("clientId", gitHubProperties.getClientId())

.replace("clientSecret", gitHubProperties.getClientSecret())

.replace("authorize_code", code);
/**

* 返回结果中直接返回token

*/

String result = OkHttpClientUtil.sendByGetUrl(accessTokenUrl);

log.info(" 请求 token 结果:{}", result);
String accessToken = null;

Pattern p = Pattern.compile("=(\\w+)&");

Matcher m = p.matcher(result);

while (m.find()) {

accessToken = m.group(1);

log.info("令牌token:{}", m.group(1));

break;

}
/**

* 成功获取token后,开始请求用户信息

*/

String userInfoUrl = gitHubProperties.getUserUrl().replace("accessToken", accessToken);
String userResult = OkHttpClientUtil.sendByGetUrl(userInfoUrl);

log.info("用户信息:{}", userResult);

UserInfo userInfo = JSON.parseObject(userResult, UserInfo.class);

redirectHome += "?name=" + userInfo.getName();

} catch (Exception e) {

log.error("授权回调异常={}", e);

}

return new ModelAndView(new RedirectView(redirectHome));

}

最后我们动图看一下整体的授权流程,由于GitHub的访问速度比较慢,偶尔会有请求超时的现象。

在这里插入图片描述

线上预览地址:http://47.93.6.5/login ,欢迎体验~

项目 GitHub 地址:https://github.com/chengxy-nds/fire.git



总结

从整个GitHub授权登录的过程来看,OAuth2.0的授权码模式还是比较简单的,搞懂了一个GitHub的登录,像微信、围脖其他三方登录也就都会了,完全是大同小异的东西,感兴趣的同学可以试一试。




本文原创,未经作者允许不可转载!

更多内容,欢迎关注作者微信公众号:程序员内点事!


0条评论
别默默看啦~登录/注册一起参与讨论吧~

暂无评论

请选择举报理由

违反法律法规

侵犯个人权益

有害网站环境

更多训练营>>

为你推荐 · 训练营(全勤打卡报名费全额返累计全额返用户133,673人)

【5月】零基础动态表情包创作训练营
距离开班仅剩12天27人已报名
【6月】人像后期案例实操训练营
距离开班仅剩39天23人已报名
【7月电脑剪映】短视频剪辑入门训练营
距离开班仅剩61天3人已报名
特惠
充值
7折购
今日还在继续学习的你,太棒了!
7
折扣券可用于
年费无限VIP
立 即
使 用
此活动优惠不可与其他活动叠加使用
有效期:000000
消息
登录即可查看消息记录
建议
意见
官方
客服
在线咨询客服热线

您可以与在线客服进行沟通获得帮助

工作日:9:00~22:00节假日:9:00~18:00

联系在线客服

您可以电话联系客服进行沟通获得帮助

工作日:9:30~18:30

400-862-9191
虎课
积分
免费学习90000+个教程!
配套素材、源文件一键下载!
昨日学员已学习了33,301
并提交了258份作业!
登录后立即学习!
loading
微信扫码关注即可登录
您需要同意协议才可以进行登录
登录虎课网,每天免费学课程全站 90000+ 视频会员教程 | 每日可免费学 1
为确保账户信息安全
请先进行真实姓名验证后进行充值付款
立即验证