ASP.NET MVC 2 のカスタム メンバーシップ プロバイダーの作成
ASP.NET MVC 2 では、メンバーシップ プロバイダーはユーザー認証と関連するものを管理します。タスク。メンバーシップ プロバイダーをカスタマイズするには、抽象 MembershipProvider クラスを継承し、そのメソッドをオーバーライドするクラスを作成できます。
ValidateUser メソッドを実装します
このメソッドは、ユーザーを認証します。カスタム データ ソース。例:
public override bool ValidateUser(string username, string password) { // Validate the user credentials against your database. // ... }
メンバーシップ プロバイダーを構成します
カスタム メンバーシップ プロバイダーを web.config に追加します:
<membership defaultProvider="MyMembershipProvider"> <providers> <clear /> <add name="MyMembershipProvider" applicationName="MyApp" connectionStringName="MyMembershipConnection" type="MyApp.MyMembershipProvider" /> </providers> </membership>
ロール管理
ユーザーのロールを管理するには、以下も必要です抽象 RoleProvider クラスから継承し、そのメソッドをオーバーライドするカスタム クラスを作成します。
GetRolesForUser メソッドを実装します
このメソッドは、ユーザーに割り当てられたロールをユーザーから取得します。データソース。例:
public override string[] GetRolesForUser(string username) { // Retrieve the user's roles from the database. // ... }
ロール プロバイダーを構成します
カスタム ロール プロバイダーを web.config に追加します:
<roleManager enabled="true" defaultProvider="MyRoleProvider"> <providers> <clear /> <add name="MyRoleProvider" applicationName="MyApp" connectionStringName="MyMembershipConnection" type="MyApp.MyRoleProvider" /> </providers> </roleManager>
認可
特定のコントローラーまたはアクションに基づいてアクセスを制限するためロールでは、[Authorize(Roles = "role1,role2")] 属性を使用します。
カスタム承認属性
承認をさらに制御するには、 AuthorizeAttribute クラスから継承するカスタム属性。これにより、承認ロジックを処理し、権限のないユーザーをカスタム エラー ビューにリダイレクトできます。
以上がASP.NET MVC 2でカスタムメンバーシップとロールプロバイダーを作成するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。