没有 AuthHttp 的提供者!在 angular2-jwt 上
No provider for AuthHttp! on angular2-jwt
我是 Angular 2 的新手,我想在我的项目中使用 JWT。所以我完全按照 the official page of angular2-jwt 给出的说明使用基本配置。
我使用以下代码创建了一个名为 auth.module.ts 的文件:
import { NgModule } from '@angular/core';
import { Http, RequestOptions } from '@angular/http';
import { AuthHttp, AuthConfig } from 'angular2-jwt';
function authHttpServiceFactory(http: Http, options: RequestOptions) {
return new AuthHttp(new AuthConfig(), http, options);
}
@NgModule({
providers: [
{
provide: AuthHttp,
useFactory: authHttpServiceFactory,
deps: [Http, RequestOptions]
}
]
})
export class AuthModule {}
下一步是发送经过身份验证的请求。我使用了一个组件,我在其中放置了一个按钮,该按钮调用一个函数来执行页面上建议的代码:
文件:calendario.components.ts
import {Component, OnInit,trigger,state,style,transition,animate,keyframes, group} from '@angular/core';
import initDemo = require('../../../assets/js/charts.js');
import initNotify = require('../../../assets/js/notify.js');
import { AuthHttp } from 'angular2-jwt';
declare var $:any;
@Component({
moduleId: module.id,
selector: 'calendario',
templateUrl: 'calendario.component.html'
})
export class CalendarioComponent{
thing: any;
constructor(public authHttp: AuthHttp) {}
obtenerDatos() {
this.authHttp.get('http://localhost/autorepuestos/web/app_dev.php/api/conjunto')
.subscribe(
data => this.thing = data,
err => console.log(err),
() => console.log('Request Complete')
);
console.log("Hola");
}
}
当我进入这个组件时出现错误:
EXCEPTION: Uncaught (in promise): Error: No provider for AuthHttp!
Error: DI Error
我能解决这个问题吗? angular 2 我真的很新,谢谢你的帮助!
看起来您已经创建了一个模块来提供此 AuthHttp
class。您是否确定 AuthModule
在 CalendarioComponent
所属的模块的导入中?
像这样:
import { AuthModule } from '...';
import { CalendarioComponent } from '...';
@NgModule({
imports: [AuthModule],
declarations: [CalendarioComponent]
})
export class SomeModule {}
我是 Angular 2 的新手,我想在我的项目中使用 JWT。所以我完全按照 the official page of angular2-jwt 给出的说明使用基本配置。 我使用以下代码创建了一个名为 auth.module.ts 的文件:
import { NgModule } from '@angular/core';
import { Http, RequestOptions } from '@angular/http';
import { AuthHttp, AuthConfig } from 'angular2-jwt';
function authHttpServiceFactory(http: Http, options: RequestOptions) {
return new AuthHttp(new AuthConfig(), http, options);
}
@NgModule({
providers: [
{
provide: AuthHttp,
useFactory: authHttpServiceFactory,
deps: [Http, RequestOptions]
}
]
})
export class AuthModule {}
下一步是发送经过身份验证的请求。我使用了一个组件,我在其中放置了一个按钮,该按钮调用一个函数来执行页面上建议的代码:
文件:calendario.components.ts
import {Component, OnInit,trigger,state,style,transition,animate,keyframes, group} from '@angular/core';
import initDemo = require('../../../assets/js/charts.js');
import initNotify = require('../../../assets/js/notify.js');
import { AuthHttp } from 'angular2-jwt';
declare var $:any;
@Component({
moduleId: module.id,
selector: 'calendario',
templateUrl: 'calendario.component.html'
})
export class CalendarioComponent{
thing: any;
constructor(public authHttp: AuthHttp) {}
obtenerDatos() {
this.authHttp.get('http://localhost/autorepuestos/web/app_dev.php/api/conjunto')
.subscribe(
data => this.thing = data,
err => console.log(err),
() => console.log('Request Complete')
);
console.log("Hola");
}
}
当我进入这个组件时出现错误:
EXCEPTION: Uncaught (in promise): Error: No provider for AuthHttp!
Error: DI Error
我能解决这个问题吗? angular 2 我真的很新,谢谢你的帮助!
看起来您已经创建了一个模块来提供此 AuthHttp
class。您是否确定 AuthModule
在 CalendarioComponent
所属的模块的导入中?
像这样:
import { AuthModule } from '...';
import { CalendarioComponent } from '...';
@NgModule({
imports: [AuthModule],
declarations: [CalendarioComponent]
})
export class SomeModule {}