繁体   English   中英

设计令牌身份验证使用密码重置令牌查找用户

[英]devise token auth find user with password reset token

我正在使用devise令牌身份验证,并且正在设置密码重置过程。 当我单击电子邮件中的重置链接时,它具有url参数reset_password_token=hK3yxC1zVZCbWL8WgqKM但是在Rails控制台中时,

2.5.1 :004 > User.first.reset_password_token
  User Load (0.6ms)  SELECT  "users".* FROM "users" ORDER BY "users"."id" ASC LIMIT $1  [["LIMIT", 1]]
 => "ab432079e4e8aacfa0ecb5df17a7cea169990b0e0809ea9553248064220471a7" 

这些令牌不匹配,但它们应该匹配。 是否以某种方式编码,如果可以,我如何找到具有令牌的用户?

存储在数据库中的是Digest::SHA256

token = "hK3yxC1zVZCbWL8WgqKM"
Digest::SHA256.hexdigest token
#⇒ "ae74625ac2357c8f2de0f3f52647aaee191dbba5d383f8ec5822cfec5c24384e"

一个人显然不能将其还原为令牌,只能hexdigest来自用户的令牌并将其与数据库中存储的令牌进行比较。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM