0

我正在使用 Angular 实现登录功能

角度-oauth2-oidc

和 IndentityServer4(.Net 核心)。如果我打开选项卡 A 并登录,然后我打开其他选项卡并转到我的站点,但浏览器重定向到登录页面,而我希望它保持在主页中。这是我的代码:

ngOnInit() {
    this.checkLogin();
    this.getLoginData();
  }

  checkLogin() {
    console.log({ TOKEN: this.oauthService.getAccessToken() })
    if (this.oauthService.getAccessToken() != null) {
      this.router.navigateByUrl('/home');
    } else {
      return;
    }
  }

  Login() {
    this.oauthService.fetchTokenUsingPasswordFlow(this.username, this.password).then((resp) => {
      return this.oauthService.loadUserProfile();
    }).then(() => {
      let claims = this.oauthService.getIdentityClaims();
      if (claims) console.log(claims);
      this.rememberMe();
      this.toastr.success("Login successful !");
      this.router.navigateByUrl('/home');
    }).catch((err) => {
      this.toastr.error(err.error.error_description)
    })
  }


  rememberMe() {
    if (this.remember_me) {
      this.cookieService.set('uSnGTX23NJKLX=', this.username);
      this.cookieService.set('pWNEAExy2HBXS=', this.password);
    } else {
      this.cookieService.deleteAll();
    }
  }

  private getLoginData() {
    this.username = this.cookieService.get('uSnGTX23NJKLX=');
    this.password = this.cookieService.get('pWNEAExy2HBXS=');
    this.remember_me = (this.username != '' || this.password != '');
  }

有人有什么主意吗?谢谢!

4

1 回答 1

0
  1. 尝试将记录的信息存储在 localStorage 中。
  2. 将 oauth 服务与角度防护一起使用:https ://github.com/katerinalev1992/Angular6Firebase/blob/master/src/app/services/auth-guard.service.ts
于 2018-11-21T08:08:36.910 回答