【问题标题】:How to safely Store J.W.T token using java Script or angular?如何使用 javaScript 或 Angular 安全地存储 J.W.T 令牌?
【发布时间】:2019-03-07 16:18:04
【问题描述】:

我找到了 3 种方法将其保存在客户端(本地存储/会话存储/cookies)..但这不够安全。因为客户端或黑客可以修改或替换为另一个有效的重新生成的 J.W.T 令牌。 我想以加密方式或无法破解的方式存储令牌... 请告诉我专业的工作方式或存储 access_token....

【问题讨论】:

  • 不要把它存储在客户端,这样会保证安全。
  • 将其存储在 HttpOnly/Secure cookie 中可能是最安全的,同时将其与用于 CSRF 令牌的 Secure cookie 一起存储。但是您将无法访问存储的数据。
  • “因为客户端或黑客可以修改或替换为另一个有效的重新生成的 JWT 令牌。我想以加密方式或无法破解的方式存储令牌”此语句表明您对 JWT 的工作方式存在根本性的误解。如果您正确签署它们,黑客就不可能修改或替换它们。此外,如果您也愿意,该规范还允许加密以隐藏有效负载。

标签: javascript angularjs node.js jwt access-token


【解决方案1】:

“这不够安全。因为客户端或黑客可以修改或替换为另一个有效的重新生成的 J.W.T-token”

所以,虽然我不确定您的具体应用程序要求,但我会这样说:通过 cookie 存储在客户端是可行的方法... cookie 不易受 XSS 攻击,CSRF 是一个简单的修复与现代框架。例如。仅通过 HTTPS 发送 JWT cookie 并设置 HttpOnly 标志(可能还有 Secure 标志)。这是一种非常标准的做法,因为它比网络存储更安全。 Check out this article from stormpath

【讨论】:

  • 无论如何,@Paul 的评论是完全正确的。无论您将 jwt 存储在哪里,如果有人修改或替换为另一个令牌,API 安全机制必须能够检测到它。
猜你喜欢
  • 2019-02-20
  • 2019-11-26
  • 2012-09-11
  • 2013-05-17
  • 2021-05-02
  • 1970-01-01
  • 2019-06-13
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多