刷新令牌keycloak js

时间:2020-01-30 16:44:07

标签: angular typescript keycloak

我使用keycloak-js版本8.0.1,我有一个getToken函数,用于测试令牌在此情况下过期(如果刷新)或令牌未过期以使其返回。问题是令牌过期后会显示警告消息,但不会更改

TokenService

@Injectable()
export class TokenService {

static auth: any = {};

constructor() { }

 static init(): Promise<any> {
    const keycloakAuth: Keycloak.KeycloakInstance = Keycloak({
        url: config.keycloak.url,
        realm: config.keycloak.realm,
        clientId: config.keycloak.clientId
    });
    return new Promise((resolve, reject) => {
        keycloakAuth.init({ onLoad: 'check-sso', flow: 'implicit', checkLoginIframe: false }).success(() => {
            TokenService.auth.authz = keycloakAuth;
            resolve();
        }).error(() => {
            reject();
        });
    });
 }

 getToken(): Promise<string> {
    return new Promise<string>((resolve, reject) => {
        if (TokenService.auth.authz.isTokenExpired()) {
             console.warn("Token expired !");
            TokenService.auth.authz.updateToken(1800).success(() => {
                console.log("Token updated");
                resolve(<string>TokenService.auth.authz.token);
            }).error(() => {
                reject('Failed to refresh token');
            });
        } else {
            resolve(<string>TokenService.auth.authz.token);
        }
    });
 }
}

1 个答案:

答案 0 :(得分:1)

我认为问题可能出在函数TokenService.auth.authz.updateToken(1800)上,这意味着(如果我理解正确),如果令牌将在1800秒内过期,那么请刷新令牌。

在您的情况下,令牌已过期,因此该功能不执行任何操作。我建议不要检查isExpired(),而是直接做类似的事情

getToken(): Promise<string> {
    return new Promise<string>((resolve, reject) => {
        TokenService.auth.authz.updateToken(100).success(() => {
                console.log("Token updated");
                resolve(<string>TokenService.auth.authz.token);
            }).error(() => {
                reject('Failed to refresh token');
            });
        resolve(<string>TokenService.auth.authz.token);
    });
 }