Angular 4:在登录时将用户重定向到上一个会话中的最后访问页面。
创始人
2024-10-15 20:31:09
0

要实现在登录时将用户重定向到上一个会话中的最后访问页面,可以使用Angular的路由守卫(Route Guards)和localStorage存储最后访问页面的URL。

首先,我们需要创建一个AuthGuard路由守卫来检查用户是否已登录。如果用户已登录,则允许访问页面,否则将用户重定向到登录页面。

import { Injectable } from '@angular/core';
import { CanActivate, Router, ActivatedRouteSnapshot, RouterStateSnapshot } from '@angular/router';

@Injectable()
export class AuthGuard implements CanActivate {
  constructor(private router: Router) {}

  canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): boolean {
    if (localStorage.getItem('isLoggedin')) {
      return true;
    }

    this.router.navigate(['/login'], { queryParams: { returnUrl: state.url } });
    return false;
  }
}

然后,在登录组件中,我们需要将用户登录成功后的重定向URL保存到localStroage中。

import { Component } from '@angular/core';
import { Router, ActivatedRoute } from '@angular/router';

@Component({
  selector: 'app-login',
  template: `
    

Login

` }) export class LoginComponent { returnUrl: string; constructor(private route: ActivatedRoute, private router: Router) { this.returnUrl = this.route.snapshot.queryParams['returnUrl'] || '/'; } login() { // 登录逻辑 localStorage.setItem('isLoggedin', 'true'); this.router.navigateByUrl(this.returnUrl); } }

最后,在需要进行权限控制的路由上添加AuthGuard

import { NgModule } from '@angular/core';
import { Routes, RouterModule } from '@angular/router';

import { HomeComponent } from './home.component';
import { LoginComponent } from './login.component';
import { AuthGuard } from './auth.guard';

const routes: Routes = [
  { path: '', component: HomeComponent, canActivate: [AuthGuard] },
  { path: 'login', component: LoginComponent },
  // 其他路由
];

@NgModule({
  imports: [RouterModule.forRoot(routes)],
  exports: [RouterModule]
})
export class AppRoutingModule { }

这样,当用户未登录时,访问受保护的页面时将被重定向到登录页面,并在登录成功后自动跳转回原始访问页面。

相关内容

热门资讯

透视详情!pokeplus脚本... 透视详情!pokeplus脚本(透视)wepoker辅助透视软件,教程妙招(有挂讲解)-哔哩哔哩1、...
wepoker可以免费玩吗!p... wepoker可以免费玩吗!pokemmo辅助器手机版下载(透视)软件-总是科普真的是有挂1、进入游...
透视解密!德普之星私人局辅助器... 透视解密!德普之星私人局辅助器(透视)we-poker辅助器,教程大纲(有人有挂)-哔哩哔哩1、许多...
hhpoker有后台操控吗!德... hhpoker有后台操控吗!德州局HHpoker透视脚本(透视)神器-本来关于存在有挂1)德州局HH...
透视关于!wepoker透视是... 透视关于!wepoker透视是真的吗(透视)pokemmo免费脚本,教程演示(揭秘有挂)-哔哩哔哩w...
hhpoker是真的还是假的!... hhpoker是真的还是假的!wpk辅助是什么(透视)软件-真是揭幕是有挂1、不需要AI权限,帮助你...
透视解密!wepoker透视有... 透视解密!wepoker透视有吗(透视)wepoker一直输的号能继续打吗,教程法门(详细教程)-哔...
we-poker辅助软件教程!... we-poker辅助软件教程!wepoker怎么挂底牌(透视)app-其实了解是有挂we-poker...
透视揭露!hhpoker一直输... 透视揭露!hhpoker一直输有挂吗(透视)wepoker私人局辅助,教程资料(有挂总结)-哔哩哔哩...
拱趴大菠萝挂怎么安装!wpk私... 拱趴大菠萝挂怎么安装!wpk私人局有透视吗(透视)app-一直辅助真的有挂1、拱趴大菠萝挂怎么安装破...