ホームページ バックエンド開発 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ツール

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の 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#対C:歴史、進化、将来の見通し C#対C:歴史、進化、将来の見通し Apr 19, 2025 am 12:07 AM

C#とCの歴史と進化はユニークであり、将来の見通しも異なります。 1.Cは、1983年にBjarnestrostrupによって発明され、オブジェクト指向のプログラミングをC言語に導入しました。その進化プロセスには、C 11の自動キーワードとラムダ式の導入など、複数の標準化が含まれます。C20概念とコルーチンの導入、将来のパフォーマンスとシステムレベルのプログラミングに焦点を当てます。 2.C#は2000年にMicrosoftによってリリースされました。CとJavaの利点を組み合わせて、その進化はシンプルさと生産性に焦点を当てています。たとえば、C#2.0はジェネリックを導入し、C#5.0は非同期プログラミングを導入しました。これは、将来の開発者の生産性とクラウドコンピューティングに焦点を当てます。

C#.NET:.NETエコシステムを使用したアプリケーションの構築 C#.NET:.NETエコシステムを使用したアプリケーションの構築 Apr 27, 2025 am 12:12 AM

.NETを使用してアプリケーションを構築する方法は? .NETを使用してアプリケーションを構築することは、次の手順を通じて達成できます。1)C#言語やクロスプラットフォーム開発サポートを含む.NETの基本を理解します。 2)コンポーネントや.NETエコシステムの作業原則などのコア概念を学習します。 3)単純なコンソールアプリケーションから複雑なWebAPISおよびデータベース操作まで、基本的および高度な使用をマスターします。 4)構成やデータベース接続の問題など、一般的なエラーとデバッグ手法に精通している。 5)アプリケーションのパフォーマンスの最適化と非同期プログラミングやキャッシュなどのベストプラクティス。

.NETフレームワーク対C#:用語のデコード .NETフレームワーク対C#:用語のデコード Apr 21, 2025 am 12:05 AM

.NetFrameworkはソフトウェアフレームワークであり、C#はプログラミング言語です。 1..netframeworkは、デスクトップ、Web、モバイルアプリケーションの開発をサポートするライブラリとサービスを提供します。 2.C#は.NetFrameWork用に設計されており、最新のプログラミング機能をサポートしています。 3..NetFrameworkはCLRを介してコード実行を管理し、C#コードはILにコンパイルされ、CLRによって実行されます。 4. .NetFrameWorkを使用してアプリケーションをすばやく開発し、C#はLINQなどの高度な関数を提供します。 5.一般的なエラーには、タイプ変換と非同期プログラミングデッドロックが含まれます。 VisualStudioツールは、デバッグに必要です。

azure/awsへのc#.netアプリケーションの展開:ステップバイステップガイド azure/awsへのc#.netアプリケーションの展開:ステップバイステップガイド Apr 23, 2025 am 12:06 AM

c#.netアプリをAzureまたはAWSに展開する方法は?答えは、AzureAppServiceとAwselasticBeanStalkを使用することです。 1。Azureでは、AzureAppServiceとAzurePipelinesを使用して展開を自動化します。 2。AWSでは、Amazon ElasticBeanstalkとAwslambdaを使用して、展開とサーバーレス計算を実装します。

ユニティゲーム開発:C#は3D物理エンジンとAIの動作ツリーを実装しています ユニティゲーム開発:C#は3D物理エンジンとAIの動作ツリーを実装しています May 16, 2025 pm 02:09 PM

Unityでは、3D物理エンジンとAIの動作ツリーをC#を通じて実装できます。 1. rigidbodyコンポーネントとaddforceメソッドを使用して、スクロールボールを作成します。 2。動作を通じて、パトロールやChaseplayerなどのツリーノードを介して、AIキャラクターはプレーヤーをパトロールして追いかけるように設計できます。

汎用性のある.NET言語としてのC#:アプリケーションと例 汎用性のある.NET言語としてのC#:アプリケーションと例 Apr 26, 2025 am 12:26 AM

C#は、エンタープライズレベルのアプリケーション、ゲーム開発、モバイルアプリケーション、Web開発で広く使用されています。 1)エンタープライズレベルのアプリケーションでは、C#がasp.netcoreにWebAPIを開発するためによく使用されます。 2)ゲーム開発では、C#がUnityエンジンと組み合わされて、ロールコントロールやその他の機能を実現します。 3)C#は、コードの柔軟性とアプリケーションのパフォーマンスを改善するために、多型と非同期プログラミングをサポートします。

PHPに認証と承認を実装するにはどうすればよいですか? PHPに認証と承認を実装するにはどうすればよいですか? Jun 20, 2025 am 01:03 AM

tosecurelyhandLeauthenticationAndauthorizationInizationInization、followTheSteps:1.LwayShashPasswordswithPassword_hash()andverifyusingpassword_verify()、usepreparedStatementStatementStatementStatementStatementStain、andstoreUserdatain $ _SessionAfterlogin.2.implementRementRementRementRementRementRementRementRole

C#.NET開発者のコ​​ミュニティ:リソースとサポート C#.NET開発者のコ​​ミュニティ:リソースとサポート May 06, 2025 am 12:11 AM

C#.NET開発者コミュニティは、次のような豊富なリソースとサポートを提供します。1。Microsoftの公式文書、2。StackoverflowやRedditなどのコミュニティフォーラム、3。Githubのオープンソースプロジェクト。これらのリソースは、開発者が基本的な学習から高度なアプリケーションまでプログラミングスキルを向上させるのに役立ちます。

See all articles