RealProxy Costruttori

Definizione

Inizializza una nuova istanza della classe RealProxy.

Overload

RealProxy()

Inizializza una nuova istanza della classe RealProxy con i valori predefiniti.

RealProxy(Type)

Inizializza una nuova istanza della classe RealProxy che rappresenta un oggetto remoto del Type specificato.

RealProxy(Type, IntPtr, Object)

Inizializza una nuova istanza della classe RealProxy.

RealProxy()

Inizializza una nuova istanza della classe RealProxy con i valori predefiniti.

C#
protected RealProxy ();

Esempio

C#
using System;
using System.Collections;
using System.Runtime.Serialization;
using System.Runtime.Remoting;
using System.Runtime.Remoting.Activation;
using System.Runtime.Remoting.Channels;
using System.Runtime.Remoting.Proxies;
using System.Runtime.Remoting.Messaging;
using System.Runtime.Remoting.Contexts;

namespace Samples
{
   [AttributeUsage(AttributeTargets.Class)]
   public class MyProxyAttribute : ProxyAttribute
   {
      public MyProxyAttribute()
      {
      }
      // Create an instance of ServicedComponentProxy
      public override MarshalByRefObject CreateInstance(Type serverType)
      {
         return base.CreateInstance(serverType);
      }
      public override RealProxy CreateProxy(ObjRef objRef1,
         Type serverType,
         object serverObject,
         Context serverContext)
      {
         MyProxy myCustomProxy = new MyProxy(serverType);
         if(serverContext != null)
         {
            RealProxy.SetStubData(myCustomProxy,serverContext);
         }
         if((!serverType.IsMarshalByRef)&&(serverContext == null))
         {
            throw new RemotingException("Bad Type for CreateProxy");
         }
         return myCustomProxy;
      }
   }
   [MyProxyAttribute]
   public class CustomServer :ContextBoundObject
   {
      public CustomServer()
      {
         Console.WriteLine("CustomServer Base Class constructor called");
      }
      public void HelloMethod(string str)
      {
         Console.WriteLine("HelloMethod of Server is invoked with message : " + str);
      }
   }
   public class MyProxy : RealProxy
   {
      String myUri;
      MarshalByRefObject myMarshalByRefObject;
      public MyProxy(): base()
      {
         Console.WriteLine("MyProxy Constructor Called...");
         myMarshalByRefObject = (MarshalByRefObject)Activator.CreateInstance(typeof(CustomServer));
         ObjRef myObjRef = RemotingServices.Marshal(myMarshalByRefObject);
         myUri = myObjRef.URI;
      }
      public MyProxy(Type type1): base(type1)
      {
         Console.WriteLine("MyProxy Constructor Called...");
         myMarshalByRefObject = (MarshalByRefObject)Activator.CreateInstance(type1);
         ObjRef myObjRef = RemotingServices.Marshal(myMarshalByRefObject);
         myUri = myObjRef.URI;
      }
      public MyProxy(Type type1, MarshalByRefObject targetObject) : base(type1)
      {
         Console.WriteLine("MyProxy Constructor Called...");
         myMarshalByRefObject = targetObject;
         ObjRef myObjRef = RemotingServices.Marshal(myMarshalByRefObject);
         myUri = myObjRef.URI;
      }
      public override IMessage Invoke(IMessage myMessage)
      {
         Console.WriteLine("MyProxy 'Invoke method' Called...");
         if (myMessage is IMethodCallMessage)
         {
            Console.WriteLine("IMethodCallMessage");
         }
         if (myMessage is IMethodReturnMessage)
         {
            Console.WriteLine("IMethodReturnMessage");
         }
         if (myMessage is IConstructionCallMessage)
         {
            // Initialize a new instance of remote object
            IConstructionReturnMessage myIConstructionReturnMessage =
               this.InitializeServerObject((IConstructionCallMessage)myMessage);
            ConstructionResponse constructionResponse = new
               ConstructionResponse(null,(IMethodCallMessage) myMessage);
            return constructionResponse;
         }
         IDictionary myIDictionary = myMessage.Properties;
         IMessage returnMessage;
         myIDictionary["__Uri"] = myUri;

         // Synchronously dispatch messages to server.
         returnMessage = ChannelServices.SyncDispatchMessage(myMessage);
         // Pushing return value and OUT parameters back onto stack.
         IMethodReturnMessage myMethodReturnMessage = (IMethodReturnMessage)returnMessage;
         return returnMessage;
      }
      public override ObjRef CreateObjRef(Type ServerType)
      {
         Console.WriteLine ("CreateObjRef Method Called ...");
         CustomObjRef myObjRef = new CustomObjRef(myMarshalByRefObject,ServerType);
         myObjRef.URI = myUri ;
         return myObjRef;
      }
      public override void GetObjectData( SerializationInfo info,
                                          StreamingContext context)
      {
         // Add your custom data if any here.
         base.GetObjectData(info, context);
      }
      public class CustomObjRef :ObjRef
      {
         public CustomObjRef(MarshalByRefObject myMarshalByRefObject,Type serverType):
                           base(myMarshalByRefObject,serverType)
         {
            Console.WriteLine("ObjRef 'Constructor' called");
         }
         // Override this method to store custom data.
         public override void GetObjectData(SerializationInfo info,
                                            StreamingContext context)
         {
            base.GetObjectData(info,context);
         }
      }
   }
   public class ProxySample
   {
      // Acts as a custom proxy user.
            public static void Main()
      {
         Console.WriteLine("");
         Console.WriteLine("CustomProxy Sample");
         Console.WriteLine("================");
         Console.WriteLine("");
         // Create an instance of MyProxy.
         MyProxy myProxyInstance = new MyProxy(typeof(CustomServer));
         // Get a CustomServer proxy.
         CustomServer myHelloServer = (CustomServer)myProxyInstance.GetTransparentProxy();
         // Get stubdata.
         Console.WriteLine("GetStubData = " + RealProxy.GetStubData(myProxyInstance).ToString());
         // Get ProxyType.
         Console.WriteLine("Type of object represented by RealProxy is :"
                           + myProxyInstance.GetProxiedType());
         myHelloServer.HelloMethod("RealProxy Sample");
         Console.WriteLine("");
         // Get a reference object from server.
         Console.WriteLine("Create an objRef object to be marshalled across Application Domains...");
         ObjRef CustomObjRef = myProxyInstance.CreateObjRef(typeof(CustomServer));
         Console.WriteLine("URI of 'ObjRef' object =  " + CustomObjRef.URI);
      }
   }
}

Si applica a

.NET Framework 4.8.1 e altre versioni
Prodotto Versioni
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1

RealProxy(Type)

Inizializza una nuova istanza della classe RealProxy che rappresenta un oggetto remoto del Type specificato.

C#
protected RealProxy (Type classToProxy);
C#
[System.Security.SecurityCritical]
protected RealProxy (Type classToProxy);

Parametri

classToProxy
Type

Type dell'oggetto remoto per il quale creare un proxy.

Attributi

Eccezioni

classToProxy non è un'interfaccia e non è derivato da MarshalByRefObject.

Esempio

C#
// Create an instance of MyProxy.
MyProxy myProxyInstance = new MyProxy(typeof(CustomServer));
// Get a CustomServer proxy.
CustomServer myHelloServer = (CustomServer)myProxyInstance.GetTransparentProxy();

Commenti

Il metodo corrente crea un proxy trasparente a cui è possibile accedere tramite il GetTransparentProxy metodo .

Un client che usa un oggetto attraverso qualsiasi tipo di limite di comunicazione remota usa effettivamente un proxy trasparente per l'oggetto. Il proxy trasparente dà l'impressione che l'oggetto effettivo risieda nello spazio del client. Questo risultato viene raggiunto inoltrando le chiamate effettuate all'oggetto reale usando l'infrastruttura remota.

Il proxy trasparente è ospitato da un'istanza di una classe RealProxydi runtime gestita. RealProxy Implementa una parte della funzionalità necessaria per inoltrare le operazioni dal proxy trasparente. Si noti che un oggetto proxy eredita la semantica associata di oggetti gestiti, ad esempio Garbage Collection e il supporto per campi e metodi, e può essere esteso per formare nuove classi. Il proxy ha una doppia natura: funge da oggetto della stessa classe dell'oggetto remoto (proxy trasparente) ed è un oggetto gestito stesso.

Si applica a

.NET Framework 4.8.1 e altre versioni
Prodotto Versioni
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1

RealProxy(Type, IntPtr, Object)

Inizializza una nuova istanza della classe RealProxy.

C#
protected RealProxy (Type classToProxy, IntPtr stub, object stubData);
C#
[System.Security.SecurityCritical]
protected RealProxy (Type classToProxy, IntPtr stub, object stubData);

Parametri

classToProxy
Type

Type dell'oggetto remoto per il quale creare un proxy.

stub
IntPtr

Stub da associare all'istanza del nuovo proxy.

stubData
Object

Dati stub da impostare per lo stub specificato e l'istanza del nuovo proxy.

Attributi

Eccezioni

classToProxy non è un'interfaccia e non è derivato da MarshalByRefObject.

Commenti

I dati stub vengono usati dagli utenti proxy personalizzati per decidere cosa fare con una chiamata al metodo in ingresso. Ad esempio, i dati stub potrebbero essere informazioni sul contesto del server che è possibile usare per determinare se eseguire la chiamata in locale o inviarli tramite l'infrastruttura remota.

Si applica a

.NET Framework 4.8.1 e altre versioni
Prodotto Versioni
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1