转自: http://blog.csdn.net/changtianshuiyue/article/details/8871597
涉及到的类:
客户端:
1.System.Runtime.Remoting.Channel.Tcp.TcpClientChannel类:为远程调用实现使用 TCP 协议传输消息的客户端信道。
信道跨越远程处理边界(例如,计算机或应用程序域)传输消息。TcpClientChannel 类使用 TCP 协议传输消息。
.NET Framework 远程处理基础结构使用信道传输远程调用。当客户端调用远程对象时,该调用即被序列化为一个消息,该消息通过客户端信道发送并通过服务器信道接收。然后将其反序列化并进行处理。所有返回值都通过服务器信道传输,并通过客户端信道接收。
2.System.Runtime.Remoting.Channel.ChannelService类:提供帮助进行远程处理信道注册、解析和 URL 发现的静态方法。无法继承此类。
3.System.Activator类:包含特定的方法,用以在本地或从远程创建对象类型,或获取对现有远程对象的引用。无法继承此类。
服务器端:
1.System.Runtime.Remoting.Channel.ChannelService类:提供帮助进行远程处理信道注册、解析和 URL 发现的静态方法。无法继承此类。
2.System.Runtime.Remoting.Channel.Tcp.TcpServerChannel类:为远程调用实现使用 TCP 协议传输消息的服务器信道。
3.System.Runtime.Remoting.RemotingConfiguration类:提供多种配置远程处理结构的静态方法。
4.System.Runtime.Remoting.WellKnownObjectMode枚举:定义如何激活已知对象。
SingleCall | 每个传入的消息由新的对象实例提供服务。 | |
Singleton | 每个传入的消息由同一个对象实例提供服务。 |
步骤:
1.设计自己的远程对象类:RemoteObject.
2.服务器端把远程对象用RemotingConfiguration.RegisterWellKnownServiceType方法注册为WellKnownServiceTypeEntry实例
3.服务器端注册TcpServerChannel到ChannelService中
4.客户端注册新的TcpClientChannel到ChannelService中。
5.客户端用Activator类从远程服务器的URL获取远程对象。
6.客户端使用远程对象。
远程对象代码:
using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace RemoteSampleLib { public class RemoteObject : MarshalByRefObject { public RemoteObject() { Console.WriteLine("New RemoteObject Added!"); } public int Add(int a, int b) { return a + b; } } }
服务器端代码:
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Runtime; using System.Runtime.Remoting; using System.Runtime.Remoting.Channels.Tcp; using RemoteSampleLib; using System.Runtime.Remoting.Channels; namespace RemoteServer { class RemoteServer { static void Main(string[] args) { TcpServerChannel channel = new TcpServerChannel(6666); ChannelServices.RegisterChannel(channel); RemotingConfiguration.RegisterWellKnownServiceType(typeof(RemoteSampleLib.RemoteObject), "RemoteObject", WellKnownObjectMode.SingleCall); System.Console.WriteLine("Press Any Key"); System.Console.ReadLine(); } } }
客户端代码:
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Runtime.Remoting; using System.Runtime.Remoting.Channels; using System.Runtime.Remoting.Channels.Tcp; using RemoteSampleLib; namespace RemoteClient { class RemoteClient { static void Main(string[] args) { ChannelServices.RegisterChannel(new TcpClientChannel()); RemoteObject remoteobj = (RemoteObject)Activator.GetObject(typeof(RemoteObject), "tcp://localhost:6666/RemoteObject"); Console.WriteLine("1+2=" + remoteobj.Add(1, 2).ToString()); Console.ReadLine(); } } }
注意远程对象要实现MarshalByRef类来允许远程对象被跨程序边界访问。
相关推荐
在IT行业中,Remoting和Web Services是两种不同的远程通信技术,它们都允许应用程序之间进行跨网络的通信。本文将深入探讨如何将一个基于.NET Remoting的服务自动转换为Web Service服务,以便更好地理解这一过程。 ...
### Remoting基本原理及其扩展机制 #### 一、Remoting基本概念 Remoting是一种在.NET平台上实现跨应用程序域通信的技术,使得对象可以在不同的应用程序域、进程甚至机器间互相调用。这种技术对于分布式系统尤为...
Remoting,全称为.NET Remoting,是微软.NET框架中的一项技术,用于实现应用程序之间的远程通信。这个"Remoting双向通信V3.0.rar"压缩包可能包含了一个演示或实现.NET Remoting V3.0版本中双向通信的示例项目,分为...
.NET Remoting是微软.NET Framework中的一个核心技术,它允许在不同应用程序域(AppDomain)或不同计算机之间进行对象交互。这个框架的设计目标是为了提供一种高效、灵活的通信机制,使得分布式应用能够像调用本地...
Remoting是.NET Framework提供的一种强大的进程间通信(IPC)机制,允许对象在不同的应用程序域(AppDomain)之间进行交互,甚至是跨网络的交互。在这个"Remoting实例源码"中,我们可以深入理解Remoting的工作原理...
Remoting是.NET Framework提供的一种强大的网络通信机制,它允许对象在不同的应用程序域(AppDomain)之间进行交互,甚至是跨越不同的机器。在这个“Remoting基本实现的一些代码样例程序.rar”压缩包中,我们可以...
C#.NET Remoting是.NET Framework提供的一种技术,用于在应用程序域(AppDomain)之间进行通信,即使这些应用程序域位于不同的进程或甚至不同的计算机上。它为开发者提供了在分布式环境中实现对象间通信的能力,使得...
《Advanced .Net Remoting Full Pack》是一份深度探讨.NET Remoting技术的专业资料,它为开发者提供了全面、深入的理解和实践指导。.NET Remoting是微软.NET框架中的一个关键组件,它允许不同进程甚至不同计算机之间...
.NET Remoting是微软.NET框架中的一个核心技术,它允许不同进程或甚至不同计算机之间的对象进行通信。这个技术在2002年随着.NET Framework 1.0的发布而引入,为开发者提供了一种高效、灵活的方式来构建分布式应用...
Remoting是.NET Framework早期版本中的一种技术,用于在应用程序之间实现跨进程通信(IPC)和远程方法调用(RPC)。这个技术允许对象在不同的应用程序域(AppDomain)之间透明地交互,甚至跨越网络。在本案例中,你...
Remoting基础是.NET框架中的一种远程通信技术,它允许对象在不同的进程或计算机之间进行交互。这个技术在早期的.NET版本中被广泛使用,尤其是在分布式系统开发中,它提供了跨进程、跨网络的对象调用能力。 Remoting...
Remoting是.NET Framework早期的一种远程通信技术,它允许对象在不同的应用程序域(AppDomain)之间进行交互,甚至跨越网络。这个“Remoting测试资源”包含了客户端和服务端的代码,是理解并实践C# Remoting的一个...
数据访问Remoting是一种在.NET Framework中实现分布式计算的技术,它允许不同进程甚至不同计算机之间的对象交互,仿佛它们在同一个应用程序域(AppDomain)内。这个技术对于构建分布式系统、网络应用和服务尤其有用...
在Hessian Remoting中,服务端通过实现特定的接口并部署,提供了一系列可供远程调用的方法。客户端则可以通过Hessian客户端库,直接调用这些远程方法,就像调用本地方法一样,无需关心网络通信的细节。Hessian会自动...
.NET Remoting是微软.NET框架提供的一种通信机制,用于在不同应用程序域(AppDomain)或不同进程甚至不同计算机之间进行交互。这个技术允许对象在这些不同的环境中透明地调用方法,从而构建分布式应用。在给定的...
《Spring Remoting详解》 Spring框架以其强大的依赖注入和面向切面编程能力,深受开发者喜爱。在分布式系统中,远程调用(Remoting)是必不可少的技术之一,Spring Remoting提供了多种远程调用解决方案,帮助开发者...
.NET Remoting是微软.NET框架提供的一种通信机制,用于在不同应用程序域(AppDomains)之间进行交互,无论是同一台机器上的不同进程,还是跨网络的进程。在这个“基于.NET Remoting的局域网聊天室”项目中,开发者...
在C# .NET环境下,分布式系统的Remoting技术实现是一个关键的课题,特别是在互联网技术迅猛发展的背景下,传统的集中式计算和客户/服务器模型已无法满足跨平台、跨地域的分布式计算需求。构建一个可扩展、高复用性且...
.NET Remoting是微软.NET框架提供的一种机制,用于在不同的应用程序域(AppDomain)之间进行通信,无论是同一台机器上的不同进程,还是网络上的不同计算机。它使得开发分布式应用程序变得更加便捷,能够实现对象间的...