0

0

面向未来的身份验证:从规则和挂钩转向行动

花韻仙語

花韻仙語

发布时间:2024-10-27 09:15:02

|

390人浏览过

|

来源于dev.to

转载

面向未来的身份验证:从规则和挂钩转向行动

auth0 是一个身份和访问管理 (iam) 平台,可简化应用程序中身份验证和授权的管理。我们开发人员依靠 auth0 规则和 hooks 来自定义身份验证过程。然而,随着 auth0 actions 的引入,现在有一个更灵活、可维护和现代的解决方案来实现自定义身份验证逻辑。

为什么要迁移?
随着我们的应用程序的增长,管理规则和挂钩变得困难。
规则和挂钩都是按顺序运行的,如果其中一个影响另一个,则可能会导致意外结果,从而使故障排除变得困难。此外,hooks 需要单独管理,这增加了复杂性。

相比之下,虽然操作也按顺序运行,但它们被设计得更加模块化,使我们能够创建更小的、可重用的逻辑片段。这种模块化使得测试和修复各个操作变得更加容易,而无需担心它们如何相互交互。 actions 还提供了更好的调试工具和版本控制,简化了我们身份验证过程的整体管理。

规则和 hook 的限制:

auth0 中的规则是作为身份验证管道的一部分执行的 javascript 函数。虽然功能强大,但它们也有局限性:

  • 它们按顺序运行,这意味着管理多个规则变得很棘手。
  • 调试和测试可能具有挑战性。
  • 没有模块化,因此经常需要重复相同的逻辑。

hook 也有缺点:

  • 它们是事件驱动的,但仅限于某些场景,例如用户后注册。
  • 它们需要在常规身份验证管道之外进行单独管理。
  • 调试钩子并不那么简单。

行动的优点:
行动解决了许多这样的问题:

  • 它们允许更好的模块化。您可以在不同的应用程序中重复使用它们。
  • 您可以访问版本控制,这可以帮助您管理和回滚更改。
  • 测试和调试体验得到极大改善,拥有更好的日志和实时测试工具。
  • 操作可以与各种触发器相关联(登录后、用户前注册 等)并且可以通过统一的界面进行管理。

准备迁移

记录现有规则和挂钩:
在开始迁移之前,我们确保彻底记录和识别所有现有规则和挂钩的用例。这帮助我们更轻松地将功能映射到操作。

了解 auth0 操作:
操作是事件驱动的功能,在身份验证管道中的特定点(例如登录后或预注册)触发。它们是用 node.js 编写的,允许您以更加模块化和可重用的方式定义逻辑。

关键组件包括:
触发器:指定何时执行操作(例如,登录后、注册期间)。
事件处理程序:从触发操作的事件中捕获详细信息(例如,用户信息)。
秘密:存储 api 密钥等敏感数据
版本控制:管理操作的不同版本,以便更轻松地更新和回滚。

迁移示例:
让我们采用一个在登录时添加用户角色的简单规则:

function (user, context, callback) {
  // check the user's email domain
  if (user.email && user.email.endswith('@example.com')) {
    // assign a role for users with the specified domain
    user.app_metadata = user.app_metadata || {};
    user.app_metadata.roles = ['employee'];

    // update the user in the auth0 database
    auth0.users.updateappmetadata(user.user_id, user.app_metadata)
      .then(function() {
        callback(null, user, context);
      })
      .catch(function(err) {
        callback(err);
      });
  } else {
    // assign a default role for other users
    user.app_metadata = user.app_metadata || {};
    user.app_metadata.roles = ['guest'];

    callback(null, user, context);
  }
}

说明:
目的:此规则检查用户的电子邮件是否以@example.com 结尾。如果是,则为该用户分配“员工”角色。否则,他们将被分配“访客”的角色。
更新用户元数据:规则使用 auth0.users.updateappmetadata 将分配的角色保存在用户的应用元数据中。
回调:规则调用callback(null, user, context)来继续认证流程,如果发生错误则调用callback(err)。

将其迁移到操作如下所示:

AI改图神器
AI改图神器

AI万能图片编辑器,一键抠图,去水印,智能图片美化,照片转漫画,照片变活转视频,图片无损放大,一键背景虚化,位图智能转矢量图

下载
exports.onexecutepostlogin = async (event, api) => {
  // check the user's email domain
  if (event.user.email && event.user.email.endswith('@example.com')) {
    // assign a role for users with the specified domain
    api.user.setappmetadata('roles', ['employee']);
  } else {
    // assign a default role for other users
    api.user.setappmetadata('roles', ['guest']);
  }
};

事件和api:action使用事件获取用户信息,使用api修改用户元数据,而rule直接操作用户对象并使用回调。
异步性质:操作旨在更干净地处理异步操作,从而实现更简单的实现。

迁移规则的最佳实践:
保持较小的操作:将复杂的逻辑分解为更小、更易于管理的部分。
跨应用程序重用:以可在多个应用程序中使用的方式编写操作,以避免重复代码。

现在让我们用一个简单的钩子来添加角色:

挂钩是由特定事件触发的服务器端扩展,例如用户注册后。它们允许您将自定义逻辑集成到用户生命周期中。

示例 hook:

module.exports = function (client, scope, audience, context, cb) {

    let access_token = {
        scope: scope
    };

    if (client.name === 'myapp') {
        access_token["https://app/persona"] = "user";

        if (context.body.customer_id || context.body.upin) {
            return cb(new invalidrequesterror('not a valid request.'));
        }
    }
}

在一个动作中,它变成:

exports.onExecuteCredentialsExchange = async (event, api) => {
    let requestBody = event.request.body;
    if (event.client.name === 'MyApp') {
        api.accessToken.setCustomClaim(`https://app/persona`, "user");
        if (!requestBody.customer_id || !requestBody.upin) {
            api.access.deny(`Not a valid request for client-credential Action`);
            return
        }
    }

实施差异:

  • 操作为处理异步代码和错误处理提供了更好的工具。
  • 迁移过程通过集成日志跟踪简化了调试 ng.

测试和调试:
auth0 的操作界面使测试变得容易,具有实时日志和模拟事件的能力。我们广泛使用实时网络任务日志记录功能来确保操作按预期进行。

迁移后体验的好处:
性能改进:
我们观察到,动作运行得更快并且更可预测,因为规则的顺序执行通常会导致性能瓶颈。

简化的工作流程:
通过操作,管理自定义逻辑变得更加容易。我们现在拥有可在不同应用程序之间重用的模块化操作,从而减少代码重复。

可重用性和模块化:
操作提高了我们跨多个租户重用逻辑的能力。以前,我们必须为不同的应用程序重复规则,但现在,一个操作可以实现多种目的。

要避免的常见陷阱:
执行顺序误解:
如果您正在运行多个操作,请确保了解它们的执行顺序。错误的执行顺序可能会导致分配不正确的用户角色等问题。

触发器配置错误:
仔细检查是否为您的操作分配了正确的触发器。
例如,将登录后操作附加到用户前注册事件将不起作用。

生产中测试:
始终首先在临时环境中进行测试。切勿将未经测试的操作直接部署到生产中。

总之,迁移到 auth0 actions 对我们来说改变了游戏规则。随着 auth0 于 2024 年 11 月 18 日弃用规则和挂钩,这一转变简化了我们的工作流程,提高了性能,并使管理身份验证逻辑变得更加容易。如果您仍然依赖规则和挂钩,那么现在是探索操作的最佳时机 - 您不会后悔的!

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

255

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

1153

2024.03.01

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

532

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

576

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

761

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

6357

2023.08.17

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

494

2023.09.01

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

Nginx跨平台安装实操指南:Windows、macOS与Linux环境快速搭建
Nginx跨平台安装实操指南:Windows、macOS与Linux环境快速搭建

本指南详解Nginx在Windows、macOS及Linux系统的安装全流程。涵盖官方包解压、Homebrew一键部署、APT/YUM源配置及Docker容器化方案。无论新手或开发者,均可快速搭建运行环境,掌握跨平台核心指令,为后续配置与调优奠定坚实基础。

10

2026.03.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
SQL 教程
SQL 教程

共61课时 | 4.4万人学习

10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号