- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在引用另一篇 SO 文章,该文章讨论了将刷新 token 与 JWT 一起使用。
JWT (JSON Web Token) automatic prolongation of expiration
我有一个具有非常通用架构的应用程序,其中我的客户端(Web 和移动)与 REST API 通信,然后与服务层和数据层通信。
我了解 JWT token 身份验证,但我对如何使用刷新 token 感到有些困惑。
我希望我的 JWT 身份验证具有以下属性:
最佳答案
让我稍后再回答您的问题,并从实际讨论刷新 token 的整个目的开始。
所以情况是:
用户打开应用程序并提供他的登录凭据。现在,该应用很可能正在与 REST 后端服务进行交互。 REST 是无状态的,无法授权访问 API。因此,到目前为止,在讨论中,没有办法检查授权用户是否正在访问 API 或只是一些随机请求正在通过。
现在为了能够解决这个问题,我们需要一种方法来知道请求来自授权用户。所以,我们所做的是引入一种叫做访问 token 的东西。所以现在一旦用户成功通过身份验证,他就会获得一个访问 token 。这个 token 应该是一个长且高度随机的 token (以确保它不能被猜到)。这就是 JWT 出现的地方。现在您可能/可能不想在 JWT token 中存储任何特定于用户的详细信息。理想情况下,您只想在 JWT 中存储非常简单、非常不敏感的细节。 JWT 哈希操作以检索其他用户的详细信息(IDOR 等)由 JWT(正在使用的库)本身负责。
所以,现在,我们的授权访问问题已经解决。
现在我们谈论一个攻击场景。假设使用上述所有用户 Alice,使用该应用程序,拥有授权访问 token ,现在她的应用程序可以向所有 API 发出请求并根据她的授权检索数据。
假设 不知为何 Alice 丢失了访问 token ,或者换句话说,对手 Bob 可以访问 Alice 的访问 token 。现在,尽管未经授权,Bob 可以向 Alice 授权的所有 API 发出请求。
我们不想要的东西。
现在这个问题的解决方案是:
关于oauth-2.0 - 使用 JWT token 身份验证时是否真的需要刷新 token ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32060478/
这个问题在这里已经有了答案: 关闭 12 年前。 Possible Duplicate: Why can't Python handle true/false values as I expect?
我是不是遗漏了什么或者这是 ruby 中的错误? a = %w(foo bar baz) a.include? "foo" # => true a.size == 3
从 Modelica 文档来看,注释 Evaluate 似乎只对参数有影响: https://build.openmodelica.org/Documentation/ModelicaReferenc
为了避免嵌套的 if 语句并提高可读性,我想创建一个switch(true){ ... } Coldfusion 中的声明。我在 php 中经常使用这个,但是当我在 Coldfusion 中尝试这个时
嗨,我正在尝试处理 ajax json 响应 这是我的代码 success: function (j) { switch(true) { case (j.cho
我之前在我的 TF 代码中使用过这个: count = "${var.whatever == "true" ? 1 : 0}" 这非常适合我想要使用的东西。但是,我正在考虑如何最好地使用类似于说的
我之前在我的 TF 代码中使用过这个: count = "${var.whatever == "true" ? 1 : 0}" 这非常适合我想要使用的东西。但是,我正在考虑如何最好地使用类似于说的
这个问题在这里已经有了答案: How can I return pivot table output in MySQL? (10 个答案) 关闭 5 年前。 我正在尝试构建一个以唯一列值作为列名的表
我制作了一个简单的 JDialog,其中包含一个标签和一个按钮,它基本上相当于信息对话框。所以在对话框中,有一个方法 display() 我在其中调用了 setVisible(true) 五次。 据我
在 bash 4.2.8(1)-release (x86_64-pc-linux-gnu) 在 Ubuntu 11.04 上这个命令 [ $(wc -l /var/www/some.log|cut -
我正在使用 c 语言进行并发处理,我有一个进程池。为此,我让每个 child 都在一个 While (True) 循环中。为了杀死 child ,我正在使用一个全局变量和一个信号处理程序来修改它来打破
我正在尝试选择填写了字段的数据库条目。数据库有两种插入数据的方式,一种输入评论,一种不输入,我希望只选择填写了评论的行。 $requete = "SELECT * FROM daysoff WHER
如何在 JavaMail session 中setDebug(true) 捕获流并在我的日志记录框架中使用它? (缺少下载源代码,更改接受流作为参数的方法,重新编译它,...) 更一般地说,Java
我是 JavaScript 的新手,我刚刚发现了我无法理解的奇怪行为: var magicVar = Math.sin; magicVar == true; // it returns false m
对此感到困惑。 在两台服务器上运行相同版本的 MySQL。 (从完全相同的 rpm 构建)- 沿线的某个地方,一些开发人员改变了一些东西...... 服务器 1: mysql> select ( no
我在查看 OpenSSL 中使用的一些预处理器宏时,从 crypto/stack/safestack.h 中发现了以下内容: #define CHECKED_STACK_OF(type, p) \
所以我遇到了一个问题,我的正则表达式看起来像这样:/true|false/。 当我检查单词 falsee 时,我从这个正则表达式中得到一个 true,有没有办法将它限制为确切的 true 或 fals
我正在对这个恶意 JavaScript 行进行一些试验:var undefined = true; JavaScript 中每个未初始化的变量都有 undefined 的值,这只是一个保存特殊值 'u
我想将 PHP 的微时间存储为我在 MySQL 中的时间戳。 我去过told最好用 DECIMAL 存储它,但我找不到理想的大小。 有谁知道 microtime(true) 返回的最大大小是多少,所以
在 PHP 中,当您在 URL 中包含诸如“var=true”之类的内容时,URL 中的“true”和“false”是否被转换为 boolean 变量,或者它们是否等于文本“true”还是“假”?例如
我是一名优秀的程序员,十分优秀!