UnauthorizedWebPart クラスとは? わかりやすく解説

UnauthorizedWebPart クラス

メモ : このクラスは、.NET Framework version 2.0新しく追加されたものです。

WebPart コントロールに対して WebPartManager コントロールの IsAuthorized メソッドfalse返す場合に、プレースホルダ オブジェクト作成するために使用されます。このクラス継承できません。

名前空間: System.Web.UI.WebControls.WebParts
アセンブリ: System.Web (system.web.dll 内)
構文構文

Public NotInheritable Class
 UnauthorizedWebPart
    Inherits ProxyWebPart
Dim instance As UnauthorizedWebPart
public sealed class UnauthorizedWebPart : ProxyWebPart
public ref class UnauthorizedWebPart sealed
 : public ProxyWebPart
public final class UnauthorizedWebPart extends
 ProxyWebPart
public final class UnauthorizedWebPart extends
 ProxyWebPart
解説解説

Web パーツ コントロール セットには、個々WebPart コントロールページ追加できるかどうか判断するための承認機構用意されています。開発者は、オプションWebPart コントロールの AuthorizationFilter プロパティ任意の文字列割り当てることができますWebPartManager コントロールページコントロール追加するときに、IsAuthorized メソッド使用して開発者設定した基準に対してこのフィルタ値を確認しコントロール承認されていない場合false返します

メモメモ

サーバー コントロールユーザー コントロール実行時に GenericWebPart オブジェクトラップされ、このオブジェクトAuthorizationFilter プロパティ継承するため、この承認機構は、WebPartZoneBase ゾーン配置されたこれらのコントロールでも動作します

WebPart コントロール承認されていない場合WebPartManager コントロールは、承認されていないコントロール代わりに UnauthorizedWebPart コントロールページコントロール ツリー挿入しますコントロール ツリー内の UnauthorizedWebPart コントロールは、ページ内の承認されていないコントロール位置予約しユーザー以前 WebPart コントロール適用したパーソナル化データ失われるのを防ぎます

UnauthorizedWebPart コントロールは、その挿入先となるページには表示されず、また表示されるページソース コード内にも出現しません。開発者は、WebPartManager コントロールWebParts プロパティ調べることにより、ページコントロール ツリー内にそれが存在することを確認できます

使用例使用例

UnauthorizedWebPart コントロール使用方法を示すコード例次に示します

コード例最初部分は、IsAuthorized(WebPart) メソッドオーバーライドしてカスタム承認基準作成するカスタム WebPartManager コントロールです。特定の値設定されAuthorizationFilter プロパティを持つ WebPart コントロール、またはそのプロパティに値が割り当てられていないコントロール承認されますが、これらの基準満たさないコントロール承認されません。

Imports System
Imports System.Web
Imports System.Web.Security
Imports System.Security.Permissions
Imports System.Web.UI
Imports System.Web.UI.WebControls
Imports System.Web.UI.WebControls.WebParts

Namespace Samples.AspNet.VB.Controls

  <AspNetHostingPermission(SecurityAction.Demand, _
    Level:=AspNetHostingPermissionLevel.Minimal)> _
  <AspNetHostingPermission(SecurityAction.InheritanceDemand, _
    Level:=AspNetHostingPermissionLevel.Minimal)> _
  Public Class MyManagerAuthorize
    Inherits WebPartManager

    Public Overrides Function
 IsAuthorized(ByVal type As Type, _
      ByVal path As String,
 ByVal authorizationFilter As String,
 _
      ByVal isShared As Boolean)
 As Boolean

      If Not String.IsNullOrEmpty(authorizationFilter)
 Then
        If authorizationFilter = "admin"
 Then
          Return True
        Else
          Return False
        End If
      Else
        Return True
      End If

    End Function

  End Class

End Namespace
using System;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;

namespace Samples.AspNet.CS.Controls
{
  public class MyManagerAuthorize : WebPartManager
  {
    public override bool IsAuthorized(Type
 type, string path, string authorizationFilter,
 bool isShared)
    {
      if (!String.IsNullOrEmpty(authorizationFilter))
      {
        if (authorizationFilter == "admin")
          return true;
        else
          return false;
      }
      else
        return true;

    }
  }
}

コード例2 番目の部分は、カスタム WebPartManager コントロールホストする Web ページです。ここでは、<asp:webpartzone> 要素内に 3 つの静的サーバー コントロール宣言されています。これらのコントロール実際にWebPart コントロールではありませんが、実行時にこれらが GenericWebPart オブジェクトラップされるため、これらを WebPart コントロールとして処理しAuthorizationFilter プロパティに値を割り当てることができます。BulletedList コントロールは、カスタム WebPartManager コントロール基準に従ってそのコントロール承認されるように値が設定されフィルタ保持しますLabel コントロールは、承認されないように設定されフィルタ値を保持しますCalendar コントロールプロパティに値を割り当てないため、既定承認されます。

<%@ Page Language="vb" %>
<%@ Register Namespace="Samples.AspNet.VB.Controls"
 
    TagPrefix="aspSample"%>


<script runat="server">

  Protected Sub Page_Load(ByVal
 sender As Object, _
    ByVal e As System.EventArgs)
    
    Dim part As WebPart
    For Each part In mgr1.WebParts
      If mgr1.IsAuthorized(part) Then
        part.ExportMode = WebPartExportMode.All
      End If
    Next
  End Sub

  Protected Sub Button1_Click(ByVal
 sender As Object, _
    ByVal e As System.EventArgs)
    
    Label2.Text = String.Empty
    Dim part As WebPart
    
    For Each part In mgr1.WebParts
      Label2.Text += part.ID & "<br />"
    Next

  End Sub
</script>

<html  >
<head id="Head1" runat="server">
    <title>Untitled Page</title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
      <aspSample:MyManagerAuthorize ID="mgr1" runat="server"
 />
      <asp:WebPartZone ID="WebPartZone1" runat="server">
        <ZoneTemplate>
          <asp:BulletedList 
            ID="BulletedList1" 
            Runat="server"
            DisplayMode="HyperLink" 
            Title="Favorite Links"
            AuthorizationFilter="admin">
            <asp:ListItem Value="http://msdn.microsoft.com">
              MSDN
            </asp:ListItem>
            <asp:ListItem Value="http://www.asp.net">
              ASP.NET
            </asp:ListItem>
            <asp:ListItem Value="http://www.msn.com">
              MSN
            </asp:ListItem>
          </asp:BulletedList>
          <asp:Label ID="Label1" runat="server"
 
            Text="Hello World"
            AuthorizationFilter="user" />
          <asp:Calendar ID="Calendar1" runat="server"></asp:Calendar>
        </ZoneTemplate>
      </asp:WebPartZone>
      <hr />
      <asp:Button ID="Button1" runat="server"
 
        Text="List WebPart Controls" OnClick="Button1_Click"
 />
      <br />
      <asp:Label ID="Label2" runat="server"
 
        Text="" />
    </div>
    </form>
</body>
</html>
<%@ Page Language="C#" %>
<%@ Register TagPrefix="aspSample"
    Namespace="Samples.AspNet.CS.Controls" %>

<script runat="server">
  
  protected void Page_Load(object sender, EventArgs
 e)
  {
    foreach (WebPart part in mgr1.WebParts)
    {
      if (mgr1.IsAuthorized(part))
        part.ExportMode = WebPartExportMode.All;
    }
   
  }

  protected void Button1_Click(object sender,
 EventArgs e)
  {
    Label2.Text = String.Empty;
    
    foreach (WebPart part in mgr1.WebParts)
      Label2.Text += part.ID + "<br />";
  }
</script>

<html  >
<head runat="server">
    <title>Untitled Page</title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
      <aspSample:MyManagerAuthorize ID="mgr1" runat="server"
 />
      <asp:WebPartZone ID="WebPartZone1" runat="server">
        <ZoneTemplate>
          <asp:BulletedList 
            ID="BulletedList1" 
            Runat="server"
            DisplayMode="HyperLink" 
            Title="Favorite Links"
            AuthorizationFilter="admin">
            <asp:ListItem Value="http://msdn.microsoft.com">
              MSDN
            </asp:ListItem>
            <asp:ListItem Value="http://www.asp.net">
              ASP.NET
            </asp:ListItem>
            <asp:ListItem Value="http://www.msn.com">
              MSN
            </asp:ListItem>
          </asp:BulletedList>
          <asp:Label ID="Label1" runat="server" 
            Text="Hello World"
            AuthorizationFilter="user" />
          <asp:Calendar ID="Calendar1" runat="server"></asp:Calendar>
        </ZoneTemplate>
      </asp:WebPartZone>
      <hr />
      <asp:Button ID="Button1" runat="server" 
        Text="List WebPart Controls" OnClick="Button1_Click"
 />
      <br />
      <asp:Label ID="Label2" runat="server" 
        Text="" />
    </div>
    </form>
</body>
</html>

コード例3 番目の部分は、Web パーツ記述ファイルエクスポートできるようにするために Web.config ファイル追加する必要のある設定です。このコード例Web ページと同じディレクトリ内に Web.config ファイル存在することを確認してください<system.web> セクション内に、次のマークアップのように、true設定されenableExport 属性を持つ <webParts> 要素存在することを確認します

<webParts enableExport="true">

...

</webParts>

ブラウザページ読み込みBulletedList コントロールCalendar コントロール予期したとおりに表示されても、Label コントロール承認されなかったため表示されないことを確認します。[List WebPart Controls] ボタンクリックすると、WebPartManager コントロールによって WebParts コレクション内のすべてのコントロールID一覧表示されます。Label コントロールID が一覧に示されページラベル表示されなくても、UnauthorizedWebPart コントロールページコントロール ツリー追加されその場所が保持されていることがわかります

.NET Framework のセキュリティ.NET Frameworkセキュリティ
継承階層継承階層
System.Object
   System.Web.UI.Control
     System.Web.UI.WebControls.WebControl
       System.Web.UI.WebControls.Panel
         System.Web.UI.WebControls.WebParts.Part
           System.Web.UI.WebControls.WebParts.WebPart
             System.Web.UI.WebControls.WebParts.ProxyWebPart
              System.Web.UI.WebControls.WebParts.UnauthorizedWebPart
スレッド セーフスレッド セーフ
この型の public static (Visual Basic では Shared) メンバはすべて、スレッド セーフです。インスタンス メンバ場合は、スレッド セーフであるとは限りません。
プラットフォームプラットフォーム
バージョン情報バージョン情報
参照参照
関連項目
UnauthorizedWebPart メンバ
System.Web.UI.WebControls.WebParts 名前空間
IsAuthorized
その他の技術情報
ASP.NET Web パーツ ページ



英和和英テキスト翻訳>> Weblio翻訳
英語⇒日本語日本語⇒英語
  

辞書ショートカット

すべての辞書の索引

「UnauthorizedWebPart クラス」の関連用語

UnauthorizedWebPart クラスのお隣キーワード
検索ランキング

   

英語⇒日本語
日本語⇒英語
   



UnauthorizedWebPart クラスのページの著作権
Weblio 辞書 情報提供元は 参加元一覧 にて確認できます。

   
日本マイクロソフト株式会社日本マイクロソフト株式会社
© 2025 Microsoft.All rights reserved.

©2025 GRAS Group, Inc.RSS