RealProxy RealProxy RealProxy RealProxy Class

Definition

プロキシの基本機能を提供します。 Provides base functionality for proxies.

public ref class RealProxy abstract
[System.Runtime.InteropServices.ComVisible(true)]
[System.Security.SecurityCritical]
public abstract class RealProxy
type RealProxy = class
Public MustInherit Class RealProxy
Inheritance
RealProxyRealProxyRealProxyRealProxy
Attributes

Examples

// Create a custom 'RealProxy'.
public ref class MyProxy: public RealProxy
{
private:
   String^ myURIString;
   MarshalByRefObject^ myMarshalByRefObject;

public:
   MyProxy( Type^ myType )
      : RealProxy( myType )
   {
      
      // RealProxy uses the Type to generate a transparent proxy.
      myMarshalByRefObject = dynamic_cast<MarshalByRefObject^>(Activator::CreateInstance(myType));
      
      // Get 'ObjRef', for transmission serialization between application domains.
      ObjRef^ myObjRef = RemotingServices::Marshal( myMarshalByRefObject );
      
      // Get the 'URI' property of 'ObjRef' and store it.
      myURIString = myObjRef->URI;
      Console::WriteLine( "URI :{0}", myObjRef->URI );
   }

   virtual IMessage^ Invoke ( IMessage^ myIMessage ) override 
	{
      Console::WriteLine( "MyProxy.Invoke Start" );
      Console::WriteLine( "" );
      if ( dynamic_cast<IMethodCallMessage^>(myIMessage) )
            Console::WriteLine( "IMethodCallMessage" );

      if ( dynamic_cast<IMethodReturnMessage^>(myIMessage) )
            Console::WriteLine( "IMethodReturnMessage" );

      Type^ msgType = myIMessage->GetType();
      Console::WriteLine( "Message Type: {0}", msgType );
      Console::WriteLine( "Message Properties" );
      IDictionary^ myIDictionary = myIMessage->Properties;
      
      // Set the '__Uri' property of 'IMessage' to 'URI' property of 'ObjRef'.
      myIDictionary->default[ "__Uri" ] = myURIString;
      IDictionaryEnumerator^ myIDictionaryEnumerator = dynamic_cast<IDictionaryEnumerator^>(myIDictionary->GetEnumerator());
      while ( myIDictionaryEnumerator->MoveNext() )
      {
         Object^ myKey = myIDictionaryEnumerator->Key;
         String^ myKeyName = myKey->ToString();
         Object^ myValue = myIDictionaryEnumerator->Value;
         Console::WriteLine( "\t{0} : {1}", myKeyName, myIDictionaryEnumerator->Value );
         if ( myKeyName->Equals( "__Args" ) )
         {
            array<Object^>^myObjectArray = (array<Object^>^)myValue;
            for ( int aIndex = 0; aIndex < myObjectArray->Length; aIndex++ )
               Console::WriteLine( "\t\targ: {0} myValue: {1}", aIndex, myObjectArray[ aIndex ] );
         }

         if ( (myKeyName->Equals( "__MethodSignature" )) && (nullptr != myValue) )
         {
            array<Object^>^myObjectArray = (array<Object^>^)myValue;
            for ( int aIndex = 0; aIndex < myObjectArray->Length; aIndex++ )
               Console::WriteLine( "\t\targ: {0} myValue: {1}", aIndex, myObjectArray[ aIndex ] );
         }
      }

      IMessage^ myReturnMessage;
      myIDictionary->default[ "__Uri" ] = myURIString;
      Console::WriteLine( "__Uri {0}", myIDictionary->default[ "__Uri" ] );
      Console::WriteLine( "ChannelServices.SyncDispatchMessage" );
      myReturnMessage = ChannelServices::SyncDispatchMessage( myIMessage );
      
      // Push return value and OUT parameters back onto stack.
      IMethodReturnMessage^ myMethodReturnMessage = dynamic_cast<IMethodReturnMessage^>(myReturnMessage);
      Console::WriteLine( "IMethodReturnMessage.ReturnValue: {0}", myMethodReturnMessage->ReturnValue );
      Console::WriteLine( "MyProxy.Invoke - Finish" );
      return myReturnMessage;
   }
};
// Create a custom 'RealProxy'.
public class MyProxy : RealProxy
{
   String myURIString;
   MarshalByRefObject myMarshalByRefObject;   

   [PermissionSet(SecurityAction.LinkDemand)]
   public MyProxy(Type myType) : base(myType)
   {
      // RealProxy uses the Type to generate a transparent proxy.
      myMarshalByRefObject = (MarshalByRefObject)Activator.CreateInstance((myType));
      // Get 'ObjRef', for transmission serialization between application domains.
      ObjRef myObjRef = RemotingServices.Marshal(myMarshalByRefObject);
      // Get the 'URI' property of 'ObjRef' and store it.
      myURIString = myObjRef.URI;
      Console.WriteLine("URI :{0}", myObjRef.URI);
   }

   [SecurityPermissionAttribute(SecurityAction.LinkDemand, Flags=SecurityPermissionFlag.Infrastructure)]
   public override IMessage Invoke(IMessage myIMessage)
   {
      Console.WriteLine("MyProxy.Invoke Start");
      Console.WriteLine("");

      if (myIMessage is IMethodCallMessage)
         Console.WriteLine("IMethodCallMessage");

      if (myIMessage is IMethodReturnMessage)
         Console.WriteLine("IMethodReturnMessage");

      Type msgType = myIMessage.GetType();
      Console.WriteLine("Message Type: {0}", msgType.ToString());
      Console.WriteLine("Message Properties");
      IDictionary myIDictionary = myIMessage.Properties;
      // Set the '__Uri' property of 'IMessage' to 'URI' property of 'ObjRef'.
      myIDictionary["__Uri"] = myURIString;
      IDictionaryEnumerator myIDictionaryEnumerator = 
         (IDictionaryEnumerator) myIDictionary.GetEnumerator();

      while (myIDictionaryEnumerator.MoveNext())
      {
         Object myKey = myIDictionaryEnumerator.Key;
         String myKeyName = myKey.ToString();
         Object myValue = myIDictionaryEnumerator.Value;

         Console.WriteLine("\t{0} : {1}", myKeyName, 
            myIDictionaryEnumerator.Value);
         if (myKeyName == "__Args")
         {
            Object[] myObjectArray = (Object[])myValue;
            for (int aIndex = 0; aIndex < myObjectArray.Length; aIndex++)
               Console.WriteLine("\t\targ: {0} myValue: {1}", aIndex, 
                  myObjectArray[aIndex]);
         }

         if ((myKeyName == "__MethodSignature") && (null != myValue))
         {
            Object[] myObjectArray = (Object[])myValue;
            for (int aIndex = 0; aIndex < myObjectArray.Length; aIndex++)
               Console.WriteLine("\t\targ: {0} myValue: {1}", aIndex, 
                  myObjectArray[aIndex]);
         }
      }
      
      IMessage myReturnMessage;

      myIDictionary["__Uri"] = myURIString;
      Console.WriteLine("__Uri {0}", myIDictionary["__Uri"]);

      Console.WriteLine("ChannelServices.SyncDispatchMessage");
      myReturnMessage = ChannelServices.SyncDispatchMessage(myIMessage);

      // Push return value and OUT parameters back onto stack.

      IMethodReturnMessage myMethodReturnMessage = (IMethodReturnMessage)
         myReturnMessage;
      Console.WriteLine("IMethodReturnMessage.ReturnValue: {0}", 
         myMethodReturnMessage.ReturnValue);

      Console.WriteLine("MyProxy.Invoke - Finish");

      return myReturnMessage;
   }
}
' Create a custom 'RealProxy'.
Public Class MyProxy
   Inherits RealProxy
   Private myURIString As String
   Private myMarshalByRefObject As MarshalByRefObject

   <PermissionSet(SecurityAction.LinkDemand)> _
   Public Sub New(ByVal myType As Type)
      MyBase.New(myType)
      ' RealProxy uses the Type to generate a transparent proxy.
      myMarshalByRefObject = CType(Activator.CreateInstance(myType), MarshalByRefObject)
      ' Get 'ObjRef', for transmission serialization between application domains.
      Dim myObjRef As ObjRef = RemotingServices.Marshal(myMarshalByRefObject)
      ' Get the 'URI' property of 'ObjRef' and store it.
      myURIString = myObjRef.URI
      Console.WriteLine("URI :{0}", myObjRef.URI)
   End Sub 'New

<SecurityPermissionAttribute(SecurityAction.LinkDemand, Flags:=SecurityPermissionFlag.Infrastructure)> _
   Public Overrides Function Invoke(ByVal myIMessage As IMessage) As IMessage
      Console.WriteLine("MyProxy.Invoke Start")
      Console.WriteLine("")

      If TypeOf myIMessage Is IMethodCallMessage Then
         Console.WriteLine("IMethodCallMessage")
      End If
      If TypeOf myIMessage Is IMethodReturnMessage Then
         Console.WriteLine("IMethodReturnMessage")
      End If
      Dim msgType As Type
      msgType = CObj(myIMessage).GetType
      Console.WriteLine("Message Type: {0}", msgType.ToString())
      Console.WriteLine("Message Properties")
      Dim myIDictionary As IDictionary = myIMessage.Properties
      ' Set the '__Uri' property of 'IMessage' to 'URI' property of 'ObjRef'.
      myIDictionary("__Uri") = myURIString
      Dim myIDictionaryEnumerator As IDictionaryEnumerator = CType(myIDictionary.GetEnumerator(), _
                                                                    IDictionaryEnumerator)

      While myIDictionaryEnumerator.MoveNext()
         Dim myKey As Object = myIDictionaryEnumerator.Key
         Dim myKeyName As String = myKey.ToString()
         Dim myValue As Object = myIDictionaryEnumerator.Value

         Console.WriteLine(ControlChars.Tab + "{0} : {1}", myKeyName, myIDictionaryEnumerator.Value)
         If myKeyName = "__Args" Then
            Dim myObjectArray As Object() = CType(myValue, Object())
            Dim aIndex As Integer
            For aIndex = 0 To myObjectArray.Length - 1
               Console.WriteLine(ControlChars.Tab + ControlChars.Tab + "arg: {0} myValue: {1}", _
                                                              aIndex, myObjectArray(aIndex))
             Next aIndex
         End If

         If myKeyName = "__MethodSignature" And Not Nothing Is myValue Then
            Dim myObjectArray As Object() = CType(myValue, Object())
            Dim aIndex As Integer
            For aIndex = 0 To myObjectArray.Length - 1
               Console.WriteLine(ControlChars.Tab + ControlChars.Tab + "arg: {0} myValue: {1}", _
                                                           aIndex, myObjectArray(aIndex))
            Next aIndex
         End If
      End While

        Dim myReturnMessage As IMessage

        myIDictionary("__Uri") = myURIString
        Console.WriteLine("__Uri {0}", myIDictionary("__Uri"))

        Console.WriteLine("ChannelServices.SyncDispatchMessage")
        myReturnMessage = ChannelServices.SyncDispatchMessage(CObj(myIMessage))

        ' Push return value and OUT parameters back onto stack.
        Dim myMethodReturnMessage As IMethodReturnMessage = CType(myReturnMessage, IMethodReturnMessage)
        Console.WriteLine("IMethodReturnMessage.ReturnValue: {0}", myMethodReturnMessage.ReturnValue)

        Console.WriteLine("MyProxy.Invoke - Finish")

        Return myReturnMessage
    End Function 'Invoke
End Class 'MyProxy

Remarks

RealProxyクラスは、abstract基底クラスのプロキシの派生元となる必要があります。The RealProxy class is the abstract base class from which proxies must derive.

あらゆる種類のリモート処理境界を越えてオブジェクトを使用するクライアントは、透過プロキシを使用して、オブジェクトは実際にします。A client that uses an object across any kind of a remoting boundary is actually using a transparent proxy for the object. 透過プロキシは、クライアントの領域で、実際のオブジェクトが置かれている錯覚を提供します。The transparent proxy provides the illusion that the actual object resides in the client's space. リモート処理インフラストラクチャを使用して実際のオブジェクトに、それに対して行われた呼び出しを転送することによって、これを実現します。It achieves this by forwarding calls made on it to the real object using the remoting infrastructure.

透過プロキシは、型のマネージ ランタイム クラスのインスタンス自体はRealProxyします。The transparent proxy is itself housed by an instance of a managed runtime class of type RealProxy. RealProxy透過プロキシから、操作を転送するために必要な機能の一部を実装します。The RealProxy implements a part of the functionality that is needed to forward the operations from the transparent proxy. プロキシ オブジェクトがガベージ コレクション、フィールドおよびメソッドのサポートなどの管理オブジェクトに関連付けられたセマンティクスを継承し、フォームの新しいクラスを拡張できることに注意してください。Note that a proxy object inherits the associated semantics of managed objects such as garbage collection, support for fields and methods, and can be extended to form new classes. プロキシは、デュアルという性質を持って: リモート オブジェクト (透過プロキシ) と同じクラスのオブジェクトとして機能することとは、マネージ オブジェクト自体です。The proxy has a dual nature: it acts as an object of the same class as the remote object (transparent proxy), and it is a managed object itself.

プロキシ オブジェクトを使用して、内の任意のリモート処理再分割に関係なく、AppDomainします。A proxy object can be used without regard to any remoting subdivisions within a AppDomain.

注意

このクラスは、リンク確認要求し、クラス レベルで継承確認要求を使用します。This class makes a link demand and an inheritance demand at the class level. ASecurityException直前の呼び出し元または派生クラスのいずれかにインフラストラクチャ アクセス許可があるない場合にスローされます。A SecurityException is thrown when either the immediate caller or the derived class does not have infrastructure permission. セキュリティ要求の詳細については、次を参照してください。リンク確認要求継承確認要求します。For details about security demands, see Link Demands and Inheritance Demands.

Notes to Inheritors

継承する場合RealProxy、オーバーライドする必要があります、Invoke(IMessage)メソッド。 When you inherit from RealProxy, you must override the Invoke(IMessage) method.

Constructors

RealProxy() RealProxy() RealProxy() RealProxy()

RealProxy クラスの新しいインスタンスを既定値で初期化します。 Initializes a new instance of the RealProxy class with default values.

RealProxy(Type) RealProxy(Type) RealProxy(Type) RealProxy(Type)

指定した RealProxy のリモート オブジェクトを表す、Type クラスの新しいインスタンスを初期化します。 Initializes a new instance of the RealProxy class that represents a remote object of the specified Type.

RealProxy(Type, IntPtr, Object) RealProxy(Type, IntPtr, Object) RealProxy(Type, IntPtr, Object) RealProxy(Type, IntPtr, Object)

RealProxy クラスの新しいインスタンスを初期化します。 Initializes a new instance of the RealProxy class.

Methods

AttachServer(MarshalByRefObject) AttachServer(MarshalByRefObject) AttachServer(MarshalByRefObject) AttachServer(MarshalByRefObject)

現在のプロキシ インスタンスを、指定したリモート MarshalByRefObject に結び付けます。 Attaches the current proxy instance to the specified remote MarshalByRefObject.

CreateObjRef(Type) CreateObjRef(Type) CreateObjRef(Type) CreateObjRef(Type)

指定したオブジェクト型の ObjRef を作成し、リモート処理インフラストラクチャでクライアント側でアクティブ化されるオブジェクトとして登録します。 Creates an ObjRef for the specified object type, and registers it with the remoting infrastructure as a client-activated object.

DetachServer() DetachServer() DetachServer() DetachServer()

現在のプロキシ インスタンスが表すリモート サーバー オブジェクトから、現在のプロキシ インスタンスを分離します。 Detaches the current proxy instance from the remote server object that it represents.

Equals(Object) Equals(Object) Equals(Object) Equals(Object)

指定したオブジェクトが、現在のオブジェクトと等しいかどうかを判断します。 Determines whether the specified object is equal to the current object.

(Inherited from Object)
GetCOMIUnknown(Boolean) GetCOMIUnknown(Boolean) GetCOMIUnknown(Boolean) GetCOMIUnknown(Boolean)

現在のプロキシ インスタンスが表すオブジェクトへのアンマネージ参照を要求します。 Requests an unmanaged reference to the object represented by the current proxy instance.

GetHashCode() GetHashCode() GetHashCode() GetHashCode()

既定のハッシュ関数として機能します。 Serves as the default hash function.

(Inherited from Object)
GetObjectData(SerializationInfo, StreamingContext) GetObjectData(SerializationInfo, StreamingContext) GetObjectData(SerializationInfo, StreamingContext) GetObjectData(SerializationInfo, StreamingContext)

RealProxy の現在のインスタンスが表すオブジェクトの透過プロキシを、指定した SerializationInfo に追加します。 Adds the transparent proxy of the object represented by the current instance of RealProxy to the specified SerializationInfo.

GetProxiedType() GetProxiedType() GetProxiedType() GetProxiedType()

Type の現在のインスタンスが表すオブジェクトの RealProxy を返します。 Returns the Type of the object that the current instance of RealProxy represents.

GetStubData(RealProxy) GetStubData(RealProxy) GetStubData(RealProxy) GetStubData(RealProxy)

指定したプロキシ用に格納されたスタブ データを取得します。 Retrieves stub data that is stored for the specified proxy.

GetTransparentProxy() GetTransparentProxy() GetTransparentProxy() GetTransparentProxy()

RealProxy の現在のインスタンスの透過プロキシを返します。 Returns the transparent proxy for the current instance of RealProxy.

GetType() GetType() GetType() GetType()

現在のインスタンスの Type を取得します。 Gets the Type of the current instance.

(Inherited from Object)
GetUnwrappedServer() GetUnwrappedServer() GetUnwrappedServer() GetUnwrappedServer()

現在のプロキシ インスタンスが表すサーバー オブジェクトを返します。 Returns the server object that is represented by the current proxy instance.

InitializeServerObject(IConstructionCallMessage) InitializeServerObject(IConstructionCallMessage) InitializeServerObject(IConstructionCallMessage) InitializeServerObject(IConstructionCallMessage)

指定した Type を使用して、RealProxy の現在のインスタンスが表すリモート オブジェクトのオブジェクト IConstructionCallMessage の新しいインスタンスを初期化します。 Initializes a new instance of the object Type of the remote object that the current instance of RealProxy represents with the specified IConstructionCallMessage.

Invoke(IMessage) Invoke(IMessage) Invoke(IMessage) Invoke(IMessage)

派生クラスでオーバーライドされた場合は、提供された IMessage で指定されたメソッドを、現在のインスタンスが表すリモート オブジェクトで呼び出します。 When overridden in a derived class, invokes the method that is specified in the provided IMessage on the remote object that is represented by the current instance.

MemberwiseClone() MemberwiseClone() MemberwiseClone() MemberwiseClone()

現在の Object の簡易コピーを作成します。 Creates a shallow copy of the current Object.

(Inherited from Object)
SetCOMIUnknown(IntPtr) SetCOMIUnknown(IntPtr) SetCOMIUnknown(IntPtr) SetCOMIUnknown(IntPtr)

現在のインスタンスが表すオブジェクトのアンマネージ プロキシを格納します。 Stores an unmanaged proxy of the object that is represented by the current instance.

SetStubData(RealProxy, Object) SetStubData(RealProxy, Object) SetStubData(RealProxy, Object) SetStubData(RealProxy, Object)

指定したプロキシのスタブ データを設定します。 Sets the stub data for the specified proxy.

SupportsInterface(Guid) SupportsInterface(Guid) SupportsInterface(Guid) SupportsInterface(Guid)

指定した ID を使用して COM インターフェイスを要求します。 Requests a COM interface with the specified ID.

ToString() ToString() ToString() ToString()

現在のオブジェクトを表す文字列を返します。 Returns a string that represents the current object.

(Inherited from Object)

Security

SecurityPermission
インフラストラクチャ コードを操作します。 For operating with infrastructure code. 要求値: InheritanceDemand;アクセス許可の値。 Infrastructure Demand value: InheritanceDemand; Permission Value: Infrastructure

Applies to