Error: Uncaught (in promise): TypeError: guard is not a function
Error: Uncaught (in promise): TypeError: guard is not a function
我正在 Angular 4 中编写一个 Authguard 来防止未经登录访问路由。但是,我收到此错误。下面是 App 模块中 Authgaurd 和 Routing 的代码。请帮助解决问题。
//Authgaurd代码
import { ActivatedRouteSnapshot, CanActivate, Route, Router,
RouterStateSnapshot } from '@angular/router';
import { Store } from '';
import { Observable } from 'rxjs/Observable';
import { map, take } from 'rxjs/operators';
import { Observer } from 'rxjs';
import { Globals } from '../../app.global';
import { CRMStorageService } from '../services/storage.service';
import 'rxjs/add/operator/take';
@Injectable()
export class AuthGuard implements CanActivate {
constructor(private router: Router,private storageService: StorageService) {
}
canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot):
Observable<boolean> {
return this.storageService.getItem(Globals._CURRENT_USER_KEY).take(1).map
(token => {
if (token) {
return true;
} else {
this.router.navigate(['/login']);
}
});
}
}
//App模块中的路由
const appRoutes: Routes = [
{ path:'',redirectTo:'/login', pathMatch: 'full' },
{ path:'login', component: LoginComponent },
{ path:'reset/:token', component: ResetpasswordComponent },
{
path: '',
canActivateChild: [AuthGuard],
children: [
{ path:'dashboard', component: DashboardComponent },
{ path:'customerlist', component: CustomerlistComponent }
]
},
{ path: '**', component: ErrorComponent }
];
@NgModule({
imports: [
RouterModule.forRoot(appRoutes,
{
enableTracing: false // <-- debugging purposes only
})],
declarations: [
AppComponent,
.
.
],
providers: [AuthGuard],
exports: [],
bootstrap: [AppComponent]})
export class AppModule { }
Just Replace the canActivateChild with canActivate in Your Routing handler it will work
const appRoutes: Routes = [
{ path: '', redirectTo: '/login', pathMatch: 'full' },
{ path: 'login', component: LoginComponent },
{ path: 'reset/:token', component: ResetpasswordComponent },
{
path: '',
canActivate: [AuthGuard],
children: [
{ path: 'dashboard', component: DashboardComponent },
{ path: 'customerlist', component: CustomerlistComponent }
]
},
{ path: '**', component: ErrorComponent }
];
@NgModule({
imports: [
RouterModule.forRoot(appRoutes,
{
enableTracing: false // <-- debugging purposes only
})],
declarations: [
AppComponent,
.
.
],
providers: [AuthGuard],
exports: [],
bootstrap: [AppComponent]
})
export class AppModule { }
You must have to implement both the CanActivate and CanAcitvateChild interface on the AuthGuard in order to use it on canActivateChild
export class AuthGuard implements CanActivate, CanActivateChild {
...
canActivateChild(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): boolean {
return this.canActivate(route, state);
}
}
我正在 Angular 4 中编写一个 Authguard 来防止未经登录访问路由。但是,我收到此错误。下面是 App 模块中 Authgaurd 和 Routing 的代码。请帮助解决问题。
//Authgaurd代码
import { ActivatedRouteSnapshot, CanActivate, Route, Router,
RouterStateSnapshot } from '@angular/router';
import { Store } from '';
import { Observable } from 'rxjs/Observable';
import { map, take } from 'rxjs/operators';
import { Observer } from 'rxjs';
import { Globals } from '../../app.global';
import { CRMStorageService } from '../services/storage.service';
import 'rxjs/add/operator/take';
@Injectable()
export class AuthGuard implements CanActivate {
constructor(private router: Router,private storageService: StorageService) {
}
canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot):
Observable<boolean> {
return this.storageService.getItem(Globals._CURRENT_USER_KEY).take(1).map
(token => {
if (token) {
return true;
} else {
this.router.navigate(['/login']);
}
});
}
}
//App模块中的路由
const appRoutes: Routes = [
{ path:'',redirectTo:'/login', pathMatch: 'full' },
{ path:'login', component: LoginComponent },
{ path:'reset/:token', component: ResetpasswordComponent },
{
path: '',
canActivateChild: [AuthGuard],
children: [
{ path:'dashboard', component: DashboardComponent },
{ path:'customerlist', component: CustomerlistComponent }
]
},
{ path: '**', component: ErrorComponent }
];
@NgModule({
imports: [
RouterModule.forRoot(appRoutes,
{
enableTracing: false // <-- debugging purposes only
})],
declarations: [
AppComponent,
.
.
],
providers: [AuthGuard],
exports: [],
bootstrap: [AppComponent]})
export class AppModule { }
Just Replace the canActivateChild with canActivate in Your Routing handler it will work
const appRoutes: Routes = [
{ path: '', redirectTo: '/login', pathMatch: 'full' },
{ path: 'login', component: LoginComponent },
{ path: 'reset/:token', component: ResetpasswordComponent },
{
path: '',
canActivate: [AuthGuard],
children: [
{ path: 'dashboard', component: DashboardComponent },
{ path: 'customerlist', component: CustomerlistComponent }
]
},
{ path: '**', component: ErrorComponent }
];
@NgModule({
imports: [
RouterModule.forRoot(appRoutes,
{
enableTracing: false // <-- debugging purposes only
})],
declarations: [
AppComponent,
.
.
],
providers: [AuthGuard],
exports: [],
bootstrap: [AppComponent]
})
export class AppModule { }
You must have to implement both the CanActivate and CanAcitvateChild interface on the AuthGuard in order to use it on canActivateChild
export class AuthGuard implements CanActivate, CanActivateChild {
...
canActivateChild(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): boolean {
return this.canActivate(route, state);
}
}