首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Laravel::尝试不使用sha512

Laravel::尝试不使用sha512
EN

Stack Overflow用户
提问于 2022-02-02 18:18:48
回答 1查看 129关注 0票数 0

让我给你看一下准确的代码:

代码语言:javascript
复制
$credentials = array(
    'email' => $request->email,
    'password' => hash('sha512', $request->password)
);

现在返回true

代码语言:javascript
复制
User::where($credentials)->exists()

但是,这将返回false

代码语言:javascript
复制
Auth::attempt($credentials)

我正在使用sha512存储我的密码。为什么Auth::attempt返回false?

EN

回答 1

Stack Overflow用户

发布于 2022-02-02 19:16:17

Laravel Hash外观为存储用户密码提供了安全的BcryptArgon2哈希。

但是,您可以像这样创建自定义哈希:

代码语言:javascript
复制
$user = User::where([
    'email' => $request->email,
    'password' => hash('sha512', $request->password)
])->first();

if($user){
    Auth::login($user);
}

Bcrypt是哈希密码的一个很好的选择,因为它的“工作因子”是可调的,这意味着生成哈希的时间可以随着硬件功率的增加而增加。当散列密码时,慢一点是好的。算法哈希密码的时间越长,恶意用户生成所有可能的字符串哈希值的“彩虹表”所花费的时间就越长,这些字符串哈希值可能用于对应用程序的强力攻击。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70960795

复制
相关文章

相似问题

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