- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
原代码:
const token = jwt.sign({ _id: user._id }, process.env.JWT_SECRET, { expiresIn: '1d' });
res.cookie('token', token, { expiresIn: '1d' });
这成功了。 token 在创建后整整一天后过期。
变化:
const token = jwt.sign({ _id: user._id }, process.env.JWT_SECRET, { expiresIn: '1m' });
res.cookie('token', token, { expiresIn: '1m' });
我注销了,重启了服务器,还是没有任何变化! token 仍将自己设置为一天后过期。我正在学习一门类(class),当类(class)讲师在他的代码中进行此更改时,它按预期工作。 token 在一分钟后过期。
我什至试过:
const token = jwt.sign({ _id: user._id }, process.env.JWT_SECRET, { expiresIn: '10' });
res.cookie('token', token, { expiresIn: '10' });
期望 token 在十秒或十毫秒后过期(我不确定默认单位是什么)但结果仍然相同。 token 仍设置为一天后过期。
这是缓存的东西吗?我对缓存的了解几乎为零,它是什么,它是如何工作的,但我很难想象对此的解释是在 NodeJS 编码本身的常规范围内。如果是的话,那将是非常简单的。 jwt 模块或我的应用程序在整个应用程序中处理 cookie 或 token 的方式没有其他“配置”。
我包含了 next.js 标签,因为我在 next.js 应用程序中使用它(虽然我怀疑它是否相关,当然我可能是错的)。
最佳答案
我想通了。不要责怪任何对潜在解决方案发表评论的人,因为缺少我没有意识到的信息。
这是一个 NextJS 应用程序,前端有单独的逻辑来设置这个 cookie 的过期日期。此到期日期设置为一天,我没有更改它(我忘记它存在)。一旦我更改它,更改就会反射(reflect)在浏览器中。
我想您可以为已签名的 jwt 设置一个与前端的 cookie 过期日期不同的过期日期。这是多余的,也是不可取的。我将不得不寻找一个不同的长期解决方案。我认为这对现实世界的应用程序没有好处,因为它很难理解正在发生的事情。
今天早上早些时候,在我弄清楚这一点之前,10 毫秒的 jwt 过期终于开始起作用了,但仅限于后端。我收到一个后端错误,说我的 jwt session 已过期,这是意料之中的。在我的前端页面上向后端发出的请求失败,因为它没有经过身份验证,所以我得到了预期的行为,但不是我期望的那样。
编辑:我相信我已经找到了困惑的症结所在。下面的代码是旨在在响应中设置 cookie 的后端代码,但是因为我们使用单独的逻辑在前端设置 cookie,所以我相信这段代码实际上没有做任何事情。我查看了前端代码接收签名的 jwt token ,但没有引用 res.cookie 的地方。我相信这一定只是教师认为必要的额外代码行。我今天没时间了,但我会尝试在没有这行代码的情况下运行该应用程序,看看我是否能获得相同的功能。
res.cookie('token', token, { expiresIn: '1d' });
关于这个:
I guess you can set an expiration date for the signed jwt that isseparate from the cookie expiration date on the front end. It'sredundant and not desirable. I'll have to look for a differentlong-term solution. I wouldn't find this to be good for real worldapplications as it makes it difficult to understand what is happening.
我开始明白,这是一个额外的安全层,值得拥有。问题不在于后端的 jwt 逻辑。这里的问题很简单,我有额外的逻辑在浏览器中的两个不同位置设置 cookie,并调整了应用程序和浏览器未使用的逻辑。
关于node.js - JWT 签名 token 过期即使在代码中更改后浏览器应用程序中也不会更改,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63078402/
我正在开发一个应用程序,它使用 OAuth - 基于 token 的身份验证。 考虑到我们拥有访问和刷新 token ,这就是流程的样子。 Api call -> intercepter append
如何取消标记此代码的输出? 类(class)核心: def __init__(self, user_input): pos = pop(user_input) subject = ""
当我使用命令 kubectl 时与 --token标记并指定 token ,它仍然使用 kubeconfig 中的管理员凭据文件。 这是我做的: NAMESPACE="default" SERVICE
我正在制作 SPA,并决定使用 JWT 进行身份验证/授权,并且我已经阅读了一些关于 Tokens 与 Cookies 的博客。我了解 cookie 授权的工作原理,并了解基本 token 授权的工作
我正在尝试从应用服务获取 Google 的刷新 token ,但无法。 日志说 2016-11-04T00:04:25 PID[500] Verbose Received request: GET h
我正在开发一个项目,只是为了为 java 开发人员测试 eclipse IDE。我是java新手,所以我想知道为什么它不起作用,因为我已经知道该怎么做了。这是代码: public class ecli
我正在尝试使用 JwtSecurityTokenHandler 将 token 字符串转换为 jwt token 。但它出现错误说 IDX12709: CanReadToken() returned
我已阅读文档 Authentication (来自 Facebook 的官方)。我仍然不明白 Facebook 提供的这三种访问 token 之间的区别。网站上给出了一些例子,但我还是不太明白。 每个
我的部署服务器有时有这个问题,这让我抓狂,因为我无法在本地主机中重现,我已经尝试在我的 web.config 中添加机器 key ,但没有成功远。 它只发生在登录页面。 我的布局:
我已经设法获得了一个简单的示例代码,它可以创建一个不记名 token ,还可以通过阅读 stackoverflow 上的其他论坛来通过刷新 token 请求新的不记名 token 。 启动类是这样的
如果我有以前的刷新 token 和使用纯 php 的访问 token ,没有 Google Api 库,是否可以刷新 Google Api token ?我在数据库中存储了许多用户刷新和访问 toke
我通过 Java 应用程序使用 Google 电子表格时遇到了问题。我创建了应用程序,该应用程序运行了 1 年多,没有任何问题,我什至在 Create Spreadsheet using Google
当我有一个有效的刷新 token 时,我正在尝试使用 Keycloak admin REST API 重新创建访问 token 。 我已经通过调用 POST/auth/realms/{realm}/p
我正在尝试让第三方 Java 客户端与我编写的 WCF 服务进行通信。 收到消息时出现如下异常: Cannot find a token authenticator for the 'System.I
在尝试将数据插入到我的 SQl 数据库时,我收到以下错误 System.Data.SqlServerCe.SqlCeException: There was an error parsing the
使用数据库 session token 系统,我可以让用户使用用户名/密码登录,服务器可以生成 token (例如 uuid)并将其存储在数据库中并将该 token 返回给客户端。其上的每个请求都将包
我最近注册了 Microsoft Azure 并设置了认知服务帐户。使用 Text Translation API Documentation 中的说明我能够使用 interactive online
我使用 IAntiforgery API 创建了一个 ASP.Net Core 2 应用程序。 这提供了一种返回 cookie 的方法。 客户端获取该 cookie,并在后续 POST 请求中将该值放
我正在使用 spacy 来匹配某些文本(意大利语)中的特定表达式。我的文本可以多种形式出现,我正在尝试学习编写一般规则的最佳方式。我有如下 4 个案例,我想写一个适用于所有案例的通用模式。像这样的东西
我无法理解 oauth 2.0 token 的原则处理。 我的场景是,我有一个基于 web 的前端后端系统,带有 node.js 和 angular 2。用户应该能够在此站点上上传视频。然后创建一些额
我是一名优秀的程序员,十分优秀!