电子邮件密码重设错误 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));
}
在此之后,我的 /login
和 admin/login
的重置密码 link 都可以使用了。
我在我的项目上使用多重授权,我的登录页面是:
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));
}
在此之后,我的 /login
和 admin/login
的重置密码 link 都可以使用了。