ホームページ バックエンド開発 C#.Net チュートリアル C# で権限制御と認証を使用する方法

C# で権限制御と認証を使用する方法

Oct 09, 2023 am 11:01 AM
認証 権限制御 c#

C# で権限制御と認証を使用する方法

C# でアクセス許可制御と認証を使用する方法には、特定のコード例が必要です

今日のインターネット時代において、情報セキュリティの問題はますます注目を集めています。システムとデータのセキュリティを保護するために、権限制御と認証は開発者にとって不可欠な部分になっています。 C# は一般的に使用されるプログラミング言語として、アクセス許可の制御と認証の実装に役立つ豊富な関数とクラス ライブラリを提供します。

権限制御とは、ユーザーの ID、役割、権限などに基づいて、特定のリソースへのユーザーのアクセスを制限することを指します。権限制御を実装する一般的な方法は、ロールと権限の管理システムを使用することです。以下では、C# でのアクセス許可制御の使用方法を具体的な例を使用して紹介します。

まず、ロールと権限のデータベース テーブルを作成する必要があります。テーブル構造は特定のニーズに応じて設計できますが、ここではそれを 2 つのテーブル (役割テーブルと権限テーブル) に単純化します。役割テーブルには役割情報が格納され、権限テーブルには権限情報が格納されます。テーブル構造は次のとおりです。

CREATE TABLE Role (
    Id INT PRIMARY KEY,
    Name VARCHAR(50) NOT NULL
)

CREATE TABLE Permission (
    Id INT PRIMARY KEY,
    Name VARCHAR(50) NOT NULL,
    RoleId INT,
    FOREIGN KEY(RoleId) REFERENCES Role(Id)
)
ログイン後にコピー

次に、C# でロールと権限のエンティティ クラスを定義します。

public class Role
{
    public int Id { get; set; }
    public string Name { get; set; }
}

public class Permission
{
    public int Id { get; set; }
    public string Name { get; set; }
    public int RoleId { get; set; }
}
ログイン後にコピー

次に、権限検証のロジックをコードに記述する必要があります。一般的には、コントローラのコンストラクタなど、システムの入り口で権限を判断できます。以下は、簡単な権限検証の例です。

public class HomeController : Controller
{
    private readonly IPermissionService _permissionService;

    public HomeController(IPermissionService permissionService)
    {
        _permissionService = permissionService;
    }

    public IActionResult Index()
    {
        if(!_permissionService.HasPermission(User.Identity.Name, "HomePageAccess"))
        {
            return Unauthorized();
        }
        
        return View();
    }
}
ログイン後にコピー

上の例では、IPermissionService インターフェイスを介して権限検証サービスにアクセスします。サービスの実装では、データベースにクエリを実行して、ユーザーが対応する権限を持っているかどうかを判断できます。ここでは、権限を決定するメソッドを直接使用するように単純化します。

public interface IPermissionService
{
    bool HasPermission(string username, string permissionName);
}

public class PermissionService : IPermissionService
{
    public bool HasPermission(string username, string permissionName)
    {
        // 根据用户名和权限名查询数据库,判断用户是否有权限
        // 这里省略具体的数据库查询过程
        
        // 假设用户有权限
        return true;
    }
}
ログイン後にコピー

上記のコード例を通じて、単純な権限制御関数を実装できます。ユーザーがホームページ (インデックス) にアクセスすると、システムはユーザーに HomePageAccess 権限があるかどうかを判断し、権限がない場合は 401 Unauthorized を返します。

さらに、権限制御に加えて、本人確認もシステムのセキュリティを確保する鍵となります。 C# では、ASP.NET Core が提供する認証関数を使用してユーザーを認証できます。以下は、ASP.NET Core を使用した認証の例です。

public class AccountController : Controller
{
    private readonly UserManager<ApplicationUser> _userManager;
    private readonly SignInManager<ApplicationUser> _signInManager;

    public AccountController(UserManager<ApplicationUser> userManager, SignInManager<ApplicationUser> signInManager)
    {
        _userManager = userManager;
        _signInManager = signInManager;
    }

    public IActionResult Login()
    {
        return View();
    }

    [HttpPost]
    public async Task<IActionResult> Login(LoginViewModel model)
    {
        if (ModelState.IsValid)
        {
            var result = await _signInManager.PasswordSignInAsync(model.Username, model.Password, model.RememberMe, lockoutOnFailure: true);
            
            if (result.Succeeded)
            {
                return RedirectToAction("Index", "Home");
            }
            else if (result.IsLockedOut)
            {
                ModelState.AddModelError(string.Empty, "账户被锁定,请稍后再试。");
            }
            else
            {
                ModelState.AddModelError(string.Empty, "用户名或密码错误。");
            }
        }

        return View();
    }
}
ログイン後にコピー

上の例では、ユーザー認証に ASP.NET Core によって提供される UserManager と SignInManager を使用します。ログイン アクション (Login) では、PasswordSignInAsync メソッドを呼び出してユーザーのユーザー名とパスワードを確認します。

要約すると、C# は、アクセス許可の制御と認証の実装に役立つ豊富な関数とクラス ライブラリを提供します。ロールと権限の管理システムを合理的に使用し、ASP.NET Core が提供する認証機能と組み合わせることで、システムとデータを効果的に保護し、システムのセキュリティを確保できます。もちろん、具体的な実装方法は実際のニーズやプロジェクトの規模に応じて調整する必要があります。

以上がC# で権限制御と認証を使用する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

C# を使用した Active Directory C# を使用した Active Directory Sep 03, 2024 pm 03:33 PM

C# を使用した Active Directory のガイド。ここでは、Active Directory の概要と、C# での動作方法について、構文と例とともに説明します。

C# の乱数ジェネレーター C# の乱数ジェネレーター Sep 03, 2024 pm 03:34 PM

C# の乱数ジェネレーターのガイド。ここでは、乱数ジェネレーターの仕組み、擬似乱数の概念、安全な数値について説明します。

C# シリアル化 C# シリアル化 Sep 03, 2024 pm 03:30 PM

C# シリアル化のガイド。ここでは、C# シリアル化オブジェクトの導入、手順、作業、例についてそれぞれ説明します。

C# データ グリッド ビュー C# データ グリッド ビュー Sep 03, 2024 pm 03:32 PM

C# データ グリッド ビューのガイド。ここでは、SQL データベースまたは Excel ファイルからデータ グリッド ビューをロードおよびエクスポートする方法の例について説明します。

C# のパターン C# のパターン Sep 03, 2024 pm 03:33 PM

C# のパターンのガイド。ここでは、C# のパターンの概要と上位 3 種類について、その例とコード実装とともに説明します。

C# の素数 C# の素数 Sep 03, 2024 pm 03:35 PM

C# の素数ガイド。ここでは、C# における素数の導入と例を、コードの実装とともに説明します。

C# の階乗 C# の階乗 Sep 03, 2024 pm 03:34 PM

C# の Factorial のガイド。ここでは、C# での階乗の概要について、さまざまな例とコード実装とともに説明します。

マルチスレッドと非同期C#の違い マルチスレッドと非同期C#の違い Apr 03, 2025 pm 02:57 PM

マルチスレッドと非同期の違いは、マルチスレッドが複数のスレッドを同時に実行し、現在のスレッドをブロックせずに非同期に操作を実行することです。マルチスレッドは計算集約型タスクに使用されますが、非同期はユーザーインタラクションに使用されます。マルチスレッドの利点は、コンピューティングのパフォーマンスを改善することですが、非同期の利点はUIスレッドをブロックしないことです。マルチスレッドまたは非同期を選択することは、タスクの性質に依存します。計算集約型タスクマルチスレッド、外部リソースと相互作用し、UIの応答性を非同期に使用する必要があるタスクを使用します。

See all articles