Angular应用集成了Keycloak,在页面刷新时只会重定向到登录页面。
创始人
2024-10-30 15:30:29
0

这通常是因为在页面刷新时 Keycloak 令牌丢失导致的。你可以通过 Keycloak Service 的 init() 方法再次获取令牌。你可以在 AppComponent 中添加以下代码:

import { Component, OnInit } from '@angular/core';
import { KeycloakService } from 'keycloak-angular';

@Component({
  selector: 'app-root',
  template: ''
})
export class AppComponent implements OnInit {
  constructor(private keycloakService: KeycloakService) {}

  ngOnInit() {
    this.keycloakService.init({ onLoad: 'login-required' })
      .then(() => console.log('Keycloak init'))
      .catch(() => console.log('Keycloak init failed'));
  }
}

这段代码将初始化 Keycloak 并创建一个新的 Token。加上 onLoad: 'login-required' 可以让 Keycloak 每次刷新页面时都需要重新登录。

然而,如果你的 Angular 应用程序有子组件,那么仍需要在 loadChildren 中初始化 Keycloak。在应用程序路由中,你可以为每个带有 lazy-loaded 子路由的路由添加 canLoad 守卫:

import { Injectable } from '@angular/core';
import { KeycloakAuthGuard, KeycloakService } from 'keycloak-angular';
import { ActivatedRouteSnapshot, CanActivateChild, Router, RouterStateSnapshot } from '@angular/router';

@Injectable({
  providedIn: 'root'
})
export class AuthGuard implements CanActivateChild {
  constructor(private keycloakAuthGuard: KeycloakAuthGuard, private keycloakService: KeycloakService, private router: Router) {}

  async canActivateChild(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Promise {
    const auth = await this.keycloakAuthGuard.canActivateChild(route, state);
    if (auth) { return true; }

    try {
      await this.keycloakService.getToken();
      return await this.keycloakAuthGuard.canActivateChild(route, state);
    } catch {
      this.keycloakService.login({ redirectUri: window.location.href });
      return false;
    }
  }

相关内容

热门资讯

透视好友!wepokerplu... 透视好友!wepokerplus辅助,wepoker私人局透视教程,资料教程(好像真的是有挂)-哔哩...
透视俱乐部!cloudpoke... 透视俱乐部!cloudpoker辅助(透视)开挂辅助器(其实存在有挂)-哔哩哔哩1、透视俱乐部!cl...
第八分钟方针!熊猫辅助器视频教... 第八分钟方针!熊猫辅助器视频教程,葫芦娃七子降妖破解版内购,细节揭秘(有挂总结)-哔哩哔哩1、上手简...
透视计算!wepoker有脚本... 透视计算!wepoker有脚本吗,wepoker破解器有用吗,演示教程(果然是有挂)-哔哩哔哩透视计...
透视计算器!pokemmo手机... 透视计算器!pokemmo手机版修改器(透视)开挂辅助插件(真是真的有挂)-哔哩哔哩1、pokemm...
第3分钟手筋!福建兄弟13水插... 第3分钟手筋!福建兄弟13水插件,蜀山四川怎么提高胜率,新版2025教程(有挂方略)-哔哩哔哩一、蜀...
透视计算!epoker底牌透视... 透视计算!epoker底牌透视,aapoker怎么提高中牌率,方案教程(竟然是有挂)-哔哩哔哩1、上...
透视专用!wepoker科技辅... 透视专用!wepoker科技辅助器(透视)开挂辅助软件(都是真的有挂)-哔哩哔哩wepoker科技辅...
第七分钟指南书!上饶打炸辅助,... 第七分钟指南书!上饶打炸辅助,越乡游辅助脚本,大神讲解(果真有挂)-哔哩哔哩1、不需要AI权限,帮助...
透视透视挂!wepoker轻量... 您好,wepoker辅助软件视频这款游戏可以开挂的,确实是有挂的,需要了解加去威信【48527505...