微软的远程处理框架.NET Remoting(转天极网)之二

微软

 以下我们将举一个使用channel的例子。在这个例子中,我们将可以看到使用HTTP channel把两个应用<br>
连接在一起是如此的简单。以下的服务器应用提供了一个服务,可将一个字符串的字母顺序反转。<br>
<br>
  Server.cs using System;<br>
  using System.IO;<br>
  using System.Runtime.Remoting;<br>
  using System.Runtime.Remoting.Channels.HTTP;<br>
<br>
  namespace RemotingSample <br>
  {<br>
   public class Reverser : MarshalByRefObject<br>
   {<br>
    public string Reverse(string text)<br>
    {<br>
     Console.WriteLine("Reverse({0})", text);<br>
<br>
     string rev = "";<br>
<br>
     for (int i=text.Length-1; i>=0; i--)<br>
     {<br>
      rev += text[i];<br>
      }<br>
<br>
     Console.WriteLine("returning : {0}", rev);<br>
<br>
     return rev;<br>
    }<br>
   }<br>
<br>
   public class TheApp<br>
   {<br>
    public static void Main()<br>
    {<br>
     file://<font color=#FF0000> Create a new HTTP channel that</font><br>
     // <font color=#FF0000>listens on port 8000</font><br>
     HTTPChannel channel = new HTTPChannel(8000);<br>
<br>
     // <font color=#FF0000>Register the channel with the runtime</font><br>
     ChannelServices.RegisterChannel(channel);<br>
<br>
     // <font color=#FF0000>Expose the Reverser object from this server</font><br>
     RemotingServices.RegisterWellKnownType(<br>
         "server", // <font color=#FF0000>assembly name</font><br>
         "RemotingSample.Reverser", // <font color=#FF0000>full type name</font><br>
         "Reverser.soap", file://<font color=#FF0000> URI</font><br>
         WellKnownObjectMode.Singleton // <font color=#FF0000>instancing mode</font><br>
      );<br>
<br>
     // <font color=#FF0000>keep the server running until</font><br>
     // <font color=#FF0000>the user presses enter</font><br>
     Console.WriteLine("Server.exe");<br>
     Console.WriteLine("Press enter to stop server...");<br>
     Console.ReadLine();<br>
    }<br>
   }<br>
  }<br>
<br>
  现在我们已经拥有了一个字符反向服务,以下我们将建立一个客户应用来使用这个服务:<br>
<br>
   Client.cs using System;<br>
   using System.Runtime.Remoting;<br>
   using System.Runtime.Remoting.Channels.HTTP;<br>
   using RemotingSample; // reference the server<br>
<br>
   public class TheApp<br>
    {<br>
     public static void Main()<br>
     {<br>
      // <font color=#FF0000>Create and register a channel</font><br>
      // <font color=#FF0000>to comunicate to the server.</font><br>
      // <font color=#FF0000>The client will use port 8001</font><br>
      // <font color=#FF0000>to listen for callbacks</font><br>
      HTTPChannel channel = new HTTPChannel(8001);<br>
      ChannelServices.RegisterChannel(channel);<br>
<br>
      // <font color=#FF0000>create an instance on the remote server</font><br>
      // <font color=#FF0000>and call a method remotely</font><br>
      Reverser rev = (Reverser)Activator.GetObject(<br>
         typeof(Reverser), // <font color=#FF0000>type to create</font><br>
         "http://localhost:8000/Reverser.soap" file://<font color=#FF0000> URI</font><br>
         );<br>
      Console.WriteLine("Client.exe");<br>
      Console.WriteLine(rev.Reverse("Hello, World!"));<br>
     }<br>
    }<br>
<br>
<br>
<img src=http://www.163design.net/n/b/"http://www.yesky.com/34670816/jt-2001-4-4-1.JPG">       <img src=http://www.163design.net/n/b/"http://www.yesky.com/34670816/jt-2001-4-4-2.jpg"><br>
************图一               图二*******************<br>
<br>
看,通过远程.NET将两个应用连接在一起是多么的简单。当服务端和客户端程序放在两台不同的机器时,我们可以令两个程序都运行在80端口。这样远程的调用就可通过一个防火墙。你也可将HTTPChannel改为一个TCPChannel试一下。<br>
<br>
  你要注意到,客户端是通过“Reverser.soap”来标识它想连接的对象的。这个名字与服务器代码中RegisterWellKnownType的URI参数符合。“.soap”的扩展是不必要的。URI可以是任何的字符串,只要它能唯一标识服务器的对象就可以了。“.soap”的扩展只是用来提醒我们HTTP channel是使用soap来格式化信息的。<br>
<br>
  在上面有关channel的例子中,你可能会产生这样的疑问:参数是如何跨网络传送,返回值又是如何送回的呢?答案是,在参数被跨网络传送之前,他们必须经过串行化处理。对于需要传送的所有对象或者结构,都要经过这样的处理。串行化的处理很简单,只是以连续字节的方式建立变量或者对象中的数据的一个持续拷贝。将这些字节还原为一个值或者对象实例的处理被称为反串行化。<br>
<br>
  那么参数是如何串行化的呢?远程.NET架构为我们提供了一个称为格式器(formatters)的对象集。格式器可将一个对象变成是一个特定的持续数据格式,也可以将该它还原回来。.NET为我们提供了两种格式器:<br>
<br>
  System.Runtime.Serialization.Formatters.Binary <br>
  System.Runtime.Serialization.Formatters.SOAP <br>
<br>
binary(二进制)格式器是最简单的。它只是将数据直接转换为一个字节流。SOAP格式器使用一个XML来保持一个对象数据。要知道SOAP更详细的信息,可到http://www.soapwebservices.com。<br>
<br>
以下我们举一个有关格式器的简单例子。我们将使用SOAP格式器,由于它使用的是XML,我们可以很容易地读出串行化的数据。<br>
<br>
  Soap.cs using System;<br>
  using System.IO;<br>
  using System.Runtime.Serialization.Formatters.Soap;<br>
<br>
  public class Person<br>
  {<br>
   public string FirstName = "David";<br>
   public string LastName = "Findley";<br>
   private int Age = 29;<br>
  }<br>
<br>
  public class TheApp<br>
  {<br>
   public static void Main()<br>
   {<br>
    Stream stream = File.Create("example.xml");<br>
    SoapFormatter formatter = new SoapFormatter();<br>
    Person p = new Person();<br>
<br>
    // <font color=#FF0000>persist an integer</font><br>
    formatter.Serialize(stream, 5);<br>
<br>
    file://<font color=#FF0000> persist a string</font><br>
    formatter.Serialize(stream, "This is a string");<br>
<br>
    // <font color=#FF0000>persist an object</font><br>
    formatter.Serialize(stream, p);<br>
<br>
    stream.Close();<br>
   }<br>
  }<br>
<br>
  对于每个串行化的调用,example.xml的内容将有三个不同的部分:<br>
<br>
  Example.xml <br>
<br>
  <SOAP-ENV:Body><br>
  <xsd:int id="ref-1"><br>
  <m_value>5</m_value><br>
  </xsd:int><br>
  </SOAP-ENV:Body><br>
<br>
  <SOAP-ENV:Body><br>
  <SOAP-ENC:string id="ref-1">This is a string</SOAP-ENC:string><br>
  </SOAP-ENV:Body><br>
<br>
  <SOAP-ENV:Body><br>
  <a1:Person id="ref-1"><br>
  <FirstName id="ref-3">David</FirstName><br>
  <LastName id="ref-4">Findley</LastName><br>
  <Age>29</Age><br>
  </a1:Person><br>
  </SOAP-ENV:Body><br>
<br>
你可以看出,它可以串行化基本值类和对象。HTTPChannel使用SOAP格式器在客户和服务器之间传送数据。<br>
<br>
  总的来说,格式器可以格式和保持值或者对象的数据。Channel传送和接收数据。通过channel和格式器的协同工作,我们将可以使用任何的网络和协议来连接两个应用。

时间: 2024-08-02 23:37:32

微软的远程处理框架.NET Remoting(转天极网)之二的相关文章

微软的远程处理框架.NET Remoting(转天极网)之一

微软 微软的.NET Remoting提供了一种允许对象通过应用程序域与另一对象进行交互的框架.本文将通过两个具体的代码例子介绍它的特性,通过.NET Remoting,两个应用间的通信将变得非常简单,使用上也相当灵活. <br><br><br> 最近几年来,在计算机世界中,关于"向外扩展"(scale-out)与"向上扩展"(scale-up)的讨论不断,并且有向scale-out转化的趋势.在以前,当计算机跟不上应用对性能的要

一起谈.NET技术,.NET远程处理框架详解

第1章系统总体结构 1.1 总体结构 系统实现需要部署服务器端的远程对象(即一个DbServerLibrary.dll),服务器端要注册通道和该远程对象.客户端要实现一个本地查询的服务器,同时根据SQL解析的结果向各个服务器发送命令,并将结果显示在客户端界面,服务器端可以接受并显示相应的命令. 1.2 关键组件结构 系统结构中关键的组件有远程对象,和本地服务器,实现的功能基本一致.下面以远程对象为例,说明组件的实现.远程对象在服务器端解决方案下的库文件中声明,通过服务器端进行注册,客户端通过TC

.NET远程处理框架详解

第1章系统总体结构 1.1 总体结构 系统实现需要部署服务器端的远程对象(即一个DbServerLibrary.dll),服务器端要注册通道和该远程对象.客户端要实现一个本地查询的服务器,同时根据SQL解析的结果向各个服务器发送命令,并将结果显示在客户端界面,服务器端可以接受并显示相应的命令. 1.2 关键组件结构 系统结构中关键的组件有远程对象,和本地服务器,实现的功能基本一致.下面以远程对象为例,说明组件的实现.远程对象在服务器端解决方案下的库文件中声明,通过服务器端进行注册,客户端通过TC

连载-基于插件技术的GIS应用框架(C# + ArcEngine9.3)(二)

问题描述 [align=center]基于插件技术的GIS应用框架(C#+ArcEngine9.3)(二)-------------------------开发环境配置[/align]选用什么样的第三方组件库来进行插件的封装是开发GIS框架的一个重要问题,直接影响到你框架容器加载插件的方式和插件对象的管理机制:此外开发平台的选择也需要考虑,但是选择有很多种,本文论及的框架开发环境配置如下:一.VisualStudio2008个人觉得比VisualStudio2005运行稳定.二.ArcEngin

CUDA并行计算框架(三)应用前景及相比价微软的并行计算框架

关于微软.net4.0推出的并行计算框架 还没深入了解 有兴趣的同学可以参考下http://bitfan.blog.51cto.com/907048/200199系列博文 不过发表下个人的观点 微软.NET 4.0中引入的并行扩展(包括任务并行库TPL和PLINQ)开发技术基于cpu. 从应用领域上来说CPU擅长处理不规则数据结构以及递归算法.分支密集型代码和单线程程序.这类程序任务拥有复杂的指令调度.循环.分支.逻辑判断以及执行等步骤.例如,操作系统.文字处理等,而GPU擅于处理规则数据结构.

Git.Framework 框架随手记--ORM查询数据集合 二

一.  分组查询 在SQL中使用Group By 来对数据分组,在实际中分组中一般与聚合函数一并使用.在Git.Framework中提供了相应的分组方法 DataTable Group(T entity); DataTable Group(T entity, bool isOpenTrans); IEnumerable<System.Linq.IGrouping<TKey, T>> Group<TKey>(T entity, Func<T, TKey> ke

【自然框架】 权限 的视频演示(二): 权限到字段、权限到记录

      继续.这里演示权限到字段和权限到记录.            权限到字段有两种安全级别,      1.低安全级别.有些项目不需要做到控制每一个字段是否显示,那么就可以采用这种级别.低安全级别就是:如果一个节点里面没有设置可以访问哪些字段,那么就默认为不需要做到控制字段的程度,就是说节点里的字段都是可以访问的.这么做是为了操作方便.       2.高安全级别.有些项目要求非常严格,要严格控制每一个字段是否可以访问,那么就可以采用这种安全级别.高安全级别:如果一个节点里面没有设置可以

车辆管理系统之搭建框架 添加必要的数据 安装svn(二)

JAVA EE第一阶段项目--车辆管理系统.MyEclipse + MySQL +powerDesinger +tomcat +svn. 今天组长把项目的分工安排好了!这个周末两天的作业就是我的车主信息管理.主要业务就是增 删 (单条删除 批量删除) 改 查 分页!   感觉还是比较简单的.但是经过今天晚上的分析. 在添加车主信息的时候,这里添加的个人照片,要让他显示出来这个需要想个办法让他显示出来.因为Chrome浏览器是不会显示图片的.暂时就这个问题.就在做作业的时候来发现问题了. 今天把数

java集合框架11——TreeMap和源码分析(二)

版权声明:尊重博主原创文章,转载请注明出处哦~http://blog.csdn.net/eson_15/article/details/51239885 目录(?)[+] 我们继续分析TreeMap的源码 1.TreeMap源码分析(续) 1. 存取方法         TreeMap中的存取方法本质上就是对红黑树的插入和删除操作,从源码里体现的更为明显,其实就是对红黑树的插入和删除(可以参考:红黑树),下面简单看下源码: [java] view plain copy   /**********