Sono riuscito a regolare l'autorizzazione Laravel predefinita in modo che funzionasse come un'API per il mio AngularJS, e finora tutto funziona correttamente. Puoi andare su/reset e inserire un'e-mail e ricevere un'e-mail con un link per reimpostare la password che va a/reset/{token} e se non ricevi errori di convalida, la tua password sarà cambiata con successo.Laravel 5.1/AngularJS: Reimposta password nella vista Angolare (come convalidare il token CSRF?)
L'unico problema è che sto usando una vista Angolare, non c'è davvero nulla che convalida il token e si assicuri che non sia solo un messaggio senza senso prima di mostrare lo stato reset-password
. Ho provato ad aggiungere questo alla parte superiore del controller:
if ($stateParams.token != $cookies.get('XSRF_TOKEN')) {
$state.go('reset');
}
... che sarebbe fondamentalmente vedere se il token è l'attuale token CSRF, ma che non funziona perché quando il link di reimpostazione password viene inviata la CSRF token è cambiato o qualcosa ... non è più il token della sessione.
Qualcuno ha qualche idea su come posso farlo? Voglio semplicemente reindirizzare l'utente se il token inserito nell'url su "/ reset /: token" non è valido.
Ecco il mio codice ..
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'
})
questo è nel tratto ResetsPassword in ResetsPassword.php. La maggior parte era già impostata ma ho rimosso/modificato molto per funzionare come un'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();
}
Questa è una domanda utile e illustrazione della tecnica per chiunque sviluppi con Laravel e Angular. Grazie per la pubblicazione. – delatbabel