IApplicationTrustManager インターフェイス
定義
重要
一部の情報は、リリース前に大きく変更される可能性があるプレリリースされた製品に関するものです。 Microsoft は、ここに記載されている情報について、明示または黙示を問わず、一切保証しません。
アプリケーションを実行するかどうか、およびどのアクセス許可セットをアプリケーションに付与するかを判断します。
public interface class IApplicationTrustManager : System::Security::ISecurityEncodable
[System.Runtime.InteropServices.ComVisible(true)]
public interface IApplicationTrustManager : System.Security.ISecurityEncodable
[<System.Runtime.InteropServices.ComVisible(true)>]
type IApplicationTrustManager = interface
interface ISecurityEncodable
Public Interface IApplicationTrustManager
Implements ISecurityEncodable
- 属性
- 実装
例
次の例は、 の簡単な実装を IApplicationTrustManager示しています。
// To use the custom trust manager MyTrustManager, compile it into CustomTrustManager.dll,
// place that assembly in the GAC, and put the following elements in
// an ApplicationTrust.config file in the config folder in the Microsoft .NET framework
// installation folder.
//<?xml version="1.0" encoding="utf-8" ?>
// <ApplicationEntries />
// <IApplicationTrustManager class="MyNamespace.MyTrustManager, CustomTrustManager, Version=1.0.0.3, Culture=neutral, PublicKeyToken=5659fc598c2a503e"/>
using System;
using System.Security;
using System.Security.Policy;
using System.Windows.Forms;
namespace MyNamespace
{
public class MyTrustManager : IApplicationTrustManager
{
public ApplicationTrust DetermineApplicationTrust(ActivationContext appContext, TrustManagerContext context)
{
ApplicationTrust trust = new ApplicationTrust(appContext.Identity);
trust.IsApplicationTrustedToRun = false;
ApplicationSecurityInfo asi = new ApplicationSecurityInfo(appContext);
trust.DefaultGrantSet = new PolicyStatement(asi.DefaultRequestSet, PolicyStatementAttribute.Nothing);
if (context.UIContext == TrustManagerUIContext.Run)
{
string message = "Do you want to run " + asi.ApplicationId.Name + " ?";
string caption = "MyTrustManager";
MessageBoxButtons buttons = MessageBoxButtons.YesNo;
DialogResult result;
// Displays the MessageBox.
result = MessageBox.Show(message, caption, buttons);
if (result == DialogResult.Yes)
{
trust.IsApplicationTrustedToRun = true;
if (context != null)
trust.Persist = context.Persist;
else
trust.Persist = false;
}
}
return trust;
}
public SecurityElement ToXml()
{
SecurityElement se = new SecurityElement("IApplicationTrustManager");
se.AddAttribute("class", typeof(MyTrustManager).AssemblyQualifiedName);
return se;
}
public void FromXml(SecurityElement se)
{
if (se.Tag != "IApplicationTrustManager" || (string)se.Attributes["class"] != typeof(MyTrustManager).AssemblyQualifiedName)
throw new ArgumentException("Invalid tag");
}
}
}
' To use the custom trust manager MyTrustManager, compile it into CustomTrustManager.dll,
' place that assembly in the GAC, and put the following elements in
' an ApplicationTrust.config file in the config folder in the Microsoft .NET framework
' installation folder.
'<?xml version="1.0" encoding="utf-8" ?>
' <ApplicationEntries />
' <IApplicationTrustManager class="MyNamespace.MyTrustManager, CustomTrustManager, Version=1.0.0.3, Culture=neutral, PublicKeyToken=5659fc598c2a503e"/>
Imports System.Security
Imports System.Security.Policy
Imports System.Windows.Forms
Public Class MyTrustManager
Implements IApplicationTrustManager
Public Function DetermineApplicationTrust(ByVal appContext As ActivationContext, ByVal context As TrustManagerContext) As ApplicationTrust Implements IApplicationTrustManager.DetermineApplicationTrust
Dim trust As New ApplicationTrust(appContext.Identity)
trust.IsApplicationTrustedToRun = False
Dim asi As New ApplicationSecurityInfo(appContext)
trust.DefaultGrantSet = New PolicyStatement(asi.DefaultRequestSet, _
PolicyStatementAttribute.Nothing)
If context.UIContext = TrustManagerUIContext.Run Then
Dim message As String = "Do you want to run " + asi.ApplicationId.Name + " ?"
Dim caption As String = "MyTrustManager"
Dim buttons As MessageBoxButtons = MessageBoxButtons.YesNo
Dim result As DialogResult
' Displays the MessageBox.
result = MessageBox.Show(message, caption, buttons)
If result = DialogResult.Yes Then
trust.IsApplicationTrustedToRun = True
If Not (context Is Nothing) Then
trust.Persist = context.Persist
Else
trust.Persist = False
End If
End If
End If
Return trust
End Function 'DetermineApplicationTrust
Public Function ToXml() As SecurityElement Implements IApplicationTrustManager.ToXml
Dim se As New SecurityElement("IApplicationTrustManager")
se.AddAttribute("class", GetType(MyTrustManager).AssemblyQualifiedName)
Return se
End Function 'ToXml
Public Sub FromXml(ByVal se As SecurityElement) Implements IApplicationTrustManager.FromXml
If se.Tag <> "IApplicationTrustManager" OrElse _
CStr(se.Attributes("class")) <> GetType(MyTrustManager).AssemblyQualifiedName Then
Throw New ArgumentException("Invalid tag")
End If
End Sub
End Class
注釈
信頼マネージャーは、 インターフェイスを実装する IApplicationTrustManager 必要があります。 ホストは メソッドを IApplicationTrustManager.DetermineApplicationTrust 呼び出して、アプリケーションを実行するかどうか、およびアプリケーションに付与する必要があるアクセス許可を決定します。
.NET Framework 4 以降では、信頼マネージャーは 1 つだけで、インターフェイスのIApplicationTrustManagerカスタム実装にすることができます。 既定の信頼マネージャーの実装では、アプリケーションをインストールし、アプリケーションに付与されたアクセス許可を昇格するアクセス許可をユーザーに求めます。 他のトラスト マネージャーの実装では、異なるユーザー エクスペリエンスが提供される場合があります。 たとえば、実装では、その情報をユーザーに求めるのではなく、信頼できるアプリケーションのエンタープライズ リストを確認できます。
メソッド
DetermineApplicationTrust(ActivationContext, TrustManagerContext) |
アプリケーションを実行するかどうか、およびどのアクセス許可セットをアプリケーションに付与するかを判断します。 |
FromXml(SecurityElement) |
XML エンコードから指定された状態で、セキュリティ オブジェクトを再構築します。 (継承元 ISecurityEncodable) |
ToXml() |
セキュリティ オブジェクトとその現在の状態の XML エンコードを作成します。 (継承元 ISecurityEncodable) |
適用対象
.NET