Angular中可以使用ngx-permissions和Angular AuthGuard来实现基于角色的访问控制。以下是使用ngx-permissions的示例代码:
npm install ngx-permissions --save
import { NgxPermissionsModule } from 'ngx-permissions'; @NgModule({ declarations: [AppComponent], imports: [BrowserModule, NgxPermissionsModule.forRoot()], bootstrap: [AppComponent] }) export class AppModule {}
import { Injectable } from '@angular/core'; import { ActivatedRouteSnapshot, CanActivate, RouterStateSnapshot, UrlTree } from '@angular/router'; import { Observable } from 'rxjs'; import { map } from 'rxjs/operators'; import { NgxPermissionsService } from 'ngx-permissions';
@Injectable({ providedIn: 'root' }) export class AuthGuard implements CanActivate {
constructor(private permissionsService: NgxPermissionsService) {}
canActivate(
next: ActivatedRouteSnapshot,
state: RouterStateSnapshot): Observable
{ path: 'secure-data', component: SecureDataComponent, canActivate: [AuthGuard], data: { allowedRoles: ['Admin'] } }
以上代码将只允许Admin角色的用户访问secure-data路由下的组件。