所谓萝卜白菜各有所爱,最近大家都在讨论WCF,但我仍然喜欢使用Remoting,可能我比较不思进取吧:)
做了一个DEMO,用的是 RemotingServices.Marshal ,网上还没有找到相关资料,于是写下此文。将RemotingServices.Marshal返回的ObjRef对象序列化传递到服务器端,再由服务器端反序列用以访问客户端对象,这个做法的好处是原先我们只能client访问server,现在可以通过动态的发布对象,并将对象传递到服务器端,使得服务器可以访问客户端的对象了,这样可以达到双向通信的目的。

附件:
您所在的用户组无法下载或查看附件客户端代码如下:
Code

Code
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.IO;
using System.Linq;
using System.Runtime.Remoting;
using System.Runtime.Serialization.Formatters.Binary;
using System.Text;
using System.Windows.Forms;
using Interface;
namespace Client
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void Form1_Load(object sender, EventArgs e)
{
Stream sw = File.OpenRead(@"D:\wwwroot\OICF\MarshalDemo\Server\bin\Debug\xx.bin");
BinaryFormatter bf=new BinaryFormatter();
ITest test=(ITest)bf.Deserialize(sw);
test.Say("hello world");
}
}
}
这里没有将序列化后的代码上传到服务器端,我是直接在服务器端读文件了
服务器端代码:
Code

Code
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.IO;
using System.Linq;
using System.Runtime.Remoting;
using System.Runtime.Serialization.Formatters.Binary;
using System.Text;
using System.Windows.Forms;
using Interface;
namespace Client
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void Form1_Load(object sender, EventArgs e)
{
Stream sw = File.OpenRead(@"D:\wwwroot\OICF\MarshalDemo\Server\bin\Debug\xx.bin");
BinaryFormatter bf=new BinaryFormatter();
ITest test=(ITest)bf.Deserialize(sw);
test.Say("hello world");
}
}
}
代码下载(VS2008):

附件:
您所在的用户组无法下载或查看附件
附件:
您所在的用户组无法下载或查看附件(文/lexus 出处/博客园)
您可能对 [Visual Studio.NET] 的这些文章也感兴趣: