GitHub OAuth 认证示例

GitHub链接:github_auth

流程图

功能特性

  • ✅ GitHub OAuth 认证
  • ✅ 获取用户基本信息
  • ✅ 显示用户的 GitHub 仓库列表
  • ✅ 安全的会话管理
  • ✅ 响应式用户界面

技术栈

后端

  • Flask - Python Web 框架
  • Flask-CORS - 跨域资源共享
  • Requests - HTTP 库
  • Session - 会话管理

前端

  • React - 用户界面库
  • React Router - 路由管理
  • Axios - HTTP 客户端
  • CSS3 - 样式设计

项目结构

复制代码
github_auth/
├── app.py                 # Flask 后端应用
├── package.json          # Node.js 依赖配置
├── public/
│   └── index.html        # HTML 模板
├── src/
│   ├── App.js            # React 主应用组件
│   ├── App.css           # 应用样式
│   ├── index.js          # React 入口文件
│   └── components/
│       ├── Home.js       # 首页组件
│       ├── AuthSuccess.js # 认证成功页面
│       └── Dashboard.js  # 用户仪表板
└── README.md

快速开始

前置要求

  • Python 3.11+
  • Node.js 16+
  • GitHub 账号

1. 创建 GitHub OAuth 应用

  1. 访问 GitHub Developer Settings
  2. 点击 "New OAuth App"
  3. 填写应用信息:
    • Application name: GitHub Auth Demo
    • Homepage URL : http://localhost:3000
    • Authorization callback URL : http://localhost:5000/auth/github/callback
  4. 获取 Client IDClient Secret

2. 配置环境

app.py 中更新你的 GitHub OAuth 配置:

python 复制代码
GITHUB_CLIENT_ID = 'your_client_id_here'
GITHUB_CLIENT_SECRET = 'your_client_secret_here'

3. 安装依赖

后端依赖
bash 复制代码
# 使用 uv (推荐)
uv sync

# 或使用 pip
pip install flask flask-cors requests
前端依赖
bash 复制代码
npm install

4. 启动应用

启动后端服务器
bash 复制代码
# 使用 uv
uv run python app.py

# 或直接运行
python app.py

后端服务器将在 http://localhost:5000 启动

启动前端开发服务器
bash 复制代码
npm start

前端应用将在 http://localhost:3000 启动

5. 使用应用

  1. 打开浏览器访问 http://localhost:3000
  2. 点击 "使用 GitHub 登录" 按钮
  3. 在 GitHub 授权页面确认授权
  4. 成功登录后查看用户信息和仓库列表

API 端点

认证相关

  • GET /auth/github - 重定向到 GitHub OAuth 授权页面
  • GET /auth/github/callback - 处理 GitHub OAuth 回调
  • POST /api/logout - 用户登出

用户数据

  • GET /api/user - 获取当前登录用户信息
  • GET /api/repos - 获取用户的 GitHub 仓库列表
相关推荐
徐小夕10 分钟前
我们放弃了单Agent方案:HiCAD 3.0 用 Harness 做多Agent编排,把3D建模的准确率提升了30%
前端·算法·github
Java面试题总结23 分钟前
MarkItDown 再次登顶GitHub榜
开发语言·c#·github
佛系豪豪吖41 分钟前
AtomCode 部署流程与使用经验
笔记·chatgpt·github·ai编程·gitcode
王小王-1232 小时前
基于多种机器学习的豆瓣电影分析与可视化预测评估系统
人工智能·机器学习·flask·豆瓣电影·电影评分预测·影评分析·哪吒电影评论分析
宝桥南山2 小时前
GitHub Copilot - 尝试使用一下Azure Devops MCP server
microsoft·微软·github·aigc·copilot·devops
MicrosoftReactor2 小时前
技术速递|提升 GitHub Agentic Workflows 的 Token 使用效率
ai·github·copilot·智能体
DogDaoDao2 小时前
【GitHub】last30days-skill 深度技术解析
深度学习·程序员·大模型·github·ai agent·agent skill
IT WorryFree2 小时前
GitHub / Gitee / Gitea / GitLab 四平台完整对比(定位、优缺点、适用场景)
gitee·github·gitea
LoserChaser2 小时前
Flask 文件上传服务器 - 知识点总结
服务器·python·flask
Dontla2 小时前
Github Personal Access Token(个人访问令牌)添加workflow scope(更新GitHub Actions工作流文件必须)
github