Я использую приложение Angular и пытаюсь проверить CanActivate
, если token
действительно, если это действительно так, верните true. Если это правда, мне нужно удалить его из url
Я пытался этот код, чтобы удалить URL-параметр
let url: string = this.router.url.substring(0, this.router.url.indexOf("?"));
this.router.navigateByUrl(url);
но он входит в бесконечный цикл. Как убрать параметры после проверки их валидности?
canActivate(
next: ActivatedRouteSnapshot,
state: RouterStateSnapshot): Observable<boolean> | Promise<boolean> | boolean {
let accesstoken: string = next.queryParams.accesstoken;
if (this.authService.IsAuthenticated) {
let user = this.authService.GetUser();
let CurrentDate = new Date();
let date = CurrentDate.getFullYear() + "-" + (CurrentDate.getMonth() + 1) + "-" + CurrentDate.getDate();
if (Date.parse(date) <= Date.parse(user.expire_date)) {
return true;
}
}
else if (!NOU(accesstoken)) { // In case current registered token is not valid, CheckAccess with new token
// this.authService.logout();
this.authService.checkAccess(accesstoken).subscribe(
data => {
if (data === true) {
return true;
} else {
this.router.navigate(['/login']);
return false;
}
},
error => {
}
);
}
else {
this.router.navigate(['/login']);
return false;
}
}
`
auth.service.ts
checkAccess(accesstoken: string) {
let Headers = new HttpHeaders();
Headers = Headers.append('AuthenticationToken', accesstoken);
return this.dataService
.post<any>(`${this.authUrl}CheckAccess.json`, null, { headers: Headers })
.pipe(
map(response => {
const authenticated = response.flag;
// login successful
if (authenticated) {
// you can use JSON.parse(localStorage.getItem('user')) statement to get the user information when needed.
const user = new User(response);
localStorage.setItem('user', JSON.stringify(user));
localStorage.setItem('AuthenticationToken', accesstoken);
this.IsAuthenticated = true;
this.authenticationSource.next(true);
// return true to indicate successful login
return authenticated;
}
}),
catchError(conError => {
// return false to indicate failed login response 401
return 'Failed';
})
);
}
обращенно-auth.guard.ts
export class ReverseAuthGuard implements CanActivate {
constructor(private router: Router, private authService: AuthService) { }
canActivate(
next: ActivatedRouteSnapshot,
state: RouterStateSnapshot
): Observable<boolean> | Promise<boolean> | boolean {
if (this.authService.IsAuthenticated) {
let user = this.authService.GetUser();
let CurrentDate = new Date();
let date = CurrentDate.getFullYear() + "-" + (CurrentDate.getMonth() + 1) + "-" + CurrentDate.getDate();
if (Date.parse(date) > Date.parse(user.expire_date)) {
// this.router.navigate(['/']);
return true;
}
this.router.navigate(['/home']);
return false;
}
else {
return true;
}
}
}
приложение-routing.module.ts
const routes: Routes = [
{
path: '',
component: LayoutComponent,
canActivate: [AuthGuard],
children: [
{
path: 'home',
loadChildren: './home/home.module#HomeModule',
data: {
title: 'Home'
}
},
{
path: '',
redirectTo: 'home',
pathMatch: 'full'
}
]
},
{
path: 'unauthorized',
component: UnauthorizedComponent,
canActivate: [ReverseAuthGuard],
data: {
title: 'Unauthorized'
}
},
{
path: 'login',
component: LoginComponent,
canActivate: [ReverseAuthGuard],
data: {
title: 'Login'
}
}
];