在laravel进行注册我在Laravel中使用加密算法来代替内置的bcrypt函数,因为获取密码并在忘记密码时将其发送到邮件.
但解密它显示的错误就像
<code>DecryptException The MAC is invalid in Encrypter.php (line 184) </code>
这个,当我运行这个代码时,它正在本地工作但服务器本身它不工作下面我提到了代码,任何人都可以请帮助
<code>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"; } } </code>
解决方法:
问题是您生成了一个新的APP_KEY,然后如果您尝试解密旧的加密数据,它将显示DecryptException:MAC无效.
如果要解密旧数据,则需要恢复旧的APP_KEY.
在意识到这一点之后,现在,在那里添加一个新问题,如果你用另一个APP_KEY或其他加密方法存储新数据,你就会对数据产生问题,因为它们在表上混合了.
如果您不知道何时开始使用新的加密方法或区分新的加密条目,最快的解决方案将使用新的加密方法重置所有密码.
您可以在官方Laravel docs上了解有关Laravel加密如何工作的更多信息.
【说明】:本文章由站长整理发布,文章内容不代表本站观点,如文中有侵权行为,请与本站客服联系(QQ:254677821)!