0

我正在处理 Laravel 5.6。我正在使用 JWT 身份验证,并且我创建了自己的身份验证控制器。

这是我在 AuthController 的恢复方法,

public function recover(Request $request)
{
    $user = User::where('email', $request->email)->first();
    if (!$user) {
        $error_message = "Your email address was not found.";
        return response()->json(['success' => false, 'error' => ['email'=> $error_message]], 401);
    }
    try {
        Password::sendResetLink($request->only('email'), function (Message $message) {
            $message->subject('Your Password Reset Link');
        });
    } catch (\Exception $e) {
        $error_message = $e->getMessage();
        return response()->json(['success' => false, 'error' => $error_message], 401);
    }
    return response()->json([
        'success' => true, 'data'=> ['message'=> 'A reset email has been sent! Please check your email.']
    ]);
}

在邮递员中,如果我执行恢复方法,我会收到此消息

{
    "success": false,
    "error": "Route [password.reset] not defined." 
}

我该如何处理。谢谢!

4

2 回答 2

1

在这种情况下,您需要为路线命名password.reset。在您routes.php(或您定义它们的任何地方)调用该name方法:

Route::post('/password/reset', 'AuthController@recover')->name('password.reset');
于 2018-02-13T11:05:35.160 回答
0

如果您还没有运行make:auth,则您没有定义路线,正如错误本身所说。
尝试在中定义以下路线routes/web.php

Route::post('/pwdreset', 'AuthController@recover')
    ->name('password.reset');
于 2018-02-13T11:04:17.683 回答