首页 > 解决方案 > Laravel - Crypt::decrypt 的问题,代码中的语法错误

问题描述

我知道我的解决方案是错误的,但是有人可以用正确的语法帮助我解密我的字符串并登录吗?

Laravel API resivedcode和存储加密Database

api route

Route::post('data','DataImport@Insert');

controller

use Illuminate\Support\Facades\Crypt;

function Insert(Request $request)
{
    $user=new User();
     $user->code=Crypt::encrypt($request->input('code'));
    return $user->save();
}

Auth\Controller

use Illuminate\Support\Facades\Crypt;

public function postLogin(Request $request)
{
    request()->validate([
        'id_message' => 'required',
        'code' => 'required',
    ]);
   
    $credentials = $request->only('id_message', 'code');
    $decrypted = $request->input('code'); 
    $request->session()->flash('success');

    if ($user=User::where($credentials)->first()) {
        if (\Crypt::decrypt($user->code) == $decrypted) {
            Auth::login($user);
            
        return redirect()->intended('dashboard')->with('success');
        }
    }
    //dd($decrypted);

    return Redirect::back()->with('error');
}

dd($decrypted);

 array:1 [▼
 "code" => "123456"
]

解密code的值正确。laravel.log只有消息代码不匹配没有错误。

谢谢你的帮助。

(哈希解决方案,不要帮我解决这个问题)

标签: phplaravelauthenticationlaravel-5crypt

解决方案


如果有人有同样的问题。@lagbox 帮助我使用不正确的语法input,下面的参考链接提供了最终解决方案:

replace this:

$credentials = $request->only('id_message', 'sms_code');

to:

$user = User::where('id_message', $request->input('id_message'))->first();

if声明:

if ($user) {
    if (\Crypt::decrypt($user->code) == $decrypted) {
        Auth::login($user);
        return redirect()->intended('dashboard')->with('success');
        }
    }
    return Redirect::back()->with('error');
}    

参考链接:https ://stackoverflow.com/a/50891573/3681759


推荐阅读