• 统一身份认证登录详细介绍-identity4


     实现细节

    RDC的统一身份认证中心使用的是 identity4,前端对接的js框架是 oidc-client-js,而这个框架默认是不支持 VUE 使用的 ES6 的模块,所以需要手动修改,在 oidc-client.min.js 文件的最后添加:

    export default Oidc

    这样才能在 VUE 项目中通过 import 引入:

    import Oidc from '../utils/oidc-client.min'

    RDC 是通过在主框架 layout.vue 组件的 beforeRouteEnter 路由守护函数中检测是否在身份认证中心登录来处理进一步的路由跳转,而不是 identify4 官方示例中的 callback.html 跳转页面切换:

    1. beforeRouteEnter (to, from, next) {
    2. // 已经登录了
    3. if (getToken()) {
    4. // 直接进入到访问页面
    5. toNext(next)
    6. } else {
    7. // 调用统一身份认证库的方法,获取用户登录信息
    8. new Oidc.UserManager({response_mode: 'query'}).signinRedirectCallback().then((user) => {
    9. // 已经登录
    10. if (user) {
    11. let url = user.state
    12. // 缓存统一身份认证的用户信息
    13. localStorage.setItem('rdc.identity.user', JSON.stringify(user))
    14. // 创建 Oidc.UserManager 实例
    15. $mgr = new Oidc.UserManager(DEV_CONFIG)
    16. // 登录跳转
    17. signIn(user, next, url)
    18. } else {
    19. $mgr = new Oidc.UserManager(DEV_CONFIG)
    20. checkSignIn(next)
    21. }
    22. }).catch((err) => {
    23. console.log('认证错误信息:', err)
    24. // 跳转到登录页面
    25. let currentPath = `${location.pathname + location.search}`
    26. next(`/login?returnUrl=${currentPath}`)
    27. })
    28. }
    29. }

    其中 DEV_CONFIG 是通过在RDC后台的认证授权添加授权应用获取到的,获取到类似的配置:

    1. export const DEV_CONFIG0 = {
    2. // 配置中心的地址
    3. 'authority': 'http://localhost:5000',
    4. // 注册的客户ID
    5. 'client_id': 'rdc-localhost',
    6. // 接入认证站点在认证中心登录有跳转的地址
    7. 'redirect_uri': 'http://localhost:5001/console',
    8. 'response_type': 'code',
    9. // 授权的 API 或者服务
    10. 'scope': 'openid profile defaultApi rdc-file-service rdc-resourcecenter-service',
    11. // 接入站点未登录的跳转地址
    12. 'post_logout_redirect_uri': 'http://localhost:5001/login',
    13. 'response_mode': 'query'
    14. }
    post_logout_redirect_uri(http://localhost:5001/login) 页面的处理方式:
    1. <script>
    2. // isString,
    3. import {getQuery} from '../../utils/utils'
    4. import Oidc from '../../utils/oidc-client.min'
    5. import {DEV_CONFIG} from '../../identity-config'
    6. export default {
    7. name: 'login',
    8. created () {
    9. let query = getQuery()
    10. let url = query && query.returnUrl ? query.returnUrl : '/'
    11. localStorage.setItem('rdc.return.url', url)
    12. this.loadData()
    13. },
    14. methods: {
    15. loadConfig () {
    16. let query = getQuery()
    17. let url = query && query.returnUrl ? query.returnUrl : '/'
    18. this.$mgr = new Oidc.UserManager(DEV_CONFIG)
    19. this.$mgr.signinRedirect({
    20. state: url
    21. })
    22. },
    23. loadData () {
    24. return this.loadConfig()
    25. }
    26. }
    27. }
    28. script>

    这个页面是一个空白页,主要是用来获取配置,并调用 signinRedirect 跳转到认证中心。只是使用了一个hack技巧,使用 state 参数传递用户当前访问的页面,以便用户在认证中心页面登录后,直接进入用户要访问的目标页面:

    1. // 获取地址栏的query信息
    2. let query = getQuery()
    3. // 获取跳转登录前用户正在访问的页面地址
    4. let url = query && query.returnUrl ? query.returnUrl : '/'
    5. this.$mgr = new Oidc.UserManager(DEV_CONFIG)
    6. this.$mgr.signinRedirect({
    7. // 通过 state 传递地址
    8. state: url
    9. })

    与这里的 state 相关对应的就是登录成功页面这样的处理方式:

    1. // 调用统一身份认证库的方法,获取用户登录信息
    2. new Oidc.UserManager({ response_mode: 'query' }).signinRedirectCallback().then((user) => {
    3. // 已经登录
    4. if (user) {
    5. // 登陆有后,用户信息的 state 会返回登陆前要访问的目标地址
    6. let url = user.state
    7. // 缓存统一身份认证的用户信息
    8. localStorage.setItem('rdc.identity.user', JSON.stringify(user))
    9. // 创建 Oidc.UserManager 实例
    10. $mgr = new Oidc.UserManager(DEV_CONFIG)
    11. // 登录跳转
    12. signIn(user, next, url)
    13. } else {
    14. $mgr = new Oidc.UserManager(DEV_CONFIG)
    15. checkSignIn(next)
    16. }
    17. }).catch((err) => {
    18. console.log('认证错误信息:', err)
    19. // 跳转到登录页面
    20. let currentPath = `${location.pathname + location.search}`
    21. next(`/login?returnUrl=${currentPath}`)
    22. })

    IE11 兼容问题

    oidc-client-js 框架默认扩展了ES6方法,注册了 babel-polyfill,而之前处理IE兼容问题也单独引入过 babel-polyfill,同时引入两个 babel-polyfill 就会报错,不允许这么处理。需要去掉单独引入的 polyfill,或者拉取 oidc-client.js 的代码,移除 babel-polyfill 引用,RDC 采用直接移除单独引入的(移除 oidc-client.js 比较麻烦)。

    移除单独引入的 polyfill 还有问题,因为 oidc-client.js 的 polyfill 是通过闭包函数传递的,算是一个私有的对象,VUE 项目中是无法引用扩展的方法的。而 RDC 引入的另外一个处理日期JS库 luxon.js 调用了ES6的 Object.assign() 方法,为了兼容IE11(IE11没有该方法),我们需要全局扩展 Object.assign() 方法,在index.html文件中添加内联的JS代码块。

     

  • 相关阅读:
    Java连接PostGreSql
    java民宿运营管理网站计算机毕业设计MyBatis+系统+LW文档+源码+调试部署
    BI业务分析思维:供应链生产制造策略(四) MTS
    弘辽科技:淘宝国庆节活动什么时候结束?活动力度大吗?
    数仓工具—Hive进阶之Statistics与Analyze Table命令(20)
    《C++PrimePlus》第8章 函数探幽
    shiro-反序列化漏洞
    Observability:使用 Elastic Agent 来进行 Uptime 监控
    备库failover升级
    正则表达式的限定符、或运算符、字符类、元字符、贪婪/懒惰匹配
  • 原文地址:https://blog.csdn.net/qq_43340606/article/details/126524351