Compartir a través de


Proxy

Un proxy reside en el espacio de direcciones del proceso de llamada y actúa como suplente para el objeto remoto. Desde la perspectiva del objeto que realiza la llamada, el proxy es el objeto . Normalmente, el rol del proxy es empaquetar los parámetros de interfaz para las llamadas a métodos en sus interfaces de objeto. El proxy empaqueta los parámetros en un búfer de mensajes y pasa el búfer al canal, que controla el transporte entre procesos. El proxy se implementa como un objeto agregado, o compuesto. Contiene un elemento de administrador proporcionado por el sistema denominado administrador de proxy y uno o varios componentes específicos de la interfaz denominados servidores proxy de interfaz. El número de servidores proxy de interfaz es igual al número de interfaces de objeto que se han expuesto a ese cliente en particular. Para el cliente que cumple con el modelo de objetos de componente, el proxy parece ser el objeto real.

Nota

Con la serialización personalizada, el proxy se puede implementar de forma similar o puede comunicarse directamente con el objeto sin usar un código auxiliar.

 

Cada proxy de interfaz es un objeto de componente que implementa el código de serialización de una de las interfaces del objeto. El proxy representa el objeto para el que proporciona código de serialización. Cada proxy también implementa la interfaz IRpcProxyBuffer . Aunque la interfaz de objeto representada por el proxy es pública, la implementación de IRpcProxyBuffer es privada y se usa internamente dentro del proxy. El administrador de proxy realiza un seguimiento de los servidores proxy de interfaz y también contiene la implementación pública de la interfaz IUnknown de control para el agregado. Cada proxy de interfaz puede existir en un archivo DLL independiente que se carga cuando la interfaz que admite se materializa en el cliente.

Estructura del proxy

En el diagrama siguiente se muestra la estructura de un proxy que admite la serialización estándar de parámetros que pertenecen a dos interfaces: IA1 e IA2. Cada proxy de interfaz implementa IRpcProxyBuffer para la comunicación interna entre las partes agregadas. Cuando el proxy está listo para pasar sus parámetros serializado a través del límite del proceso, llama a métodos en la interfaz IRpcChannelBuffer , que implementa el canal. A su vez, el canal reenvía la llamada a la biblioteca en tiempo de ejecución rpc para que pueda llegar a su destino en el objeto .

Diagrama que muestra la estructura del proxy.

Canal

Comunicación entre objetos

Detalles de serialización

Microsoft RPC

Stub