飞书三方登录功能实现与行业思考

需求背景

近期在原有后台账号密码登录功能基础上,增加了飞书三方登录功能,主要解决两个问题:

  1. 方便经常忘记密码的同事快速登录系统
  2. 新同事入职时可通过飞书自动创建账号,只需上级分配权限即可
  3. 同事离职后,无需手动禁用账号,通过飞书权限控制自然拦截

飞书三方登录实现

流程图解

详细流程参考 飞书官方文档

实现特点

创建企业自建应用 后,在安全设置中配置重定向地址即可使用,甚至支持 https://localhost:6120 本地测试,这与其他三方登录平台相比更加便捷。

用户信息处理方案

  • 获取用户唯一ID作为账号
  • 密码设置为随机数
  • 沿用原有创建新账号流程

老用户绑定方案思考

最初考虑最小化变动,但在流程设计中发现问题。最终采用 登录与绑定分离 的方案:

  1. 登录是登录流程绑定是绑定流程
  2. 增加专门入口供老用户绑定飞书账号
  3. 数据库增加 third_party_id 字段存储用户唯一ID
  4. 登录时优先查询 third_party_id 字段

移动端兼容性问题与解决方案

问题发现

第一版方案:

登录页A点击飞书登录 → 打开B页面 → 完成登录 → 通过 window.opener.postMessage 通知父页面 → 关闭当前页 → A页面提示登录成功

PC端正常,但移动端出现跨源问题

解决方案

javascript 复制代码
function listenEvent(event) {
    // 安全检查:验证消息来源(兼容http和https)
    const currentOrigin = window.location.origin;
    const eventOrigin = event.origin;
    // 检查是否为同域不同协议的情况
    const isSameDomain = eventOrigin.replace(/^https?:/, '') === currentOrigin.replace(/^https?:/, '');
    
    if (!isSameDomain) {
        console.warn('收到来自不受信任域名的消息:', event.origin);
        return;
    }
    
    handleThirdLoginResult(event.data);
}

同时增加 BroadcastChannel 通信作为兜底方案

iOS Safari特殊处理

针对 iOS Safari 不支持 window.open 方法的问题,采用 localStorage 存储源页面地址,登录完成后跳转回原页面。

行业变化与AI发展思考

Cursor 等AI编码助手已经达到高级前端工程师水平,能够:

  • 🚀 快速解决积累的技术问题
  • 💡 提供优质的技术方案
  • 🌐 扩大技术视野,提高开发下限

这种变化意味着:

  • ⚖️ 技术门槛降低,技术垄断被打破
  • 🔥 行业竞争加剧,用工成本下降
  • 📚 开发者需要更加关注自身健康持续学习能力

健康 > 心态 > 赚钱 ------ 这才是技术人员应当坚持的价值排序。

相关推荐
广州华水科技9 分钟前
单北斗变形监测一体机在基础设施安全与地质灾害监测中的应用价值分析
前端
钟智强9 分钟前
React2Shell:CVE-2025-66478 Next.js 远程执行漏洞深度分析与代码剖析
开发语言·javascript·ecmascript
Dragon Wu15 分钟前
Electron Forge集成React Typescript完整步骤
前端·javascript·react.js·typescript·electron·reactjs
芳草萋萋鹦鹉洲哦15 分钟前
【Tailwind】动画解读:Tailwind CSS Animation Examples
前端·css
华仔啊18 分钟前
jQuery 4.0 发布,IE 终于被放弃了
前端·javascript
一心赚狗粮的宇叔23 分钟前
03.Node.js依赖包补充说明及React&Node.Js项目
前端·react.js·node.js
子春一25 分钟前
Flutter for OpenHarmony:音律尺 - 基于Flutter的Web友好型节拍器开发与节奏可视化实现
前端·flutter
JarvanMo25 分钟前
150万开发者“被偷家”!这两款浓眉大眼的 VS Code 插件竟然是间谍
前端
亿元程序员26 分钟前
大佬,现在AI游戏开发教程那么多,你不搞点卖给大学生吗?
前端
龙山云仓26 分钟前
MES系统超融合架构
大数据·数据库·人工智能·sql·机器学习·架构·全文检索