微软的远程处理框架.NET Remoting(转天极网)之二
类别: ASP.NET教程
以下我们将举一个使用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.yesky.com/34670816/jt-2001-4-4-1.JPG"> <img src="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和格式器的协同工作,我们将可以使用任何的网络和协议来连接两个应用。
连接在一起是如此的简单。以下的服务器应用提供了一个服务,可将一个字符串的字母顺序反转。<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.yesky.com/34670816/jt-2001-4-4-1.JPG"> <img src="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和格式器的协同工作,我们将可以使用任何的网络和协议来连接两个应用。
-= 资 源 教 程 =-
文 章 搜 索