ホームページ > ウェブフロントエンド > jsチュートリアル > Angular プロジェクトで権限制御を実装する方法について話しましょう?

Angular プロジェクトで権限制御を実装する方法について話しましょう?

青灯夜游
リリース: 2022-04-28 20:57:56
転載
2889 人が閲覧しました

Angular プロジェクトで権限制御を実装するにはどうすればよいですか?次の記事では、コード例を通じて Angular プロジェクトに権限制御を実装する方法について説明します。

Angular プロジェクトで権限制御を実装する方法について話しましょう?

前の記事では、 Angular コンポーネント通信について説明しました。この記事では、プロジェクト開発中にそのようなニーズが発生するかどうかについて説明します。 ユーザーがログインに基づいてアクセスできるコンテンツを制限してください。 [関連チュートリアルの推奨事項: "angular チュートリアル"]

つまり、これは 権限制御 を実行するためのものです。

ユーザーの権限制限については、通常次のような処理方法があります。

  • ユーザーのログイン メニューの制御

  • #ユーザーの制限動作

このトピックについては、

Angular と合わせて説明します。

メニュールーティング制御

Angular プロジェクトで権限制御を実装する方法について話しましょう?

システムを開発するとたくさんのメニューが登場します。バックエンドはユーザーの役割を決定し、ユーザーの権限に従って異なるメニュー ルートを返す必要があります。

返されるデータ形式は、

app-routing.module.ts に記述したルーティング パスに対応する必要があります。

たとえば、次のようなルーティング ファイルがあります。

// app-routing.module.ts

const routes: Routes = [
  {
    path: 'user-manage',
    component: AuthLayoutComponent, // 通过鉴权的组件
    children: [
      {
        path: '',
        redirectTo: 'user',
        pathMatch: 'full'
      },
      {
        path: 'user', // 用户列表
        component: UserComponent
      },
      {
        path: 'user/detail/:uuid', // 用户详情,类似这种不会出现在菜单里面
        component: UserDetailComponent
      },
      {
        path: 'department', // 部门列表
        component: DepartmentComponent
      }
    ]
  },
  // ...
]
ログイン後にコピー

ページでは、メニューによって表示されるデータは次のようになります。

<!-- demo.component.html -->

<ul nz-menu nzMode="inline" [nzInlineCollapsed]="isCollapsed">
  <li *ngFor="let submenu of menu_data" nz-submenu [nzTitle]="isCollapsed ? &#39;&#39; : submenu.title" [nzIcon]="submenu.icon"
    [nzOpen]="submenu.is_open" (nzOpenChange)="selectMenu(submenu)">
    <ul>
      <li *ngFor="let child of submenu?.children" nz-menu-item nzMatchRouter>
        <a [routerLink]="[&#39;/&#39; + child.url]">{{ child.title }}</a>
      </li>
    </ul>
  </li>
</ul>
ログイン後にコピー

は、第 2 レベルを定義します。 menu には次のフィールドがあります:

  • title フィールド - メニューのタイトル
  • url フィールド - メニューのルートapp-routing.module.ts の完全な path
  • icon フィールドに対応します - タイトルの前の小さなアイコン、# はありません## セカンダリ タイトルの場合
  • is_open
  • フィールド - メニューが展開されているかどうかの識別
  • 現時点では、バックエンド メニュー インターフェイスは次のようなデータを返す必要があります。以下:
// demo.component.ts

public menu_data:any = [
  {
    title: "成员管理",
    url: "user-manage",
    icon: "user-switch", // 这里是用了 angular ant design 的图标
    is_open: false,
    children: [
      {
        title: "用户",
        url: "user-manage/user",
        icon: undefined,
        is_open: false
      },
      {
        title: "部门",
        url: "user-manage/department",
        icon: undefined,
        is_open: false
      }
    ]
  },
  // ...
]
ログイン後にコピー

ご質問がありますか?️:

2 つのフィールド

iconis_open は、第 2 レベルのタイトルでは使用されません。なぜまだそれらを書く必要があるのでしょうか?

まあ、読者はバックエンドのリターンをリクエストできますが、データを読みやすく操作しやすい状態に保つためには、データを保持しておいたほうがよいでしょう...

ユーザー動作制御

ユーザー動作制御。これは非常にきめ細かい動作です。ユーザーのボタンの表示を制御する程度の小さなものにすることもできますが、本質的にはバックエンド インターフェイスのリクエストに対する制限です。たとえば、リストをリクエストしても権限がない場合、リストをリクエストすることはできず、エラー

401 が報告されます。

Angular プロジェクトで権限制御を実装する方法について話しましょう?

ユーザーのニーズや役割に応じて、ユーザーの閲覧やその他の操作を制限できます。しかし、これは不合理であり、ユーザーはシステムを経由する代わりに、

postman やその他のツールを通じてリクエストを開始できます。したがって、次のことを行う必要があります--

#バックエンドに制限のレイヤーを作成します

#バックエンドから返されるインターフェイスのアクセス許可を取得します (たとえば、次のデータを受信します)。

{
  code: 0,
  msg: &#39;ok&#39;,
  results: {
    getUserList: {
     url: &#39;/api/get/user/list&#39;, // 当然,可以按照前后端规定返回,不一定是真实的 url ...
     enable: true
    },
    editUser: {
      url: &#39;/api/edit/:uuid&#39;,
      enable: false
    }
  }
}
ログイン後にコピー

データを取得したら、フロントエンドが保存した内容と比較し、条件に応じて制御するため、フロントエンドだけで判断するのではなく、インターフェース側でアクセスを制限する必要があります。 。

<!-- demo.component.html -->

<button *ngIf="userObj.editUser.enable">Edit</button>
ログイン後にコピー

単純なフロントエンドの判断: 1. 保守が容易ではない 2. 安全ではない、ユーザーはブラウザをまたいでリクエストできる

【終了】

続きプログラミング関連の知識について詳しくは、

プログラミング入門

をご覧ください。 !

以上がAngular プロジェクトで権限制御を実装する方法について話しましょう?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:juejin.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート