私のWeb Angularプロジェクトでは、セキュリティを処理するためのAuthenticationGuardとAuthenticationServiceを作成しました。アングルサービスはその呼び出しごとにリセットされます
これらのファイルは、完璧に動作するプロジェクトの別のブランチからのものです。
- 移動し「認証/ログイン」へ
- ユーザーが自分の資格情報
- のAuthServiceがベアラートークン
- を取得するには、バックエンドwepApiを呼び出す入力:ここ
は、どのように私のスクリプトべき作品でありますバックエンドはトークンを返します。
- AuthServiceは、彼のvarを 'isLoggedIn'に設定します。
- AuthServiceが '/ home'にナビゲートするためにルータに使用する
- AuthServiceは、AuthServiceの 'isLoggedIn'をチェックして認証を確認します。
私の問題は、AuthGuardがAuthServiceにアクセスするときです:AuthServiceは常にfalseを返します。私はあなたが行っていないと思われるあなたのモジュール定義を見なくても
auth.guard.ts
import { Injectable } from '@angular/core';
import { CanActivate, Router, ActivatedRouteSnapshot,RouterStateSnapshot } from '@angular/router';
import { AuthService } from './auth.service';
@Injectable()
export class AuthGuard implements CanActivate {
constructor(private authService: AuthService, private router: Router) {}
canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): boolean {
let url: string = state.url;
return this.checkLogin(url);
}
checkLogin(url: string): boolean {
if (this.authService.getIsLoggedIn()) {
return true;
}
// Store the attempted URL for redirecting
this.authService.redirectUrl = url;
// Navigate to the login page with extras
this.router.navigate(['/auth/login']);
return false;
}
}
auth.service.ts
import { Injectable } from '@angular/core';
import { Router } from '@angular/router';
import { Observable } from 'rxjs/Observable';
import 'rxjs/add/observable/of';
import 'rxjs/add/operator/do';
import 'rxjs/add/operator/delay';
import { config } from './../shared/smartadmin.config';
import { Http, Headers, RequestOptions, Response } from '@angular/http';
import 'rxjs/add/operator/map'
@Injectable()
export class AuthService {
private isLoggedIn: boolean = false;
public redirectUrl: string;
constructor(private router: Router, private http: Http) {
}
public getIsLoggedIn(): boolean {
console.log("getIsLoggedIn() = " + this.isLoggedIn); // Always returns false
return this.isLoggedIn;
}
public login(username: string, password: string) {
this.ProcessLogin(username, password)
.subscribe(result => {
if (result === true) {
console.log("before attribution");
console.log("this.isLoggedIn = " + this.isLoggedIn); // returns false
this.isLoggedIn = true;
console.log("after attribution");
console.log("this.isLoggedIn = " + this.isLoggedIn); // returns true
this.router.navigate(this.redirectUrl ? [this.redirectUrl] : ['/home']);
} else {
this.logout();
}
});
}
public logout(): void {
localStorage.removeItem('oAuthToken');
this.isLoggedIn = false;
}
private ProcessLogin(username: string, password: string): Observable<boolean> {
let headers = new Headers({ 'Content-Type': 'application/x-www-form-urlencoded' });
let options = new RequestOptions({ headers: headers });
let body = 'grant_type=password&username=' + encodeURIComponent(username) + '&password=' + encodeURIComponent(password);
let endpoint = config.API_ENDPOINT + 'token';
return this.http.post(endpoint, body, options)
.map((response: Response) => {
// login successful if there's a jwt token in the response
let token = response.json() && response.json().access_token;
if (token) {
localStorage.setItem('oAuthToken', token);
// return true to indicate successful login
return true;
} else {
localStorage.removeItem('oAuthToken');
// return false to indicate failed login
return false;
}
});
}
}
if elseロジックを購読部分に移動してもう一度やり直すことはできますか?マップの 'response.json()'を返すだけです。 – echonax
すみませんが、私はあなたの提案を本当に理解していません。あなたは正確にそれを教えていただけますか? –
'ProcessLogin'メソッドの中で' Observable 'を返すのではなく、あなたの' map'で 'response.json()'を返してください。あなたが 'login'メソッドの中で' ProcessLogin'に 'subscribe 'するときにif/elseロジックを行います。 –
echonax