首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >对于假字符串数据,Bcrypt.Net.Verify返回true

对于假字符串数据,Bcrypt.Net.Verify返回true
EN

Stack Overflow用户
提问于 2013-09-24 01:13:16
回答 1查看 784关注 0票数 0

我使用一个带有salt数据的字符串通过BCrypt.Net库来散列密码。

代码:

代码语言:javascript
复制
string src = Salt + UserName + Key + Password
var hash = Bc.HashPassword(src, 12);

当我尝试使用错误的字符串数据(例如,不同的密码)验证散列数据时,BCrypt.Verify(wrongStr,hash)返回的值为true

有什么想法吗?字符串的长度有限制吗?

EN

回答 1

Stack Overflow用户

发布于 2013-11-08 15:00:48

bcrypt返回60个字符的字符串,确保您的文件可以处理该字符串

并且您的验证是错误的,您需要使用布尔值!

代码语言:javascript
复制
string myPassword = "password";
string mySalt = BCrypt.GenerateSalt();
//mySalt == "$2a$10$rBV2JDeWW3.vKyeQcM8fFO"
string myHash = BCrypt.HashPassword(myPassword, mySalt);
//myHash == "$2a$10$rBV2JDeWW3.vKyeQcM8fFO4777l4bVeQgDL6VIkxqlzQ7TCalQvla"


bool doesPasswordMatch = BCrypt.CheckPassword(myPassword, myHash);
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18965072

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档