在 Laravel 中进行注册时,我使用密码加密算法而不是 Laravel 中内置的 bcrypt 函数,因为要获取密码并在忘记密码时将其发送到邮件。
但解密它显示错误,例如
DecryptException The MAC is invalid in Encrypter.php (line 184)
这,当我运行此代码时,它在本地工作,但服务器本身无法工作,下面我提到了代码,任何人都可以帮忙
public function forgotpassword(Request $request)
{
$email=$request->email;
$selectemail = User::select('email','password','name')
->where('email',$email)
->first();
if($selectemail)
{
$password=decrypt($selectemail->password);
$data = array( 'email' => $selectemail->email,'password' => $password , 'name' => $selectemail->name);
Mail::send('email.resetpassword',$data,function($message) use ($email)
{
$message->to([$email])->subject('Forgot Password Letgo');
});
echo "Mail has sent successfully";
} else {
echo "This email is not yet registered";
}
}
问题是您生成了一个新的 APP_KEY,那么如果您尝试解密旧的加密数据,它将显示DecryptException: The MAC is invalid
.
如果您想解密旧数据,您需要恢复旧的 APP_KEY。
意识到这一点后,现在在那里添加一个新问题,如果您使用另一个 APP_KEY 或其他加密方法存储新数据,那么数据就会出现问题,因为它们混合在表中。
如果您不知道什么时候开始使用新的加密方法或区分新的加密条目,最快的解决方案是使用新的加密方法重置所有密码。
你可以在官方了解更多关于 Laravel 加密是如何工作的Laravel 文档 https://laravel.com/docs/5.7/encryption.
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)