真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

angular9中路由守衛(wèi)的使用方法

小編給大家分享一下angular9中路由守衛(wèi)的使用方法,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

目前成都創(chuàng)新互聯(lián)已為成百上千的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)站空間、網(wǎng)站改版維護(hù)、企業(yè)網(wǎng)站設(shè)計(jì)、麥蓋提網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長(zhǎng),共同發(fā)展。

路由守衛(wèi)是什么

任何用戶都能在任何時(shí)候?qū)Ш降饺魏蔚胤?。但有時(shí)候出于種種原因需要控制對(duì)該應(yīng)用的不同部分的訪問??赡馨ㄈ缦聢?chǎng)景:

該用戶可能無權(quán)導(dǎo)航到目標(biāo)組件。

可能用戶得先登錄(認(rèn)證)。

在顯示目標(biāo)組件前,你可能得先獲取某些數(shù)據(jù)。

在離開組件前,你可能要先保存修改。

你可能要詢問用戶:你是否要放棄本次更改,而不用保存它們?

相關(guān)推薦:《angular教程》

組件的創(chuàng)建

1、home組件創(chuàng)建
2、login組件創(chuàng)建
3、home下的first和second子組件

angular9中路由守衛(wèi)的使用方法

守衛(wèi)路由相關(guān)核心代碼

routing中每個(gè)路由都是對(duì)所有人開放的。這些新的管理特性應(yīng)該只能被已登錄用戶訪問。

編寫一個(gè) CanActivate() 守衛(wèi),將正在嘗試訪問管理組件匿名用戶重定向到登錄頁(yè)。

1.1 在auth 文件夾下,新建一個(gè)auth.service.ts文件,模擬有關(guān)登錄的請(qǐng)求服務(wù),實(shí)際場(chǎng)景一般是將后臺(tái)token保存在cookie中.

import { Injectable } from '@angular/core';

import { Observable, of } from 'rxjs';
import { tap, delay } from 'rxjs/operators';

@Injectable({
  providedIn: 'root',
})
export class AuthService {
  isLoggedIn = false; //默認(rèn)未登錄

  // 記錄登錄之后,需要跳轉(zhuǎn)到原來請(qǐng)求的地址
  redirectUrl: string;
// 登錄
  login(): Observable {
    return of(true).pipe(
      delay(1000),
      tap(val => this.isLoggedIn = true)
    );
  }
// 登出
  logout(): void {
    this.isLoggedIn = false;
  }
}

1.2 在 auth 文件夾下,新建一個(gè)auth.guard.ts文件

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

import { AuthService } from './auth.service'; 
@Injectable({
  providedIn: 'root',
})
export class AuthGuard implements CanActivate {
  constructor(private authService: AuthService, private router: Router) {}
  canActivate(
    next: ActivatedRouteSnapshot,
    state: RouterStateSnapshot): boolean {
    let url: string = state.url
    return this.checkLogin(url);
  }
  
  checkLogin(url: string): boolean {
    if (this.authService.isLoggedIn) { return true; }

    // 保存原始的請(qǐng)求地址,登錄后跳轉(zhuǎn)到該地址
    this.authService.redirectUrl = url;

    // 未登錄,跳轉(zhuǎn)到登錄頁(yè)面
    this.router.navigate(['/login']);
    return false;
  }
}

在路由中使用守衛(wèi)

在app-routing.module.ts文件下使用

import { NgModule } from '@angular/core';
import { Routes, RouterModule } from '@angular/router';
import { AuthGuard } from './auth/auth.guard';
import { LoginComponent } from './login/login.component';

const routes: Routes = [
  {
    path: '',
    redirectTo: '/home',
    pathMatch: 'full'
  },
 
  {
    path: 'login',
    component: LoginComponent
  },
  {
    path: 'home',
    loadChildren: () => import('./home/home.module')
      .then(mod => mod.HomeModule),
    canActivate: [AuthGuard], // 守衛(wèi)路由
  }
];

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

以上是“angular9中路由守衛(wèi)的使用方法”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!


網(wǎng)頁(yè)標(biāo)題:angular9中路由守衛(wèi)的使用方法
瀏覽地址:http://weahome.cn/article/ggjdco.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部