当前位置: 首页 > news >正文

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 配置:

GITHUB_CLIENT_ID = 'your_client_id_here'
GITHUB_CLIENT_SECRET = 'your_client_secret_here'

3. 安装依赖

后端依赖
# 使用 uv (推荐)
uv sync# 或使用 pip
pip install flask flask-cors requests
前端依赖
npm install

4. 启动应用

启动后端服务器
# 使用 uv
uv run python app.py# 或直接运行
python app.py

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

启动前端开发服务器
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 仓库列表
http://www.lryc.cn/news/573466.html

相关文章:

  • 闲庭信步使用SV进行图像处理系列教程介绍
  • 2025年- H83-Lc191--139.单词拆分(动态规划)--Java版
  • 吴恩达:从斯坦福到 Coursera,他的深度学习布道之路
  • C++基础练习-二维数组
  • C++ 文件读写
  • GPT-1 与 BERT 架构
  • 开源项目分析:EDoRA | 了解如何基于peft实现EDoRA方法
  • 【软考高级系统架构论文】论无服务器架构及其应用
  • 博图SCL语言GOTO语句深度解析:精准跳转
  • 深入解析ID3算法:信息熵驱动的决策树构建基石
  • GO语言---数组
  • 基于Spring Boot瀚森健身房会员管理系统设计与实现【源码+文档】
  • 作为测试人员,平时用什么大模型?怎么用?
  • 《深入解析:如何通过CSS集成WebGPU实现高级图形效果》
  • 【软考高级系统架构论文】论企业应用系统的数据持久层架构设计
  • 【FineDance】舞蹈多样性的得来
  • RocketMQ--为什么性能不如Kafka?
  • verilog HDLBits刷题“Module cseladd”--模块 cseladd---Carry-select adder 进位选择adder
  • 为车辆提供路径规划解决方案:技术演进、挑战与未来蓝图
  • 【appium】2.初始连接脚本配置
  • C++模板基础
  • 【AGI】突破感知-决策边界:VLA-具身智能2.0
  • 用OBS Studio录制WAV音频,玩转语音克隆和文本转语音!
  • 《揭开CSS渲染的隐秘角落:重排与重绘的深度博弈》
  • 【StarRocks系列】查询优化
  • 操作系统进程与线程核心知识全览
  • 前端开发面试题总结-vue3框架篇(二)
  • 钉钉智能会议室集成指纹密码锁,临时开门密码自动下发
  • 前端登录不掉线!Vue + Node.js 双 Token 无感刷新方案
  • 爱高集团引领转型浪潮:AI与区块链驱动香港科技资本新机遇