역할 만들기 및 관리(C#)
작성자 : Scott Mitchell
참고
이 문서가 작성된 이후 ASP.NET 멤버 자격 공급자는 ASP.NET ID로 대체되었습니다. 이 문서를 작성할 때 추천하는 멤버 자격 공급자가 아닌 ASP.NET ID 플랫폼을 사용하도록 앱을 업데이트하는 것이 좋습니다. ASP.NET ID는 를 포함하여 ASP.NET 멤버 자격 시스템에 비해 여러 가지 이점이 있습니다.
- 성능 향상
- 향상된 확장성 및 테스트 용이성
- OAuth, OpenID Connect 및 2단계 인증 지원
- 클레임 기반 ID 지원
- ASP.Net Core와의 상호 운용성 향상
이 자습서에서는 역할 프레임워크를 구성하는 데 필요한 단계를 살펴봅니다. 그런 다음 역할을 만들고 삭제하는 웹 페이지를 빌드합니다.
소개
사용자 기반 권한 부여 자습서에서는 URL 권한 부여를 사용하여 특정 사용자를 페이지 집합에서 제한하는 방법을 살펴보았습니다. 방문 사용자에 따라 ASP.NET 페이지의 기능을 조정하기 위한 선언적 및 프로그래밍 기술을 살펴보았습니다. 그러나 사용자 단위로 페이지 액세스 또는 기능에 대한 권한을 부여하는 것은 사용자 계정이 많거나 사용자의 권한이 자주 변경되는 시나리오에서 유지 관리 악몽이 될 수 있습니다. 사용자가 특정 작업을 수행하기 위해 권한 부여를 얻거나 잃을 때마다 관리자는 적절한 URL 권한 부여 규칙, 선언적 태그 및 코드를 업데이트해야 합니다.
일반적으로 사용자를 그룹 또는 역할로 분류한 다음 역할 별로 권한을 적용하는 데 도움이 됩니다. 예를 들어 대부분의 웹 애플리케이션에는 관리자용으로만 예약된 특정 페이지 또는 작업 집합이 있습니다. 사용자 기반 권한 부여 자습서에서 학습한 기술을 사용하여 지정된 사용자 계정이 관리 작업을 수행할 수 있도록 적절한 URL 권한 부여 규칙, 선언적 태그 및 코드를 추가합니다. 그러나 새 관리자가 추가되었거나 기존 관리자가 관리 권한을 취소해야 하는 경우 구성 파일 및 웹 페이지를 반환하고 업데이트해야 합니다. 그러나 역할을 사용하면 Administrators라는 역할을 만들고 신뢰할 수 있는 사용자를 관리자 역할에 할당할 수 있습니다. 다음으로, 관리자 역할이 다양한 관리 작업을 수행할 수 있도록 적절한 URL 권한 부여 규칙, 선언적 태그 및 코드를 추가합니다. 이 인프라를 사용하면 사이트에 새 관리자를 추가하거나 기존 관리자를 제거하는 것은 관리자 역할에서 사용자를 포함하거나 제거하는 것만큼 간단합니다. 구성, 선언적 태그 또는 코드 변경이 필요하지 않습니다.
ASP.NET 역할을 정의하고 사용자 계정과 연결하기 위한 역할 프레임워크를 제공합니다. 역할 프레임워크를 사용하여 역할을 만들고 삭제하고, 역할에 사용자를 추가하거나, 역할에서 사용자를 추가하고, 특정 역할에 속한 사용자 집합을 결정하고, 사용자가 특정 역할에 속하는지 여부를 알 수 있습니다. 역할 프레임워크가 구성되면 URL 권한 부여 규칙을 통해 역할별로 페이지에 대한 액세스를 제한하고 현재 로그온한 사용자 역할에 따라 페이지에 추가 정보 또는 기능을 표시하거나 숨길 수 있습니다.
이 자습서에서는 역할 프레임워크를 구성하는 데 필요한 단계를 살펴봅니다. 그런 다음 역할을 만들고 삭제하는 웹 페이지를 빌드합니다. 사용자에게 역할 할당 자습서에서는 역할에서 사용자를 추가하고 제거하는 방법을 살펴봅니다. 또한 역할 기반 권한 부여 자습서에서는 방문 중인 사용자의 역할에 따라 페이지 기능을 조정하는 방법과 함께 역할별로 페이지에 대한 액세스를 제한하는 방법을 알아봅니다. 그럼 시작하겠습니다.
1단계: 새 ASP.NET 페이지 추가
이 자습서와 다음 두 가지에서는 다양한 역할 관련 함수 및 기능을 살펴보겠습니다. 이러한 자습서 전체에서 검토된 topics 구현하려면 일련의 ASP.NET 페이지가 필요합니다. 이러한 페이지를 만들고 사이트 맵을 업데이트해 보겠습니다.
먼저 라는 Roles
프로젝트에 새 폴더를 만듭니다. 그런 다음 폴더에 새 ASP.NET 페이지 4개를 Roles
추가하여 각 페이지를 master 페이지와 Site.master
연결합니다. 페이지 이름을 지정합니다.
ManageRoles.aspx
UsersAndRoles.aspx
CreateUserWizardWithRoles.aspx
RoleBasedAuthorization.aspx
이 시점에서 프로젝트의 솔루션 탐색기 그림 1에 표시된 스크린샷과 유사하게 표시됩니다.
그림 1: 폴더에 4개의 새 페이지가 Roles
추가되었습니다(전체 크기 이미지를 보려면 클릭).
이 시점에서 각 페이지에는 master 페이지의 ContentPlaceHolders MainContent
LoginContent
각각에 대해 하나씩 및 의 두 콘텐츠 컨트롤이 있어야 합니다.
<asp:Content ID="Content1" ContentPlaceHolderID="MainContent"Runat="Server">
</asp:Content>
<asp:Content ID="Content2" ContentPlaceHolderID="LoginContent"Runat="Server">
</asp:Content>
LoginContent
ContentPlaceHolder의 기본 태그는 사용자가 인증되었는지 여부에 따라 사이트에 로그온하거나 로그오프할 수 있는 링크를 표시합니다. Content2
그러나 ASP.NET 페이지에 콘텐츠 컨트롤이 있으면 master 페이지의 기본 태그가 재정의됩니다. 양식 인증 개요 자습서에서 설명한 대로 기본 태그를 재정의하는 것은 왼쪽 열에 로그인 관련 옵션을 표시하지 않으려는 페이지에서 유용합니다.
그러나 이 네 페이지의 경우 ContentPlaceHolder에 대한 master 페이지의 기본 태그를 LoginContent
표시하려고 합니다. 따라서 콘텐츠 컨트롤에 대한 선언적 태그를 Content2
제거합니다. 이렇게 하면 네 페이지의 태그 각각에 하나의 콘텐츠 컨트롤만 포함되어야 합니다.
마지막으로 이러한 새 웹 페이지를 포함하도록 사이트 맵(Web.sitemap
)을 업데이트해 보겠습니다. 멤버 자격 자습서에 대해 추가한 <siteMapNode>
다음에 다음 XML을 추가합니다.
<siteMapNode title="Roles">
<siteMapNode url="~/Roles/ManageRoles.aspx" title="Manage Roles"/>
<siteMapNode url="~/Roles/UsersAndRoles.aspx" title="Users and Roles" />
<siteMapNode url="~/Roles/CreateUserWizardWithRoles.aspx" title="Create Account (with Roles)" />
<siteMapNode url="~/Roles/RoleBasedAuthorization.aspx" title="Role-Based Authorization" />
</siteMapNode>
사이트 맵이 업데이트되면 브라우저를 통해 사이트를 방문합니다. 그림 2에서 볼 수 있듯이 왼쪽 탐색에는 이제 역할 자습서에 대한 항목이 포함됩니다.
그림 2: 폴더에 4개의 새 페이지가 Roles
추가되었습니다(전체 크기 이미지를 보려면 클릭).
2단계: 역할 프레임워크 공급자 지정 및 구성
멤버 자격 프레임워크와 마찬가지로 역할 프레임워크는 공급자 모델 위에 빌드됩니다. 보안 기본 사항 및 ASP.NET 지원 자습서에서 설명한 대로 .NET Framework 세 가지 기본 제공 역할 공급자AuthorizationStoreRoleProvider
인 , WindowsTokenRoleProvider
및 와 SqlRoleProvider
함께 제공됩니다. 이 자습서 시리즈에서는 SqlRoleProvider
Microsoft SQL Server 데이터베이스를 역할 저장소로 사용하는 에 중점을 둡니다.
아래에는 역할 프레임워크가 포함되며 멤버 자격 프레임워크 및 SqlRoleProvider
와 SqlMembershipProvider
마찬가지로 작동합니다. .NET Framework 역할 프레임워크에 Roles
대한 API 역할을 하는 클래스를 포함합니다. 클래스에는 Roles
, , , DeleteRole
IsUserInRole
AddUserToRole
GetAllRoles
, 등과 같은 CreateRole
정적 메서드가 있습니다. 이러한 메서드 중 하나가 호출되면 클래스는 Roles
구성된 공급자에 대한 호출을 위임합니다. 는 SqlRoleProvider
응답에서 역할별 테이블(aspnet_Roles
및 )과 aspnet_UsersInRoles
함께 작동합니다.
애플리케이션에서 공급자를 SqlRoleProvider
사용하려면 저장소로 사용할 데이터베이스를 지정해야 합니다. 에는 SqlRoleProvider
지정된 역할 저장소에 특정 데이터베이스 테이블, 뷰 및 저장 프로시저가 있어야 합니다. 이러한 필수 데이터베이스 개체는 도구를 사용하여 aspnet_regsql.exe
추가할 수 있습니다. 이 시점에서 에 필요한 스키마가 있는 데이터베이스가 이미 있습니다 SqlRoleProvider
. SQL Server 멤버 자격 스키마 만들기 자습서에서 라는 SecurityTutorials.mdf
데이터베이스를 만들고 에 필요한 SqlRoleProvider
데이터베이스 개체를 포함하는 애플리케이션 서비스를 추가하는 데 사용 aspnet_regsql.exe
했습니다. 따라서 역할 지원을 사용하도록 설정하고 데이터베이스와 함께 를 역할 저장소로 사용하도록 SqlRoleProvider
역할 프레임워크에 SecurityTutorials.mdf
지시하기만 하면 됩니다.
Roles 프레임워크는 애플리케이션 파일의 Web.config
요소를 통해 <roleManager
> 구성됩니다. 기본적으로 역할 지원은 사용하지 않도록 설정됩니다. 이를 사용하도록 설정하려면 요소의 enabled
특성을 true
다음과 같이 설정 <roleManager
> 해야 합니다.
<?xml version="1.0"?>
<configuration>
<system.web>
... Additional configuration markup removed for brevity ...
<roleManager enabled="true" />
<system.web>
</configuration>
기본적으로 모든 웹 애플리케이션에는 형식SqlRoleProvider
의 역할 공급자가 있습니다AspNetSqlRoleProvider
. 이 기본 공급자는 에 machine.config
등록됩니다(에 %WINDIR%\Microsoft.Net\Framework\v2.0.50727\CONFIG
있음).
<roleManager>
<providers>
<add name="AspNetSqlRoleProvider"
connectionStringName="LocalSqlServer"
applicationName="/"
type="System.Web.Security.SqlRoleProvider,
System.Web, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"/>
</providers>
</roleManager>
공급자의 connectionStringName
특성은 사용되는 역할 저장소를 지정합니다. 공급자는 AspNetSqlRoleProvider
이 특성을 로 설정합니다. 이 특성LocalSqlServer
은 에 machine.config
정의되어 있으며 기본적으로 라는 aspnet.mdf
폴더의 SQL Server 2005 Express Edition 데이터베이스를 App_Data
가리킵니다.
따라서 애플리케이션의 파일에 공급자 정보를 지정하지 않고 역할 프레임워크를 사용하도록 설정하는 경우 애플리케이션 Web.config
은 기본 등록된 역할 공급자 를 AspNetSqlRoleProvider
사용합니다. 데이터베이스가 ~/App_Data/aspnet.mdf
없으면 ASP.NET 런타임에서 자동으로 데이터베이스를 만들고 애플리케이션 서비스 스키마를 추가합니다. 그러나 데이터베이스를 사용하지 aspnet.mdf
않고, 애플리케이션 서비스 스키마를 이미 만들고 추가한 데이터베이스를 사용 SecurityTutorials.mdf
하려고 합니다. 이 수정은 다음 두 가지 방법 중 하나로 수행할 수 있습니다.
- 에 대한 값을 지정합니다.
LocalSqlServer
의Web.config
연결 문자열 이름. 에서Web.config
연결 문자열 이름 값을 덮어쓰LocalSqlServer
면 등록된 기본 역할 공급자(AspNetSqlRoleProvider
)를 사용하고 데이터베이스에서SecurityTutorials.mdf
올바르게 작동하게 할 수 있습니다. 이 기술에 대한 자세한 내용은 Scott Guthrie의 블로그 게시물, SQL Server 2000 또는 SQL Server 2005를 사용하도록 ASP.NET 2.0 Application Services 구성을 참조하세요. - 형식
SqlRoleProvider
의 등록된 새 공급자 추가및 구성connectionStringName
를 가리키SecurityTutorials.mdf
도록 설정데이터베이스. 이 방법은 SQL Server 멤버 자격 스키마 만들기 자습서에서 권장하고 사용하는 방법이며 이 자습서에서도 사용할 방법입니다.
파일에 다음 역할 구성 태그를 추가합니다 Web.config
. 이 태그는 라는 SecurityTutorialsSqlRoleProvider
새 공급자를 등록합니다.
<?xml version="1.0"?>
<configuration>
<connectionStrings>
<add name="SecurityTutorialsConnectionString"
connectionString="..."/>
</connectionStrings>
<system.web>
... Additional configuration markup removed for brevity ...
<roleManager enabled="true" defaultProvider="SecurityTutorialsSqlRoleProvider">
<providers>
<add name="SecurityTutorialsSqlRoleProvider"
type="System.Web.Security.SqlRoleProvider"
applicationName="SecurityTutorials"
connectionStringName="SecurityTutorialsConnectionString" />
</providers>
</roleManager>
<system.web>
</configuration>
위의 태그는 를 기본 공급자로 정의합니다 SecurityTutorialsSqlRoleProvider
(요소의 defaultProvider
특성을 <roleManager>
통해). 또한 의 applicationName
설정을 SecurityTutorials
멤버 자격 공급자()에서 사용하는 것과 동일한 applicationName
설정인 로SecurityTutorialsSqlMembershipProvider
설정합니다SecurityTutorialsSqlRoleProvider
. 여기에 <add>
표시되지 않지만 의 요소 SqlRoleProvider
에는 데이터베이스 제한 시간(초)을 지정하는 특성이 포함될 commandTimeout
수도 있습니다. 기본값은 30입니다.
이 구성 태그가 준비되면 애플리케이션 내에서 역할 기능을 사용할 준비가 된 것입니다.
참고
위의 구성 태그는 요소의 enabled
및 defaultProvider
특성을 사용하는 것을><roleManager
보여 줍니다. 역할 프레임워크가 사용자 단위로 역할 정보를 연결하는 방법에 영향을 주는 여러 가지 다른 특성이 있습니다. 역할 기반 권한 부여 자습서에서 이러한 설정을 검토합니다.
3단계: 역할 API 검사
역할 프레임워크의 기능은 역할 기반 작업을 수행하기 위한 13개의 정적 메서드를 포함하는 클래스를 통해 Roles
노출됩니다. 4단계와 6단계에서 역할을 만들고 삭제하는 방법을 살펴보면 시스템에서 역할을 추가하거나 제거하는 및 DeleteRole
메서드를 사용합니다CreateRole
.
시스템의 모든 역할 목록을 얻으려면 메서드를 GetAllRoles
사용합니다(5단계 참조). 메서드는 RoleExists
지정된 역할이 있는지 여부를 나타내는 부울 값을 반환합니다.
다음 자습서에서는 사용자를 역할과 연결하는 방법을 살펴봅니다. 클래스의 AddUserToRole
, , AddUserToRoles
AddUsersToRole
및 AddUsersToRoles
메서드는 Roles
하나 이상의 역할에 하나 이상의 사용자를 추가합니다. 역할에서 사용자를 제거하려면 , , RemoveUserFromRoles
RemoveUsersFromRole
또는 RemoveUsersFromRoles
메서드를 RemoveUserFromRole
사용합니다.
역할 기반 권한 부여 자습서에서는 현재 로그인한 사용자의 역할에 따라 프로그래밍 방식으로 기능을 표시하거나 숨기는 방법을 살펴보겠습니다. 이를 위해 클래스의 FindUsersInRole
, , GetRolesForUser
GetUsersInRole
또는 IsUserInRole
메서드를 사용할 Role
수 있습니다.
참고
이러한 메서드 중 하나가 호출될 때마다 클래스는 Roles
구성된 공급자에게 호출을 위임합니다. 이 경우 호출이 로 전송 SqlRoleProvider
되고 있음을 의미합니다. 그런 다음 호출 SqlRoleProvider
된 메서드에 따라 적절한 데이터베이스 작업을 수행합니다. 예를 들어 코드 Roles.CreateRole("Administrators")
SqlRoleProvider
는 저장 프로시저를 aspnet_Roles_CreateRole
실행하여 Administrators 라는 테이블에 새 레코드를 aspnet_Roles
삽입합니다.
이 자습서의 나머지 부분에서는 클래스의 CreateRole
, GetAllRoles
및 DeleteRole
메서드를 사용하여 Roles
시스템의 역할을 관리하는 방법을 살펴봅니다.
4단계: 새 역할 만들기
역할은 임의로 사용자를 그룹화할 수 있는 방법을 제공하며, 가장 일반적으로 이 그룹화는 권한 부여 규칙을 적용하는 보다 편리한 방법에 사용됩니다. 그러나 역할을 권한 부여 메커니즘으로 사용하려면 먼저 애플리케이션에 존재하는 역할을 정의해야 합니다. 안타깝게도 ASP.NET CreateRoleWizard 컨트롤은 포함되지 않습니다. 새 역할을 추가하려면 적합한 사용자 인터페이스를 만들고 역할 API를 직접 호출해야 합니다. 좋은 소식은 이것이 달성하기가 매우 쉽다는 것입니다.
참고
CreateRoleWizard 웹 컨트롤은 없지만 웹 애플리케이션의 구성을 보고 관리하는 데 도움이 되도록 설계된 로컬 ASP.NET 애플리케이션인 ASP.NET 웹 사이트 관리 도구가 있습니다. 그러나 두 가지 이유로 ASP.NET 웹 사이트 관리 도구의 열렬한 팬이 아닙니다. 첫째, 그것은 조금 버그이며 사용자 환경은 원하는 많은 잎. 둘째, ASP.NET 웹 사이트 관리 도구는 로컬에서만 작동하도록 설계되었으므로 라이브 사이트에서 역할을 원격으로 관리해야 하는 경우 고유한 역할 관리 웹 페이지를 빌드해야 합니다. 이러한 두 가지 이유로 이 자습서와 다음 자습서에서는 ASP.NET 웹 사이트 관리 도구에 의존하지 않고 웹 페이지에서 필요한 역할 관리 도구를 빌드하는 데 중점을 줍니다.
폴더에서 ManageRoles.aspx
Roles
페이지를 열고 TextBox 및 단추 웹 컨트롤을 페이지에 추가합니다. TextBox 컨트롤의 ID
속성을 로 RoleName
설정하고 단추 및 ID
속성을 각각 및 Text
역할 만들기로 CreateRoleButton
설정합니다. 이 시점에서 페이지의 선언적 태그는 다음과 유사하게 표시됩니다.
<b>Create a New Role: </b>
<asp:TextBox ID="RoleName" runat="server"></asp:TextBox>
<br />
<asp:Button ID="CreateRoleButton" runat="server" Text="Create Role" />
다음으로 Designer 단추 컨트롤을 두 번 클릭하여 CreateRoleButton
이벤트 처리기를 만든 Click
다음 다음 코드를 추가합니다.
protected void CreateRoleButton_Click(object sender, EventArgs e)
{
string newRoleName = RoleName.Text.Trim();
if (!Roles.RoleExists(newRoleName))
// Create the role
Roles.CreateRole(newRoleName);
RoleName.Text = string.Empty;
}
위의 코드는 TextBox에 입력한 트리밍된 역할 이름을 변수에 RoleName
할당하여 newRoleName
시작합니다. 다음으로, Roles
클래스의 RoleExists
메서드를 호출하여 역할이 newRoleName
시스템에 이미 있는지 확인합니다. 역할이 없으면 메서드에 대한 호출 CreateRole
을 통해 생성됩니다. 메서드가 CreateRole
시스템에 이미 있는 역할 이름을 전달하면 예외가 ProviderException
throw됩니다. 이 때문에 코드는 먼저 를 호출 CreateRole
하기 전에 시스템에 역할이 없는지 확인합니다. Click
이벤트 처리기는 TextBox의 Text
속성을 지워 RoleName
종료합니다.
참고
사용자가 TextBox에 값을 RoleName
입력하지 않으면 어떤 일이 일어날지 궁금할 수 있습니다. 메서드에 CreateRole
전달된 값이 null
또는 빈 문자열이면 예외가 발생합니다. 마찬가지로 역할 이름에 쉼표가 포함되어 있으면 예외가 발생합니다. 따라서 페이지에는 사용자가 역할을 입력하고 쉼표가 포함되어 있지 않은지 확인하기 위한 유효성 검사 컨트롤이 포함되어야 합니다. 나는 독자를위한 운동으로 떠난다.
Administrators라는 역할을 만들어 보겠습니다. 브라우저를 ManageRoles.aspx
통해 페이지를 방문하여 텍스트 상자에 관리자를 입력한 다음(그림 3 참조) 역할 만들기 단추를 클릭합니다.
그림 3: 관리자 역할 만들기(전체 크기 이미지를 보려면 클릭)
어떻게 되나요? 포스트백이 발생하지만 역할이 실제로 시스템에 추가되었다는 시각적 신호는 없습니다. 시각적 피드백을 포함하도록 5단계에서 이 페이지를 업데이트합니다. 그러나 지금은 데이터베이스로 이동하여 SecurityTutorials.mdf
테이블의 데이터를 aspnet_Roles
표시하여 역할이 만들어졌는지 확인할 수 있습니다. 그림 4와 aspnet_Roles
같이 테이블에 방금 추가한 관리자 역할에 대한 레코드가 포함되어 있습니다.
그림 4: aspnet_Roles
테이블에 관리자용 행이 있습니다(전체 크기 이미지를 보려면 클릭).
5단계: 시스템에서 역할 표시
시스템의 현재 역할 목록을 포함하도록 페이지를 보강 ManageRoles.aspx
해 보겠습니다. 이렇게 하려면 페이지에 GridView 컨트롤을 추가하고 해당 ID
속성을 로 RoleList
설정합니다. 다음으로, 다음 코드를 사용하여 라는 DisplayRolesInGrid
페이지의 코드 숨김 클래스에 메서드를 추가합니다.
private void DisplayRolesInGrid()
{
RoleList.DataSource = Roles.GetAllRoles();
RoleList.DataBind();
}
클래스의 GetAllRoles
메서드는 Roles
시스템의 모든 역할을 문자열 배열로 반환합니다. 그런 다음 이 문자열 배열은 GridView에 바인딩됩니다. 페이지가 처음 로드될 때 역할 목록을 GridView에 바인딩하려면 페이지의 Page_Load
이벤트 처리기에서 메서드를 호출 DisplayRolesInGrid
해야 합니다. 다음 코드는 페이지를 처음 방문할 때 이 메서드를 호출하지만 후속 포스트백에서는 호출하지 않습니다.
protected void Page_Load(object sender, EventArgs e)
{
if (!Page.IsPostBack)
DisplayRolesInGrid();
}
이 코드를 사용하면 브라우저를 통해 페이지를 방문합니다. 그림 5에서 볼 수 있듯이 항목이라는 레이블이 지정된 단일 열이 있는 표가 표시됩니다. 표에는 4단계에서 추가한 관리자 역할에 대한 행이 포함됩니다.
그림 5: GridView는 단일 열에 역할을 표시합니다(전체 크기 이미지를 보려면 클릭).
GridView의 AutoGenerateColumns
속성이 True(기본값)로 설정되어 있으므로 GridView는 Item이라는 고독한 열을 표시하므로 GridView는 의 각 속성에 DataSource
대한 열을 자동으로 만듭니다. 배열에는 배열의 요소를 나타내는 단일 속성이 있으므로 GridView의 단일 열이 있습니다.
GridView를 사용하여 데이터를 표시할 때 GridView에서 암시적으로 생성하지 않고 열을 명시적으로 정의하는 것을 선호합니다. 열을 명시적으로 정의하면 데이터의 서식을 지정하고, 열을 다시 정렬하고, 다른 일반적인 작업을 수행하는 것이 훨씬 쉽습니다. 따라서 해당 열이 명시적으로 정의되도록 GridView의 선언적 태그를 업데이트해 보겠습니다.
먼저 GridView의 AutoGenerateColumns
속성을 False로 설정합니다. 다음으로 Grid에 TemplateField를 추가하고 해당 HeaderText
속성을 Roles로 설정하고 배열의 내용을 표시하도록 구성 ItemTemplate
합니다. 이렇게 하려면 라는 RoleNameLabel
레이블 웹 컨트롤을 에 ItemTemplate
추가하고 해당 Text
속성을 에 바인딩합니다 Container.DataItem
.
이러한 속성 및 ItemTemplate
의 콘텐츠는 선언적으로 또는 GridView의 필드 대화 상자 및 템플릿 편집 인터페이스를 통해 설정할 수 있습니다. 필드 대화 상자에 도달하려면 GridView의 스마트 태그에서 열 편집 링크를 클릭합니다. 그런 다음 필드 자동 생성 확인란의 선택을 취소하여 속성을 False로 설정하고 AutoGenerateColumns
GridView에 TemplateField를 추가하여 속성을 HeaderText
Role로 설정합니다. 의 ItemTemplate
콘텐츠를 정의하려면 GridView의 스마트 태그에서 템플릿 편집 옵션을 선택합니다. 레이블 웹 컨트롤을 로 끌어서 ItemTemplate
속성을 ID
로 설정하고 해당 속성 RoleNameLabel
이 Text
에 바인딩 Container.DataItem
되도록 데이터 바인딩 설정을 구성합니다.
사용하는 방법에 관계없이 GridView의 결과 선언적 태그는 완료되면 다음과 유사하게 표시됩니다.
<asp:GridView ID="RoleList" runat="server" AutoGenerateColumns="false">
<Columns>
<asp:TemplateField HeaderText="Role">
<ItemTemplate>
<asp:Label runat="server" ID="RoleNameLabel" Text='<%# Container.DataItem %>' />
</ItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>
참고
배열의 내용은 데이터 바인딩 구문을 <%# Container.DataItem %>
사용하여 표시됩니다. GridView에 바인딩된 배열의 내용을 표시할 때 이 구문이 사용되는 이유에 대한 자세한 설명은 이 자습서의 scope. 이 문제에 대한 자세한 내용은 스칼라 배열을 데이터 웹 컨트롤에 바인딩을 참조하세요.
현재 RoleList
GridView는 페이지를 처음 방문할 때만 역할 목록에 바인딩됩니다. 새 역할이 추가되면 그리드를 새로 고쳐야 합니다. 이렇게 하려면 새 역할이 만들어지면 메서드를 CreateRoleButton
호출 DisplayRolesInGrid
하도록 Button의 Click
이벤트 처리기를 업데이트합니다.
protected void CreateRoleButton_Click(object sender, EventArgs e)
{
string newRoleName = RoleName.Text.Trim();
if (!Roles.RoleExists(newRoleName))
{
// Create the role
Roles.CreateRole(newRoleName);
// Refresh the RoleList Grid
DisplayRolesInGrid();
}
RoleName.Text = string.Empty;
}
이제 사용자가 새 역할을 RoleList
추가하면 GridView는 포스트백에 방금 추가된 역할을 표시하여 역할이 성공적으로 생성되었다는 시각적 피드백을 제공합니다. 이를 설명하려면 브라우저를 ManageRoles.aspx
통해 페이지를 방문하여 감독자라는 역할을 추가합니다. 역할 만들기 단추를 클릭하면 포스트백이 계속되고 그리드가 업데이트되어 관리자와 새 역할인 감독자가 포함됩니다.
그림 6: 감독자 역할이 추가되었습니다(전체 크기 이미지를 보려면 클릭).
6단계: 역할 삭제
이 시점에서 사용자는 새 역할을 만들고 페이지에서 모든 기존 역할을 ManageRoles.aspx
볼 수 있습니다. 사용자가 역할을 삭제하도록 허용해 보겠습니다. 메서드에는 Roles.DeleteRole
두 개의 오버로드가 있습니다.
DeleteRole(roleName)
- roleName 역할을 삭제합니다. 역할에 하나 이상의 멤버가 포함된 경우 예외가 throw됩니다.DeleteRole(roleName, throwOnPopulatedRole)
- roleName 역할을 삭제합니다. throwOnPopulateRole이true
이면 역할에 하나 이상의 멤버가 포함된 경우 예외가 throw됩니다. throwOnPopulateRole이false
이면 멤버가 포함되어 있는지 여부에 관계없이 역할이 삭제됩니다. 내부적으로 메서드는 를DeleteRole(roleName)
호출합니다DeleteRole(roleName, true)
.
DeleteRole
roleName이 또는 빈 문자열이거나 roleName에 쉼표가 null
포함된 경우에도 메서드가 예외를 throw합니다. roleName이 시스템에 DeleteRole
없으면 예외를 발생시키지 않고 자동으로 실패합니다.
GridView ManageRoles.aspx
를 확대하여 선택한 역할을 삭제하는 삭제 단추를 포함해 보겠습니다. 먼저 필드 대화 상자로 이동하고 CommandField 옵션 아래에 있는 삭제 단추를 추가하여 GridView에 삭제 단추를 추가합니다. 삭제 단추를 맨 왼쪽 열로 만들고 해당 DeleteText
속성을 역할 삭제 로 설정합니다.
그림 7: GridView에 RoleList
삭제 단추 추가(전체 크기 이미지를 보려면 클릭)
삭제 단추를 추가한 후 GridView의 선언적 태그는 다음과 유사하게 표시됩니다.
<asp:GridView ID="RoleList" runat="server" AutoGenerateColumns="False">
<Columns>
<asp:CommandField DeleteText="Delete Role" ShowDeleteButton="True"/>
<asp:TemplateField HeaderText="Role">
<ItemTemplate>
<asp:Label runat="server" ID="RoleNameLabel" Text='<%# Container.DataItem %>' />
</ItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>
다음으로 GridView RowDeleting
의 이벤트에 대한 이벤트 처리기를 만듭니다. 역할 삭제 단추를 클릭할 때 포스트백 시 발생하는 이벤트입니다. 다음 코드를 이벤트 처리기에 추가합니다.
protected void RoleList_RowDeleting(object sender, GridViewDeleteEventArgs e)
{
// Get the RoleNameLabel
Label RoleNameLabel = RoleList.Rows[e.RowIndex].FindControl("RoleNameLabel") as Label;
// Delete the role
Roles.DeleteRole(RoleNameLabel.Text, false);
// Rebind the data to the RoleList grid
DisplayRolesInGrid();
}
코드는 역할 삭제 단추를 클릭한 행의 웹 컨트롤을 프로그래밍 방식으로 참조하여 RoleNameLabel
시작합니다. 그런 다음 메서드가 Roles.DeleteRole
호출되어 및 의 RoleNameLabel
를 전달 Text
하여 역할과 false
연결된 사용자가 있는지 여부에 관계없이 역할을 삭제합니다. 마지막으로 방금 RoleList
삭제한 역할이 그리드에 더 이상 나타나지 않도록 GridView가 새로 고쳐집니다.
참고
역할 삭제 단추는 역할을 삭제하기 전에 사용자로부터 어떤 종류의 확인도 요구하지 않습니다. 작업을 확인하는 가장 쉬운 방법 중 하나는 클라이언트 쪽 확인 대화 상자를 사용하는 것입니다. 이 기술에 대한 자세한 내용은 삭제할 때 Client-Side 확인 추가를 참조하세요.
요약
많은 웹 애플리케이션에는 특정 사용자 클래스에서만 사용할 수 있는 특정 권한 부여 규칙 또는 페이지 수준 기능이 있습니다. 예를 들어 관리자만 액세스할 수 있는 웹 페이지 집합이 있을 수 있습니다. 이러한 권한 부여 규칙을 사용자 단위로 정의하는 대신 역할을 기반으로 규칙을 정의하는 것이 더 유용한 경우가 많습니다. 즉, Scott 및 Jisun 사용자가 관리 웹 페이지에 액세스할 수 있도록 명시적으로 허용하는 대신 관리자 역할의 구성원이 이러한 페이지에 액세스할 수 있도록 허용한 다음 Scott 및 Jisun을 관리자 역할에 속한 사용자로 나타내는 것이 더 유지 관리 가능한 방법입니다.
역할 프레임워크를 사용하면 역할을 쉽게 만들고 관리할 수 있습니다. 이 자습서에서는 Microsoft SQL Server 데이터베이스를 역할 저장소로 사용하는 을 사용하도록 SqlRoleProvider
역할 프레임워크를 구성하는 방법을 검토했습니다. 또한 시스템의 기존 역할을 나열하고 새 역할을 만들고 기존 역할을 삭제할 수 있는 웹 페이지를 만들었습니다. 후속 자습서에서는 역할에 사용자를 할당하는 방법과 역할 기반 권한 부여를 적용하는 방법을 살펴봅니다.
행복한 프로그래밍!
추가 정보
이 자습서에서 설명하는 topics 대한 자세한 내용은 다음 리소스를 참조하세요.
- ASP.NET 2.0의 멤버 자격, 역할 및 프로필 검사
- 방법: ASP.NET 2.0에서 역할 관리자 사용
- 역할 공급자
- 요소에
<roleManager>
대한 기술 설명서 - 멤버 자격 및 역할 관리자 API 사용
저자 정보
여러 ASP/ASP.NET 책의 저자이자 4GuysFromRolla.com 설립자인 Scott Mitchell은 1998년부터 Microsoft 웹 기술을 사용하고 있습니다. Scott은 독립 컨설턴트, 트레이너 및 작가로 일합니다. 그의 최신 책은 샘스 자신을 가르친다 ASP.NET 2.0 24 시간. Scott은 에서 mitchell@4guysfromrolla.com 또는 에서 자신의 블로그 http://ScottOnWriting.NET를 통해 연락할 수 있습니다.
특별 감사
이 자습서 시리즈는 많은 유용한 검토자가 검토했습니다. 이 자습서의 수석 검토자로는 Alicja Maziarz, Suchi Banerjee 및 Teresa Murphy가 있습니다. 예정된 MSDN 문서를 검토하시겠습니까? 그렇다면 에서 줄을 놓습니다. mitchell@4GuysFromRolla.com