Угловой поток входа в систему 2 с вызовом localStorage и http api
Я довольно новичок в Angular 2, и в настоящее время я пытаюсь завершить процесс входа в систему. Я размещаю учетные данные пользователя в API и получаю токен JWT. затем я запрашиваю данные пользователя с этим токеном и сохраняю всю информацию в localStorage, но я не уверен, что это правильно, иногда у меня возникают проблемы.
метод входа
login(user): Promise<any> {
localStorage.clear();
return this.http
.post(`${this.url}/auth/login_check`, JSON.stringify(user), { headers: this.headers }).toPromise().then(resp => {
let json = resp.json();
if (json.token){
console.log('token exists')
localStorage.setItem('jwt_token', json.token);
this.storeUser().then(resp => {
console.log('user exists')
return true;
}, err => {
this.handleError(err);
return false;
})
}
else {
return false;
}
},
err => {
this.handleError(err);
return false;
})
};
метод storeUser
storeUser(): Promise<any> {
this.headers.append('Authorization', 'Bearer '+localStorage.getItem('jwt_token'));
console.log(this.headers);
return this.http.get(`${this.url}/users/0`, { headers: this.headers }).toPromise().then(resp => {
let json = resp.json();
let picture = '';
localStorage.setItem('user_id', json.id);
localStorage.setItem('user_username', json.username);
localStorage.setItem('user_email', json.email);
localStorage.setItem('user_enabled', json.enabled);
localStorage.setItem('user_last_login', json.last_login);
localStorage.setItem('user_roles', json.roles);
localStorage.setItem('user_validated', json.validated);
localStorage.setItem('user_picture', picture);
console.log(localStorage.getItem('user_username'));
return true;
},
err => {
this.handleError(err);
return false;
});
}
Метод входа в компонент входа
signIn() {
this.processing = true;
this.active = true;
this.error = false;
this.success = false;
this.authSvc.login({ username: this.loginForm.value['username'], password: this.loginForm.value['password'] }).then(resp => {
this.processing = false;
this.success = true;
this.router.navigateByUrl('');
}, err => {
this.processing = false;
this.error = true;
})
};