全球中文玩家俱乐部 Chinese players club of the Global .

侠外游戏论坛

 找回密码
 立即注册
快捷导航
搜索
视听
视听
图片
图片
段子
段子
小说
小说
查看: 385|回复: 1
打印 上一主题 下一主题
收起左侧

一篇文章带你搞定 GitHub OAuth 第三方登录示例教程

[复制链接]
ミ蒙面侠客ミ
跳转到指定楼层
俺是撸主
ミ蒙面侠客ミ  发表于 2022-2-19 03:26:02 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多侠客,享用更多功能,让你轻松玩转侠外论坛。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x

今天演示一个实例,如何通过 OAuth 获取 API 数据。

很多网站登录时,允许使用第三方网站的身份,这称为"第三方登录"。

下面就以 GitHub 为例,写一个最简单的应用,演示第三方登录。

[color=rgba(0, 0, 0, 0.75)]一、第三方登录的原理

所谓第三方登录,实质就是 OAuth 授权。用户想要登录 A 网站,A 网站让用户提供第三方网站的数据,证明自己的身份。获取第三方网站的身份数据,就需要 OAuth 授权。

举例来说,A 网站允许 GitHub 登录,背后就是下面的流程。

(1) A 网站让用户跳转到 GitHub。
(2)GitHub 要求用户登录,然后询问"A 网站要求获得 xx 权限,你是否同意?"
(3)用户同意,GitHub 就会重定向回 A 网站,同时发回一个授权码。
(4)A 网站使用授权码,向 GitHub 请求令牌。
(5)GitHub 返回令牌.
(6)A 网站使用令牌,向 GitHub 请求用户数据。

二、应用登记

一个应用要求 OAuth 授权,必须先到对方网站登记,让对方知道是谁在请求。

所以,你要先去 GitHub 登记一下。当然,我已经登记过了,你使用我的登记信息也可以,但为了完整走一遍流程,还是建议大家自己登记。这是免费的。

访问这个网址,填写登记表。

应用的名称随便填,主页 URL 填写http://localhost:8080,跳转网址填写 http://localhost:8080/oauth/redirect。

提交表单以后,GitHub 应该会返回客户端 ID(client ID)和客户端密钥(client secret),这就是应用的身份识别码。

三、示例仓库

这里提供了一个代码仓库:示例代码仓库,将其克隆到本地:

$ git clone [email protected]:ruanyf/node-oauth-demo.git
$ cd node-oauth-demo

两个配置项要改一下,写入上一步的身份识别码。

index.js:改掉变量clientID and clientSecret
public/index.html:改掉变量client_id

然后,安装依赖。$ npm install
启动服务。$ node index.js
浏览器访问http://localhost:8080,就可以看到这个示例了。

四、浏览器跳转 GitHub

示例的首页很简单,就是一个链接,让用户跳转到 GitHub。

跳转的 URL 如下。

https://github.com/login/oauth/authorize?  client_id=7e015d8ce32370079895&  redirect_uri=http://localhost:8080/oauth/redirect
  • 1
  • 2
  • 3

这个 URL 指向 GitHub 的 OAuth 授权网址,带有两个参数:client_id告诉 GitHub 谁在请求,redirect_uri是稍后跳转回来的网址。

用户点击到了 GitHub,GitHub 会要求用户登录,确保是本人在操作。

五、授权码

登录后,GitHub 询问用户,该应用正在请求数据,你是否同意授权。


用户同意授权, GitHub 就会跳转到redirect_uri指定的跳转网址,并且带上授权码,跳转回来的 URL 就是下面的样子。

http://localhost:8080/oauth/redirect?  code=859310e7cecc9196f4af
  • 1
  • 2

后端收到这个请求以后,就拿到了授权码(code参数)

六、后端实现

示例的后端采用 Koa 框架编写,具体语法请看教程。

这里的关键是针对/oauth/redirect的请求,编写一个路由,完成 OAuth 认证。

const oauth = async ctx => {  // ...};app.use(route.get('/oauth/redirect', oauth));
  • 1
  • 2
  • 3
  • 4

上面代码中,oauth函数就是路由的处理函数。下面的代码都写在这个函数里面。

路由函数的第一件事,是从 URL 取出授权码。

const requestToken = ctx.request.query.code;
  • 1
七、令牌

后端使用这个授权码,向 GitHub 请求令牌。

const tokenResponse = await axios({  method: 'post',  url: 'https://github.com/login/oauth/access_token?' +    `client_id=${clientID}&` +    `client_secret=${clientSecret}&` +    `code=${requestToken}`,  headers: {    accept: 'application/json'  }});
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

上面代码中,GitHub 的令牌接口https://github.com/login/oauth/access_token需要提供三个参数。

client_id:客户端的 ID
client_secret:客户端的密钥
code:授权码

作为回应,GitHub 会返回一段 JSON 数据,里面包含了令牌accessToken。

const accessToken = tokenResponse.data.access_token;
  • 1
八、API数据

有了令牌以后,就可以向 API 请求数据了。

const result = await axios({  method: 'get',  url: `https://api.github.com/user`,  headers: {    accept: 'application/json',    Authorization: `token ${accessToken}`  }});
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

上面代码中,GitHub API 的地址是https://api.github.com/user,请求的时候必须在 HTTP 头信息里面带上令牌Authorization: token 361507da。

然后,就可以拿到用户数据,得到用户的身份。

const name = result.data.name;ctx.response.redirect(`/welcome.html?name=${name}`);
  • 1
  • 2





[color=rgba(0, 0, 0, 0.75)]


原文链接 一篇文章带你搞定 GitHub OAuth 第三方登录示例教程_南淮北安的博客-CSDN博客_github添加oauth

沙花按摩
发表于 2022-2-20 01:08:53 | 只看该作者
提示: 作者被禁止或删除 内容自动屏蔽
这里是你的个性签名位置,可在“设置”-“个人信息”-“个人签名”处修改。
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则


发布主题 上个主题 下个主题 快速回复 收藏帖子 返回列表 搜索

联系我们|Archiver|手机版|小黑屋|侠外网 ( 豫ICP备13018943号-1 )

GMT+8, 2025-1-22 18:44 , Processed in 0.039462 second(s), 18 queries , Gzip On, Memcache On.

Copyright © 2001-2023 侠外游戏论坛 Powered by !Zucsud X3.5

Support By A mysterious team , A great team ! Email:

快速回复 返回顶部 返回列表