首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将angular从4升级到6时,使用angular2-jwt和AuthHttp时出现问题

将angular从4升级到6时,使用angular2-jwt和AuthHttp时出现问题
EN

Stack Overflow用户
提问于 2018-12-29 20:46:14
回答 1查看 272关注 0票数 0

我正在尝试将一个angular4应用程序更新到angular6,并使用angular2-jwt向web发送身份验证,但在angular6中我生成了这个错误:TypeError: Observable_1.Observable.defer is not a function see the error here

这就是我创建令牌的地方

代码语言:javascript
复制
 login(model: any) {
    const headers = new Headers({ 'Content-type': 'application/json' });
    const options = new RequestOptions({ headers: headers });
    return this.http
      .post(this.baseUrl, model, options)
      .map((response: Response) => {
        const user = response.json();
        if (user) {
          localStorage.setItem('token', user.userModel.tokenString);
          this.decodedToken = this.jwtHelper.decodeToken(user.userModel.tokenString);
          this.userToken = user.userModel.tokenString;
          this.currentUserModel = user.userModel;
          this.changeuserPhotoUrl(this.currentUserModel.userImage);
        }
      }).catch(this.handelError);
  }

这是我的HttpServiceFactory

代码语言:javascript
复制
import { Http, RequestOptions } from "@angular/http";
import { AuthHttp, AuthConfig } from "angular2-jwt";
import { NgModule } from "@angular/core";

export function authenticationHttpServiceFactory(http: Http, options: RequestOptions) {
  return new AuthHttp(new AuthConfig({
    tokenName: 'token',
    tokenGetter: (() => localStorage.getItem('token')),
    globalHeaders: [{ 'Content-Type':'application/json'}]
  }),http,options);
}

@NgModule({
  providers: [
    {
      provide: AuthHttp,
      useFactory: authenticationHttpServiceFactory,
      deps: [Http, RequestOptions]
    }
    ]
})

export class AuthenticationModule { }
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-12-29 21:35:44

我认为你可以使用Interceptor来实现你的目的。例如:

代码语言:javascript
复制
@Injectable()
export class AuthInterceptor implements HttpInterceptor {
 .......
 .....
}

然后你应该像这样把它放到你的module.ts中

代码语言:javascript
复制
{
  provide: HTTP_INTERCEPTORS,
  useClass: AuthInterceptor,
  multi: true
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53969662

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档