Qt实现单点登录功能,使用OAuth2.0协议

为什么写这篇博客

最近项目中需要在客户端的Qt程序中实现单点登陆功能(SSO),越看越像是加瓦老哥们做的呀,我区区一个C/C++底层开发咋搞呀,网上关于Qt的单点登陆的资料少之又少,硬着头皮干了,好在实现了一个简单版本的,简单记录下

如何申请第三方应用来做授权?

这里使用Gitee作为第三方进行授权

  1. 登陆gitee在这里插入图片描述

  2. 第三方应用
    在这里插入图片描述

  3. 创建第三方应用
    在这最重要的是回调地址的填写,后面会讲如何填

  4. 创建HTTP服务端程序
    服务端程序运行在Linux端,下面是代码

文件夹目录结构

//安装node.js
//npm init -y
//npm install express

project-directory/
│
├── public/
│   └── login.html
│
└── app.js

app.js

// app.js
const express = require('express');
const app = express();
const port = 8090;

// 静态文件服务,用于提供登录页面
app.use(express.static('public'));

// 根路由,用于接收回调并显示欢迎页面
app.get('/', (req, res) => {
   
   
    // 从请求中获取参数
    const code = req.query.code;
    const username = req.query.username;

    // 处理授权码或本地登录
    if (code || username) {
   
   
        res.send(`<h1>欢迎!</h1><p>Received authorization code: ${
     
     code || ''}</p><p>Welcome, ${
     
     username || 'User'}!</p>`);
    } else {
   
   
        res.redirect('/login');
    }
});

// 登录路由,显示登录页面
app.get('/login', (req, res) => {
   
   
    res.s
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值