电子邮件密码重设错误 link

Wrong password reset link on email

我在我的项目上使用多重授权,我的登录页面是:

myurl.com/login

myurl.com/admin/login

myurl.com/login 上的密码重置例程工作正常。但是当我在 myurl.com/admin/login 上尝试时,我在电子邮件中收到的重置 link 仍然是:

myurl.com/password/reset/XXXXXXXXXX

但应该是:

myurl.com/admin/password/reset/XXXXXXXXXX

如有任何帮助,我们将不胜感激。

尝试为管理员密码重置创建一个特定的路由,如果你没有在代码中指定它,一个路由不会走所有的守卫。 您还必须通过覆盖 Illuminate\Foundation\Auth\SendsPasswordResetEmails trait function

在 App\Http\Controllers\Auth\ForgotPasswordController class 的通知中使用 if 条件指定它
    public function sendResetLinkEmail(Request $request)
    {
        $this->validateEmail($request);
        // We will send the password reset link to this user. Once we have attempted
        // to send the link, we will examine the response then see the message we
        // need to show to the user. Finally, we'll send out a proper response.
        $response = $this->broker()->sendResetLink(
            $this->credentials($request)
        );

        return $response == Password::RESET_LINK_SENT
                   ? $this->sendResetLinkResponse($request, $response)
                   : $this->sendResetLinkFailedResponse($request, $response);
     }

// 或响应函数

    protected function sendResetLinkResponse(Request $request, $response)
    {
        return $request->wantsJson()
                   ? new JsonResponse(['message' => trans($response)], 200)
                   : back()->with('status', trans($response));
    }

验证电子邮件是否属于管理员,并发送适当的 link 我个人会更新 sendResetLinkEmail 函数并创建另一个函数来发送 link 给管理员 Like this

    $guard = 'user';
    $user = User::query()->where('email', $email)->first();
    if (!$user) {
        $user = Admin::query()->where('email', $email)->first();
        $guard = 'admin';
    }
    if (!$user) {
        // This for another case
        //    $user = 
        //    $guard =
    }
    // and then, instead of 
    //     return $response == Password::RESET_LINK_SENT
    //                ? $this->sendResetLinkResponse($request, $response)
    //                : $this->sendResetLinkFailedResponse($request,    $response);

    // i will do

    if ($guard == 'user') {
        $success_response = $this->sendResetLinkResponse($request, $response);
    } else if ($guard == 'admin') {
        $success_response = $this->createAdminResetResponseFunction($request, $response);
    } else {
        // Set one as default
        $success_response = $this->sendResetLinkResponse($request, $response);
    }

    return $response == Password::RESET_LINK_SENT
                ? $success_response
                : $this->sendResetLinkFailedResponse($request, $response);

感谢所有花时间回答的人。

这是解决我问题的方法。

我在 App\Notifications\AdminResetPassword 上有以下条目:

public function toMail($notifiable)
{
  return (new MailMessage)
    ->line('You are receiving this email because we received a password reset request for your account.')
    ->action('Reset Password', url('admin/password/reset', $this->token))
    ->line('If you did not request a password reset, no further action is required.');
}

然后我在 App\Models\Admin 上定义了这个:

use App\Notifications\AdminResetPassword as ResetPasswordNotification;

public function sendPasswordResetNotification($token)
{
   $this->notify(new ResetPasswordNotification($token));
}

在此之后,我的 /loginadmin/login 的重置密码 link 都可以使用了。