京东6.18大促主会场领京享红包更优惠

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 9441|回复: 0

vue实现GitHub的第三方授权方法示例

[复制链接]

23

主题

0

回帖

10

积分

新手上路

积分
10
发表于 2021-11-12 08:26:21 | 显示全部楼层 |阅读模式 来自 中国
目录
% t/ X* P2 t2 j: Y; G
3 x. t* N) ?) C5 H
    ; L  x9 m3 N4 d3 l+ H
  • 创建OAuth Apps' ~! q* @) }2 a" s% G
  • 获取code# F4 g) O+ J, b4 C$ q
  • 获取access_token1 z& j1 U! U! B1 w% L: W9 R
  • 获取用户信息" s3 Y/ T$ E& s
最近在完善我的博客系统,突然想到从原本临时填写 name + email 进行评论改成使用GitHub授权登陆以发表评论。; u  s% s" X( {9 U* K! D
废话不多说,直接奔入主题' u: F  ]6 C" F/ Q, x0 v! k" g& B
温馨提示:本文章只满足个人使用需求,如果需要学习更详细的使用方法,可访问 OAuth官方文档。
: S/ _0 W, @5 x" p' }( t
. O5 x5 u( R7 G; }2 i  ?! S创建OAuth Apps
3 t4 V/ E. o' R8 k1 C( E
* ?9 Q8 I% R. T$ I
/ L) a6 A& a" H+ D: }; Q3 h8 G
首先,你需要一个GitHub账户然后前往GitHub developers,根据要求填写完成之后,会自动生成Client_ID和Client Secret,在之后的步骤中会用到。
+ L) ~, y5 B% O9 V7 K
5 z/ T, }. g) X5 d) [
3 N  [' \5 F! b3 D获取code
# b' U2 U# a" c' X. N

' f' V- p% k4 E) b# A+ _
  1. //methodasync githubLogin() { windows.location.href =     "https://github.com/login/oauth/authorize?client_id = your_client_id&redirect_uri=your_redirect_uri"}
复制代码
  1. [url=https://github.com/login/oauth/authorize?client_id = your_client_id&redirect_uri=your_redirect_uri]GitHub登陆[/url]
复制代码
路由参数中redirect_uri是可选的。如果省略,则GitHub将重定向到你在OAuth apps配置的回调路径。如果提供,则你所填写的redirect_uri必须是你在OAuth apps中配置的回调路径的子路径。如下:
- f( l3 ~: y4 b0 O& R3 k7 R% ^( v6 q# Y: U$ Q
CALLBACK: http://xx.com/github
; h7 q) @; Y1 ~" t8 |GOOD: http://xx.com/github
* y, G3 R1 ~5 k' H' c. h/ `8 pGOOD: http://xx.com/github/path/path
  u( @( i% p. v/ _BAD: http://xx.com/git
9 J6 P' K; c7 x. @4 r: S# [BAD: http://xxxxx.com/path$ ^: R8 d% \- H
如果用户接受你的请求,将会跳转到redirect_uri,我们可以接受路由中的参数code,以进行下一步操作。" ?5 o: F$ W: k  C" p0 z" S4 m
  1. your_redirect_uri?code=xxx
复制代码
获取access_token2 T9 x3 M# M9 y4 {+ B* s7 K/ m
6 q* a6 q- E% p7 F6 T3 Z1 C
8 p# M2 @& k* X0 }
我们需要client_id、client_secret和code来获取access_token。
0 k- y# b2 ]9 U5 z2 G, J8 f8 j
  1. /*/githubAccessToken:https://github.com/login/oauth/access_token*/this.$axios .get('/githubAccessToken',{ params: {  client_id: your_client_id,  client_secret: your_client_secret,  code: your_code  } })
复制代码
默认情况下,你会获取如下响应:8 v; K5 l  `: o+ g0 \
  1. access_token=xxxxx&token_type=bearer
复制代码
如果你想用更方便的格式接收响应,你可以在headers中自定义Accept:
- k& l9 I+ r7 X$ }( j# r8 S7 _
  1. Accept: "application/json"=> {"access_token":xxxxx,"token_type":bearer}
复制代码
获取用户信息
: c7 B" m8 b! k+ u8 s) ^2 K, H' f5 B

2 z' e* w2 G5 x* ~5 X  |0 j9 S& \3 o5 K" ~) l& s! T2 ^
获取access_token之后,我们就可以请求用户的部分信息了:
* U: R) s& `8 u/ h; o: s- h; t1 U
  1. /*/githubUserInfo:https://api.github.com/user*/this.$axios .get('/githubUserInfo', {  headers: {    "Content-Type": "application/x-www-form-urlencoded",    Accept: "application/json",    Authorization: `token ${access_token}` //必填  }})
复制代码
然后你便可以获取到用户信息了。# A( J4 Z. j: b0 O
到此这篇关于vue实现GitHub的第三方授权的文章就介绍到这了,更多相关vue实现GitHub的第三方授权内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! 
% y6 t& u) w4 `2 V" H3 G/ t6 Y  m) V% h$ [: u8 r# h9 M
来源:http://www.jb51.net/article/227114.htm3 R0 W6 k5 U# T# H( H0 M' n7 W* C
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

帖子地址: 

梦想之都-俊月星空 优酷自频道欢迎您 http://i.youku.com/zhaojun917
回复

使用道具 举报

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

本版积分规则

QQ|手机版|小黑屋|梦想之都-俊月星空 ( 粤ICP备18056059号 )|网站地图

GMT+8, 2025-11-10 12:06 , Processed in 0.043972 second(s), 22 queries .

Powered by Mxzdjyxk! X3.5

© 2001-2025 Discuz! Team.

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