在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:MAC无效.
如果要解密旧数据,则需要恢复旧的APP_KEY.
在意识到这一点之后,现在,在那里添加一个新问题,如果你用另一个APP_KEY或其他加密方法存储新数据,你就会对数据产生问题,因为它们在表上混合了.
如果您不知道何时开始使用新的加密方法或区分新的加密条目,最快的解决方案将使用新的加密方法重置所有密码.
您可以在官方Laravel docs上了解有关Laravel加密如何工作的更多信息.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。