remoting使用手记

王朝other·作者佚名  2006-01-09
宽屏版  字体: |||超大  

最近在尝试使用remoting进行分布式应用开发,出现一些小错误,让我走了不少的弯路,现记录如下。

1、 发现服务器激活对象支持不带参数的构造函数,所以改为客户端激活对象的方式;

2、客户端激活对象由于是知名对象,可以采用http://localhost/*.soap?wsdl的方式查看远程对象是否已经配置,可是客户端激活对象不支持这种方式查看;

3、不知是调用的远程remoting对象还是本地对象,通过如下代码检查对象是否是代理对象:

if (RemotingServices.IsTransparentProxy(obj))

{

Console.WriteLine("transparent proxy");

RealProxy proxy = RemotingServices.GetRealProxy(obj);

Console.WriteLine(proxy.ToString());

}

4、序列化对象同时标明Serializable属性和从System.MarshalByRefObject继承,出现错误;

5、客户端组件和远程组件(通过IIS承载,位于站点的bin目录下)的版本不一致,出现错误;

6、在传递序列化对象时,出现“由于安全限制,无法访问对象”错误,我一直在查找是否权限的问题;为了判断传递的对象是否可以序列化,使用如下代码检验,发现本地序列化组件没有问题;

//反序列化对象

public static Object DeSer()

{

object info;

IFormatter formatter = new BinaryFormatter();

Stream stream = new FileStream("sam.dat",

FileMode.Open , FileAccess.Read , FileShare.None);

info = formatter.Deserialize(stream);

stream.Close();

return info;

}

//序列化对象

public static void Ser(Object info)

{

IFormatter formatter = new BinaryFormatter();

Stream stream = new FileStream("sam.dat",

FileMode.Create , FileAccess.Write , FileShare.None);

formatter.Serialize(stream,info);

stream.Close();

}

7、对于错误“由于安全限制,无法访问对象”,最终发现是由于序列化对象的组件添加了强名,引起的错误。去掉强名就不会出现这个错误。这个问题困扰我两天。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
© 2005- 王朝网络 版权所有