使用localStorage和http api调用的angular 2登录流程

时间:2017-11-03 11:57:48

标签: angular api angular-promise angular2-localstorage

我对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方法

  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;
})

};

0 个答案:

没有答案