【发布时间】:2018-11-01 00:05:08
【问题描述】:
我试图弄清楚如何将作为服务中 oauth2 隐式过程的一部分返回的用户令牌传递给作为回调 url 的组件,这样我就可以在文章中进一步使用该令牌。
服务代码
import { Injectable } from '@angular/core';
import {UserManager, UserManagerSettings, User} from 'oidc-client';
@Injectable({
providedIn: 'root'
})
export class AuthService {
private manager: UserManager = new UserManager(getClientSettings());
private user: User = null;
constructor() {
this.manager.getUser().then(user => {
this.user = user;
});
}
isLoggedIn(): boolean {
return this.user != null && !this.user.expired;
}
getClaims(): any {
return this.user.profile;
}
getAuthorizationHeaderValue(): string {
return `${this.user.token_type} ${this.user.access_token}`;
}
startAuthentication(): Promise<void> {
return this.manager.signinRedirect();
}
completeAuthentication(): Promise<void> {
return this.manager.signinRedirectCallback().then(user => {
console.log(user.access_token);
this.user = user;
});
}
}
export function getClientSettings(): UserManagerSettings {
return {
authority: 'https://someserver.com',
client_id: 'clientid',
redirect_uri: 'http://localhost:4200/auth-callback',
post_logout_redirect_uri: 'http://localhost:4200/',
response_type: "id_token token",
scope: "openid read write",
filterProtocolClaims: true,
loadUserInfo: false,
automaticSilentRenew: true,
silent_redirect_uri: 'http://localhost:4200/silent-refresh.html'
};
}
这使用 OICD Oauth 2 库
组件代码如下
import { Component, OnInit } from '@angular/core';
import { AuthService } from '../services/auth.service';
import { Router, NavigationCancel, ActivatedRoute } from '@angular/router';
import { URLSearchParams } from '@angular/http';
import { Http, RequestOptions, Headers, Response} from '@angular/http';
@Component({
selector: 'app-auth-callback',
templateUrl: './auth-callback.component.html',
styleUrls: ['./auth-callback.component.css'],
providers: [AuthService]
})
export class AuthCallbackComponent implements OnInit {
public accesstoken:any;
constructor(private http: Http, private router: Router, private authService: AuthService, private route: ActivatedRoute) {
}
ngOnInit() {
this.authService.completeAuthentication();
}
}
正如您所看到的,组件在初始化时成功地从服务调用了 completeAuthentication,但是我不知道如何将 user_token 从服务传递给组件。您将在服务的 completeAuthentication 函数中看到此令牌引用,并且此时它确实成功地进行了控制台日志。目前,我要做的就是通过 auth 回调组件控制台记录该用户令牌,以显示其被正确传递。
【问题讨论】: