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

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

王林
リリース: 2023-10-09 11:01:47
オリジナル
1213 人が閲覧しました

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 サイトの他の関連記事を参照してください。

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