GitHub OAuth 第三方登录(使用 Flask)

简介

本篇文章以 GitHub 为示例, 展示一个使用OAuth 实现第三方登录的简单 Demo, 后台使用 Flask


注册

注册 OAuth Apps, 在 GitHub 的 setting/Developer setting 界面, 选择新增 OAuth App


在 Demo 阶段, URL 设为本机地址


之后添加一个 client secret, 后边会使用 client id 和 client secret 以及 跳转地址 “http://127.0.0.1:5000/oauth/redirect”


后台

保存全局参数

oauth_info = {
    "client_id": "d1c8a036b4daf17d110d",
    "client_secret": "d33da54871cd978b9e4203ed373ceb62c20063d3",
    "redirect_uri": "http://127.0.0.1:5000/oauth/redirect"
}

BASE_URL = "https://github.com/login/oauth/"

client_id 和 client_secret 可以修改为自己申请的参数


主页视图

向 GitHub 发送授权请求

相应地址为:

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

import urllib.parse

# 主页视图
@app.route('/', methods=['GET'])
def index():
    q_string = urllib.parse.urlencode({
        "client_id": oauth_info["client_id"],
        "redirect_uri": oauth_info["redirect_uri"]
    })
    # 组装授权申请地址
    oauth_url = BASE_URL + "/authorize?" + q_string
    return f"<h3><a href='{oauth_url}'>Login</a></h3>"

主页很简单, 就一个登录链接

点击后跳转授权界面


登录 GitHub 后将跳转到 “http://127.0.0.1:5000/oauth/redirect?code=1a20d2be4bc9d7f74fbb”, 并附带一个授权码, 这样我们就得处理这个视图


跳转页面视图

得到授权码后, 下一步就是获取令牌, 再由令牌获取 GitHub 用户信息

import requests

@app.route("/oauth/redirect")
def oauth():
    token_url = BASE_URL + "/access_token"
    # 获取授权码
    auth_code = request.args.get("code")
    params = {
        "client_id": oauth_info["client_id"],
        "client_secret": oauth_info["client_secret"],
        "code": auth_code
    }
    headers = {
        "accept": "application/json",
    }
    # 请求令牌
    res = requests.post(token_url, params=params, headers=headers)
    # 获取令牌
    token = res.json().get("access_token")
    # 带上令牌
    headers["Authorization"] = "token " + token
    # 获取用户信息, API 地址为 https://api.github.com/user
    res = requests.get("https://api.github.com/user", headers=headers)

    return f"<h3>{res.json().get('name')}</h3>"

该视图处理的结果为展示 GitHub 用户名


整个代码

import urllib.parse

import requests
from flask import Flask, request

app = Flask(__name__)

BASE_URL = "https://github.com/login/oauth/"

oauth_info = {
    "client_id": "d1c8a036b4daf17d110d",
    "client_secret": "d33da54871cd978b9e4203ed373ceb62c20063d3",
    "redirect_uri": "http://127.0.0.1:5000/oauth/redirect"
}

# 主页视图
@app.route('/', methods=['GET'])
def index():
    q_string = urllib.parse.urlencode({
        "client_id": oauth_info["client_id"],
        "redirect_uri": oauth_info["redirect_uri"]
    })
    # 组装授权申请地址
    oauth_url = BASE_URL + "/authorize?" + q_string
    return f"<h3><a href='{oauth_url}'>Login</a></h3>"


# 跳转页面视图
@app.route("/oauth/redirect")
def oauth():
    token_url = BASE_URL + "/access_token"
    # 获取授权码
    auth_code = request.args.get("code")
    params = {
        "client_id": oauth_info["client_id"],
        "client_secret": oauth_info["client_secret"],
        "code": auth_code
    }
    headers = {
        "accept": "application/json",
    }
    # 请求令牌
    res = requests.post(token_url, params=params, headers=headers)
    # 获取令牌
    token = res.json().get("access_token")
    # 带上令牌
    headers["Authorization"] = "token " + token
    # 获取用户信息, API 地址为 https://api.github.com/user
    res = requests.get("https://api.github.com/user", headers=headers)

    return f"<h3>{res.json().get('name')}</h3>"


if __name__ == '__main__':
    app.run(debug=True)
  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要将 GitHub 第三方登录接入到你的应用程序中,你可以按照以下步骤进行操作: 1. 创建一个 GitHub 开发者帐户:在 GitHub 上创建一个帐户(如果你还没有)。然后登录到你的帐户并导航到开发者设置页面。 2. 创建一个新的 OAuth 应用程序:在开发者设置页面中,点击 "New OAuth App" 按钮创建一个新的应用程序。填写应用程序的名称、主页 URL(可以是你的应用程序网站)、回调 URL(GitHub 会将用户重定向到此 URL),并选择适当的权限范围。 3. 获取应用程序的客户端 ID 和客户端密钥:创建应用程序后,你将获得一个客户端 ID 和一个客户端密钥。这些信息将在后续步骤中使用。 4. 在你的应用程序中实现登录功能:根据你所使用的编程语言和框架,找到适当的库或插件来帮助你实现 GitHub 第三方登录功能。不同语言和框架可能有不同的实现方式,你可以参考 GitHub 的官方文档或搜索相关示例代码。 5. 配置登录回调处理:当用户使用 GitHub 登录成功后,GitHub 会将用户重定向到你在步骤 2 中设置的回调 URL。在你的应用程序中,需要处理这个回调请求,并从中提取授权码或访问令牌。使用这些令牌,你可以与 GitHub API 进行交互,获取用户的信息或执行其他操作。 6. 使用 GitHub API:一旦用户成功登录并授权你的应用程序,你可以使用 GitHub API 访问用户的存储库、个人信息等。根据你的需求,调用适当的 API 端点来获取所需的数据。 这些步骤涵盖了一个基本的 GitHub 第三方登录接入流程。具体实现方式可能因你所使用的编程语言和框架而有所不同,但上述步骤应该能够帮助你开始进行接入。记得在实际开发过程中查阅相关文档和示例代码,以确保正确地实现登录功能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值