gpt4 book ai didi

Angular 服务在每次调用时都会重置

转载 作者:太空狗 更新时间:2023-10-29 18:25:13 25 4
gpt4 key购买 nike

在我的 Web Angular 项目中,我创建了一个 AuthenticationGuard 和一个 AuthenticationService 来处理安全问题。

这些文件来 self 项目的另一个完美运行的分支。

这是我的脚本应该如何工作:

  1. 导航到“授权/登录”
  2. 用户输入他的凭据
  3. Authservice调用后端wepApi获取Bearer Token
  4. 后端返回 token 。
  5. AuthService 将他的变量“isLoggedIn”设置为 true;
  6. AuthService 使用路由器导航到“/home”
  7. AuthGuard 通过检查 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;
}
});
}
}

最佳答案

在没有看到您的模块定义的情况下,我怀疑您没有将 AuthService 设为核心服务(单例),这意味着使用它的每个模块都将拥有自己的实例(跟踪自己的 isLoggedIn 标志)。

要使服务成为 Angular 中的单例,它必须由根模块注入(inject)器提供服务。为此,您需要执行以下操作:

import { NgModulep } from '@angular/core';
import { CommonModule, ModuleWithProviders } from '@angular/common';
import { AuthService, AuthGuard } from './services/index';

@NgModule({
imports: [
CommonModule,
ModuleWithProviders
]
})
export class SharedModule {

static forRoot(): ModuleWithProviders {
return {
ngModule: SharedModule,
providers: [
AuthService,
AuthGuard
]
};
}

}

然后在将 SharedModule 导入根 AppModule 时调用 forRoot 方法。

@NgModule({
imports: [
...
SharedModule.forRoot(),
...
],
...,
bootstrap: [AppComponent]
})
export class AppModule { }

在这里查看“配置核心服务”https://angular.io/docs/ts/latest/guide/ngmodule.html#!#core-for-root

关于Angular 服务在每次调用时都会重置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44361707/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com