Udało mi się dostosować domyślne uwierzytelnienie Laravel, aby działał jako interfejs API dla mojego AngularJS, i jak na razie wszystko działa dobrze. Można przejść do/resetować i wpisać adres e-mail, a następnie wysłać e-mail z linkiem do resetowania hasła, który przechodzi do/reset/{token}, a jeśli nie otrzymasz żadnych błędów sprawdzania poprawności, twoje hasło zostanie pomyślnie zmienione.Laravel 5.1/AngularJS: Zresetuj hasło w widoku kątowym (jak sprawdzić token CSRF?)
Jedynym problemem jest to, że używam widoku kątowego, tak naprawdę nie ma nic sprawdzania poprawności tokena i upewniania się, że nie jest to zwykły bełkot, zanim pojawi się stan reset-password
. Próbowałem, dodając to do górnej części kontrolera:
if ($stateParams.token != $cookies.get('XSRF_TOKEN')) {
$state.go('reset');
}
... co w zasadzie zobaczyć jeśli znacznik jest obecny CSRF żeton, ale to nie działa, ponieważ kiedy link resetowania hasła zostanie wysłana CSRF zmiana tokena lub coś takiego ... to już nie token z sesji.
Ktoś ma jakieś pomysły, jak mogę to zrobić? Chcę przekierować użytkownika, jeśli token wprowadzony w url na `/ reset /: token 'jest nieprawidłowy.
Oto mój kod ..
App.js:
.state('reset', {
url: '/reset',
data: {
permissions: {
except: ['isLoggedIn'],
redirectTo: 'user.dashboard'
}
},
templateUrl: 'views/auth/forgot-password.html',
controller: 'ForgotPasswordController as forgot'
})
.state('reset-password', {
url: '/reset/:token',
data: {
permissions: {
except: ['isLoggedIn'],
redirectTo: 'user.dashboard'
}
},
templateUrl: 'views/auth/reset-password.html',
controller: 'ResetPasswordController as reset'
})
Jest to cechą ResetsPassword w ResetsPassword.php. Większość była już skonfigurowana, ale usunąłem/zmieniłem wiele, aby działać jako interfejs API:
/**
* Send a reset link to the given user.
*/
public function postEmail(EmailRequest $request)
{
$response = Password::sendResetLink($request->only('email'), function (Message $message) {
$message->subject($this->getEmailSubject());
});
switch ($response) {
case Password::RESET_LINK_SENT:
return;
case Password::INVALID_USER:
return response()->json([
'denied' => 'We couldn\'t find your account with that information.'
], 404);
}
}
/**
* Get the e-mail subject line to be used for the reset link email.
*/
protected function getEmailSubject()
{
return property_exists($this, 'subject') ? $this->subject : 'Your Password Reset Link';
}
/**
* Reset the given user's password.
*/
public function postReset(ResetRequest $request)
{
$credentials = $request->only(
'password', 'password_confirmation', 'token'
);
$response = Password::reset($credentials, function ($user, $password) {
$this->resetPassword($user, $password);
});
switch ($response) {
case Password::PASSWORD_RESET:
return;
default:
return response()->json([
'error' => [
'message' => 'Could not reset password'
]
], 400);
}
}
/**
* Reset the given user's password.
*/
protected function resetPassword($user, $password)
{
$user->password = bcrypt($password);
$user->save();
}
Jest to przydatne pytanie i ilustracja techniki dla każdego, kto rozwija się z Laravel i Angular. Dzięki za publikację. – delatbabel