解决反序列化(Deserialize)无法找到程序集的错误
2010-06-15 11:22
211 查看
原帖地址:http://blog.csdn.net/silverice/archive/2009/10/15/4674831.aspx
在使用.NET序列化对象时,会将程序集信息也包含进去。如果将序列化之后的字节数组通过网络(或其他传输方式)传输到另一个应用程序,再使用Deserialize反序列化还原对象时,可能(注意是可能)会出现无法找到程序集的错误。之所以说是可能,是因为如果两边的应用程序结构(命名空间、类结构、程序名、程序签名、程序版本等)相同,则不会出现该错误。下面说一个具体实例:
在客户端动态生成一条SELECT语句,将该语句发送到服务器执行,再将执行后的结果返回给客户端。(题外话:要实现本功能完全可以不使用序列化和反序列化的方法,本实例只是为了解释如何解决反序列化时出现的无法找到程序集的错误)
解决方案:
创建一个.NET类库,把要传输的对象做成一个结构或类放在类库(假设为ClassLib.dll)中。如:
view plaincopy to clipboardprint?
[Serializable]
public struct Data
{
public string sql;
}
[Serializable]
public struct Data
{
public string sql;
}
然后在客户端程序(假设为Client.exe)中引用ClassLib.dll,创建Data对象,给Data.sql赋值,再调用Serialize方法将Data对象序列化成字节数组发送出去。参考代码:
view plaincopy to clipboardprint?
BinaryFormatter formatter = new BinaryFormatter();
MemoryStream mem = new MemoryStream();
ClassLib.Data data;
data.sql="select * from table";
formatter.Serialize(mem, data);
mem.Seek(0, SeekOrigin.Begin);
byte[] buffer = mem.GetBuffer(); //这里使用mem.GetBuffer()要比mem.ToArray()效率高,
//因为前者直接返回mem使用的内存,后者是创建一块合适大小的内存,
//再将mem对象缓存中的数据拷贝进去。
//但是如果改变使用GetBuffer方法返回的数组中数据的值,
//则mem对象缓存中的值也会变化
Send(buffer, mem.Length); //Send原型为 void Send(byte[] buf, long bufLen)
//之所以Send函数要有第2个参数bufLen,
//是因为使用GetBuffer方法返回的缓存中有未使用的字节
//通过给该参数传递mem.Length可以让Send函数只发送使用的字节
BinaryFormatter formatter = new BinaryFormatter();
MemoryStream mem = new MemoryStream();
ClassLib.Data data;
data.sql="select * from table";
formatter.Serialize(mem, data);
mem.Seek(0, SeekOrigin.Begin);
byte[] buffer = mem.GetBuffer(); //这里使用mem.GetBuffer()要比mem.ToArray()效率高,
//因为前者直接返回mem使用的内存,后者是创建一块合适大小的内存,
//再将mem对象缓存中的数据拷贝进去。
//但是如果改变使用GetBuffer方法返回的数组中数据的值,
//则mem对象缓存中的值也会变化
Send(buffer, mem.Length); //Send原型为 void Send(byte[] buf, long bufLen)
//之所以Send函数要有第2个参数bufLen,
//是因为使用GetBuffer方法返回的缓存中有未使用的字节
//通过给该参数传递mem.Length可以让Send函数只发送使用的字节
在服务器端(假设为Server.exe)中也引用ClassLib.dll,调用Deserialize函数反序列化接收到的字节得到Data对象。参考代码:
view plaincopy to clipboardprint?
ClassLib.Data data = (ClassLib.Data)formatter.Deserialize(new MemoryStream(data, index, length));
ClassLib.Data data = (ClassLib.Data)formatter.Deserialize(new MemoryStream(data, index, length));
至此序列化和反序列化完成。今后在库变换时,只要保证服务器和客户端的库一致,就可以了。
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/silverice/archive/2009/10/15/4674831.aspx
在使用.NET序列化对象时,会将程序集信息也包含进去。如果将序列化之后的字节数组通过网络(或其他传输方式)传输到另一个应用程序,再使用Deserialize反序列化还原对象时,可能(注意是可能)会出现无法找到程序集的错误。之所以说是可能,是因为如果两边的应用程序结构(命名空间、类结构、程序名、程序签名、程序版本等)相同,则不会出现该错误。下面说一个具体实例:
在客户端动态生成一条SELECT语句,将该语句发送到服务器执行,再将执行后的结果返回给客户端。(题外话:要实现本功能完全可以不使用序列化和反序列化的方法,本实例只是为了解释如何解决反序列化时出现的无法找到程序集的错误)
解决方案:
创建一个.NET类库,把要传输的对象做成一个结构或类放在类库(假设为ClassLib.dll)中。如:
view plaincopy to clipboardprint?
[Serializable]
public struct Data
{
public string sql;
}
[Serializable]
public struct Data
{
public string sql;
}
然后在客户端程序(假设为Client.exe)中引用ClassLib.dll,创建Data对象,给Data.sql赋值,再调用Serialize方法将Data对象序列化成字节数组发送出去。参考代码:
view plaincopy to clipboardprint?
BinaryFormatter formatter = new BinaryFormatter();
MemoryStream mem = new MemoryStream();
ClassLib.Data data;
data.sql="select * from table";
formatter.Serialize(mem, data);
mem.Seek(0, SeekOrigin.Begin);
byte[] buffer = mem.GetBuffer(); //这里使用mem.GetBuffer()要比mem.ToArray()效率高,
//因为前者直接返回mem使用的内存,后者是创建一块合适大小的内存,
//再将mem对象缓存中的数据拷贝进去。
//但是如果改变使用GetBuffer方法返回的数组中数据的值,
//则mem对象缓存中的值也会变化
Send(buffer, mem.Length); //Send原型为 void Send(byte[] buf, long bufLen)
//之所以Send函数要有第2个参数bufLen,
//是因为使用GetBuffer方法返回的缓存中有未使用的字节
//通过给该参数传递mem.Length可以让Send函数只发送使用的字节
BinaryFormatter formatter = new BinaryFormatter();
MemoryStream mem = new MemoryStream();
ClassLib.Data data;
data.sql="select * from table";
formatter.Serialize(mem, data);
mem.Seek(0, SeekOrigin.Begin);
byte[] buffer = mem.GetBuffer(); //这里使用mem.GetBuffer()要比mem.ToArray()效率高,
//因为前者直接返回mem使用的内存,后者是创建一块合适大小的内存,
//再将mem对象缓存中的数据拷贝进去。
//但是如果改变使用GetBuffer方法返回的数组中数据的值,
//则mem对象缓存中的值也会变化
Send(buffer, mem.Length); //Send原型为 void Send(byte[] buf, long bufLen)
//之所以Send函数要有第2个参数bufLen,
//是因为使用GetBuffer方法返回的缓存中有未使用的字节
//通过给该参数传递mem.Length可以让Send函数只发送使用的字节
在服务器端(假设为Server.exe)中也引用ClassLib.dll,调用Deserialize函数反序列化接收到的字节得到Data对象。参考代码:
view plaincopy to clipboardprint?
ClassLib.Data data = (ClassLib.Data)formatter.Deserialize(new MemoryStream(data, index, length));
ClassLib.Data data = (ClassLib.Data)formatter.Deserialize(new MemoryStream(data, index, length));
至此序列化和反序列化完成。今后在库变换时,只要保证服务器和客户端的库一致,就可以了。
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/silverice/archive/2009/10/15/4674831.aspx
相关文章推荐
- 解决反序列化(Deserialize)无法找到程序集的错误
- 解决反序列化(Deserialize)无法找到程序集的错误
- 解决“无法开始调试。无法找到Microsoft Internet Explorer”错误
- 无法在证书存储区中找到清单签名证书”错误的解决方法
- cocos2d-x 关于无法找到gl/gl.h头文件错误,以及r.java无法生成解决办法
- 在ubuntu下安装任何软件时都提示软件包 flash-plugin 需要重新安装,但是我无法找到相应的安装文件的错误的解决办法。
- 无法在com+ 目录中安装和配置程序集 错误:-2146233087的解决方法[已测]
- UDP传输错误 无法找到程序集“client, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
- VS2010无法查看自定义的普通变量解决办法( CXX0017: 错误: 没有找到符号 )
- 配置iis6解决运行asp.net mvc项目“无法找到该页”的错误
- 错误“ORA-12520: TNS: 监听程序无法找到需要的服务器类型的可用句柄”解决方法
- 解决sqlserver2008在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服务器。请验证实例名称是否正确并且 SQ
- 关于“无法找到资源程序集”错误
- 解决“无法开始调试。无法找到Microsoft Internet Explorer”错误
- ASP.NET中“无法找到脚本库”错误解决方法
- System.Net.WebException: 无法显示错误消息,原因是无法找到包含此错误消息的可选资源程序集
- Linux下Eric4开发,遇见无法找到“ Designer”错误的解决办法
- sqlserver2017 重装过程中出现“无法找到数据库引擎启动句柄”错误的解决办法
- cocos2d-x 关于无法找到gl/gl.h头文件错误,以及r.java无法生成解决办法
- iis 无法找到该页 错误的解决【2】