Soap 序列化程序不支持序列化一般类型: System.Collections.Generic.List`1[System.Object]。

qjf9013 2010-01-11 03:37:25
Soap 序列化程序不支持序列化一般类型: System.Collections.Generic.List`1[System.Object]。
要序列化的对象中 存在List<Object> 和Dictionary<string,Object>
Soap不行 binary 可以 怎么解决。条件是必须要用Soap
...全文
2908 30 打赏 收藏 转发到动态 举报
写回复
用AI写文章
30 条回复
切换为时间正序
请发表友善的回复…
发表回复
nn0821 2010-10-12
  • 打赏
  • 举报
回复
把泛型类中的内容转存到ArrayList中,然后用soap序列化ArrayList,反序列化时反序列化成ArrayList,在转存回来就行了
wangdj2 2010-08-28
  • 打赏
  • 举报
回复
dffdfdfdfdf
aihuahu1987 2010-08-02
  • 打赏
  • 举报
回复
[WebMethod]
public List<modWeiEquipment> GetEquipmentList()
{
IBizWeiEquipment we = BizFactory.BizFactory.GetBizWeiEquipment();
return (List<modWeiEquipment >) we.GetEquipmentList();
}//返回所有电子衡类型实体的列表;
qldsrx 2010-01-12
  • 打赏
  • 举报
回复
BinaryFormatter的话,当然可行了。如果对方不支持BinaryFormatter的反序列化的话,那就用XML序列化,XML序列化也是支持泛型类的,唯独SoapFormatter被微软废弃了,不提供进一步的支持。
qjf9013 2010-01-12
  • 打赏
  • 举报
回复
楼上的大哥 加个好友行不。 WCF 完全没接触过。 15038549
qjf9013 2010-01-12
  • 打赏
  • 举报
回复
[Quote=引用 24 楼 qldsrx 的回复:]
既然微软说SoapFormatter已经过时,而且还说在不同的.NET版本上使用SoapFormatter序列化会出现错误,可见那个不是很好的方法,不支持泛型也不足为奇,而且应该不会增加它的功能了。
WCF是新兴产物,它自然要支持SOAP的泛型序列化了,不过有一点奇怪的,SoapFormatter虽然不支持泛型,但是却支持Hashtable的序列化,WCF则只支持泛型下的Dictionary序列化,更离谱的是SoapFormatter还可以对Object类进行序列化。可见SoapFormatter已经不是一个规范的序列化方案了,与其使用SoapFormatter序列化,还不如直接使用BinaryFormatter后,进行Base64编码传输文本内容呢。
[/Quote]
如果我有一个类A中含有泛型类型,而我想序列化A的对象a 可行么
qldsrx 2010-01-12
  • 打赏
  • 举报
回复
既然微软说SoapFormatter已经过时,而且还说在不同的.NET版本上使用SoapFormatter序列化会出现错误,可见那个不是很好的方法,不支持泛型也不足为奇,而且应该不会增加它的功能了。
WCF是新兴产物,它自然要支持SOAP的泛型序列化了,不过有一点奇怪的,SoapFormatter虽然不支持泛型,但是却支持Hashtable的序列化,WCF则只支持泛型下的Dictionary序列化,更离谱的是SoapFormatter还可以对Object类进行序列化。可见SoapFormatter已经不是一个规范的序列化方案了,与其使用SoapFormatter序列化,还不如直接使用BinaryFormatter后,进行Base64编码传输文本内容呢。
xray2005 2010-01-12
  • 打赏
  • 举报
回复
SOAP不能序列化泛型 除非自己定制方法

贴你代码来看看
qjf9013 2010-01-12
  • 打赏
  • 举报
回复
[Quote=引用 21 楼 qldsrx 的回复:]
另外,我用WCF自带的TextMessageEncodingBindingElement,使用SOAP序列化传输List <Object>或者Dictionary <string,Object>均正常,这说明SOAP是支持泛型序列化的,关键是如何设计它了。
[/Quote]
[Serializable]
public class JamesBondCar
{
public bool canFly;
public string canNum;
public bool math;
public int l= 10000;
public JamesBondCar(bool skyWorthy, string seaWorthy, bool mathy)
{
canFly = skyWorthy;
canNum = seaWorthy;
math = mathy;


}
public JamesBondCar()
{
}
}
[Serializable]

public class Bike:ISerializable
{
public int Num = 909090;
public int[] x1 = new int[20];
public string L = " I'm OK!";
List<Object> myCars = new List<Object>();

public Bike(SerializationInfo info , StreamingContext context)
{
Num = info.GetInt32("Num");
L = info.GetString("L");
x1 = (int[])info.GetValue("x1", typeof(int[]));
myCars = (List<Object>)info.GetValue("myCars", typeof(List<Object>));


}
public void GetObjectData(SerializationInfo info, StreamingContext context)
{
info.AddValue("Num", Num);
info.AddValue("x1", x1[0] = 100);
info.AddValue("myCars",myCars);

}
public Bike()
{
myCars.Add(new JamesBondCar(true, "first", false));
}
}

我的测试Class是这样的,怎么把bike用soap序列化呢? 为什么我用soapformatter会出错?
sparts87A 2010-01-12
  • 打赏
  • 举报
回复
关注一下
qldsrx 2010-01-12
  • 打赏
  • 举报
回复
另外,我用WCF自带的TextMessageEncodingBindingElement,使用SOAP序列化传输List<Object>或者Dictionary<string,Object>均正常,这说明SOAP是支持泛型序列化的,关键是如何设计它了。
qldsrx 2010-01-12
  • 打赏
  • 举报
回复
老实说,我不清楚你是怎么调用SOAP序列化的,另外私有成员是没必要序列化传输的,因为是私有的,你传到远程做什么?对方又看不到私有成员的内容,传过去也没用。

如果你手动序列化SOAP到XML流,有段示例代码你看下:
XmlTypeMapping myTypeMapping = (new SoapReflectionImporter().ImportTypeMapping(typeof(Group));
XmlSerializer mySerializer = new XmlSerializer(myTypeMapping);

显然,就算是Object,你也可以在XmlTypeMapping中指定特定的类型。
qjf9013 2010-01-12
  • 打赏
  • 举报
回复
XML序列化 首先不能序列化私有成员。 而你在开发一个 系统的时候会有多少公有成员呢? 几乎都是私有的吧。而且XML序列化后的文件是不加密的,安全性更低。还有一个缺点就是XML序列化无法实现自定义接口。

同样SOAP xml 都无法序列化泛型 你可以试试Dictionary。
qjf9013 2010-01-12
  • 打赏
  • 举报
回复
[Quote=引用 16 楼 qldsrx 的回复:]
晕倒,Soap的序列化本质上是和XML序列化一样的,都是传输XML,那么你可以理解为只要支持XML序列化,就一定可以SOAP序列化了,而XML序列化不需要[Serializable]标志,泛型也可以XML序列化,所以你很多地方是理解错误的。
[/Quote]
自己去试试。
qldsrx 2010-01-12
  • 打赏
  • 举报
回复
晕倒,Soap的序列化本质上是和XML序列化一样的,都是传输XML,那么你可以理解为只要支持XML序列化,就一定可以SOAP序列化了,而XML序列化不需要[Serializable]标志,泛型也可以XML序列化,所以你很多地方是理解错误的。
qjf9013 2010-01-12
  • 打赏
  • 举报
回复
[Serializable]
public class ObjectList:List<Object>
{

}

如果定义这个继承 然后用ObjectList的对象来建立泛型。

这是一种解决方法。 但是开发一个系统里面有大量的泛型使用,不可能每一个都这样定义。 很繁琐,加大了团队的开发复杂度。

我想的方法是,将List<> 在序列化时候转换为ObjectList 但是,泛型不能转换为类类型,只能通过一个Object[] 数组来中间传递。
可是问题又出来了,在转换完成后的确可以正常无错误的序列化的。 反序列化的时候出错,因为序列化的是一个类对象,而改变泛型为类类型后,就改变了类对象内的成员组成,故无法反序列化。而若是再转换为泛型的话SOAPformatter无法反序列化。

soapformatter没有过时。 试想binaryformatter 怎么进行平台扩展?而xmlformatter又没有灵活的自己定义。
antony1029 2010-01-11
  • 打赏
  • 举报
回复
SoapFormatter 就过时了。咳!!
hhc123 2010-01-11
  • 打赏
  • 举报
回复
[Quote=引用 11 楼 soaringbird 的回复:]
你用SoapFormatter 序列化的?
从 .NET Framework 3.5 版开始,此类已过时。应改用 BinaryFormatter。

[/Quote]
这么快就过时了啊,晕
soaringbird 2010-01-11
  • 打赏
  • 举报
回复
你用SoapFormatter 序列化的?
从 .NET Framework 3.5 版开始,此类已过时。应改用 BinaryFormatter。
LutzMark 2010-01-11
  • 打赏
  • 举报
回复
用binary序列化List <Object> ,用时再返序列化为List<Object>
加载更多回复(8)
JAVA相关基础知识 1、面向对象的特征有哪些方面 1.抽象: 抽象就是忽略一个主题中与当前目标无关的那些方面,以便更充分地注意与当前目标有关的方面。抽象并不打算了解全部问题,而只是选择其中的一部分,暂时不用部分细节。抽象包括两个方面,一是过程抽象,二是数据抽象。 2.继承: 继承是一种联结类的层次模型,并且允许和鼓励类的重用,它提供了一种明确表述共性的方法。对象的一个新类可以从现有的类中派生,这个过程称为类继承。新类继承了原始类的特性,新类称为原始类的派生类(子类),而原始类称为新类的基类(父类)。派生类可以从它的基类那里继承方法和实例变量,并且类可以修改或增加新的方法使之更适合特殊的需要。 3.封装: 封装是把过程和数据包围起来,对数据的访问只能通过已定义的界面。面向对象计算始于这个基本概念,即现实世界可以被描绘成一系列完全自治、封装的对象,这些对象通过一个受保护的接口访问其他对象。 4. 多态性: 多态性是指允许不同类的对象对同一消息作出响应。多态性包括参数化多态性和包含多态性。多态性语言具有灵活、抽象、行为共享、代码共享的优势,很好的解决了应用程序函数同名问题。 2、String是最基本的数据类型吗? 基本数据类型包括byte、int、char、long、float、double、boolean和short。 java.lang.String类是final类型的,因此不可以继承这个类、不能修改这个类。为了提高效率节省空间,我们应该用StringBuffer类 3、int 和 Integer 有什么区别 Java 提供两种不同的类型:引用类型和原始类型(或内置类型)。Int是java的原始数据类型,Integer是java为int提供的封装类。Java为每个原始类型提供了封装类。 原始类型封装类 booleanBoolean charCharacter byteByte shortShort intInteger longLong floatFloat doubleDouble 引用类型和原始类型的行为完全不同,并且它们具有不同的语义。引用类型和原始类型具有不同的特征和用法,它们包括:大小和速度问题,这种类型以哪种类型的数据结构存储,当引用类型和原始类型用作某个类的实例数据时所指定的缺省值。对象引用实例变量的缺省值为 null,而原始类型实例变量的缺省值与它们的类型有关。 4、String 和StringBuffer的区别 JAVA平台提供了两个类:String和StringBuffer,它们可以储存和操作字符串,即包含多个字符的字符数据。这个String类提供了数值不可改变的字符串。而这个StringBuffer类提供的字符串进行修改。当你知道字符数据要改变的时候你就可以使用StringBuffer。典型地,你可以使用StringBuffers来动态构造字符数据。 5、运行时异常与一般异常有何异同? 异常表示程序运行过程中可能出现的非正常状态,运行时异常表示虚拟机的通常操作中可能遇到的异常,是一种常见运行错误。java编译器要求方法必须声明抛出可能发生的非运行时异常,但是并不要求必须声明抛出未被捕获的运行时异常。 6、说出Servlet的生命周期,并说出Servlet和CGI的区别。 Servlet被服务器实例化后,容器运行其init方法,请求到达时运行其service方法,service方法自动派遣运行与请求对应的doXXX方法(doGet,doPost)等,当服务器决定将实例销毁的时候调用其destroy方法。 与cgi的区别在于servlet处于服务器进程中,它通过多线程方式运行其service方法,一个实例可以服务于多个请求,并且其实例一般不会销毁,而CGI对每个请求都产生新的进程,服务完成后就销毁,所以效率上低于servlet。 7、说出ArrayList,Vector, LinkedList的存储性能和特性 ArrayList和Vector都是使用数组方式存储数据,此数组元素数大于实际存储的数据以便增加和插入元素,它们都允许直接按序号索引元素,但是插入元素要涉及数组元素移动等内存操作,所以索引数据快而插入数据慢,Vector由于使用了synchronized方法(线程安全),通常性能上较ArrayList差,而LinkedList使用双向链表实现存储,按序号索引数据需要进行前向或后向遍历,但是插入数据时只需要记录本项的前后项即可,所以插入速度较快。 8、EJB是基于哪些技术实现的?并说出SessionBean和EntityBean的区别,StatefulBean和StatelessBean的区别。 EJB包括Session Bean、Entity Bean、Message Driven Bea
超级有影响力的Java面试题大全文档 1.抽象: 抽象就是忽略一个主题中与当前目标无关的那些方面,以便更充分地注意与当前目标有关的方面。抽象并不打算了解全部问题,而只是选择其中的一部分,暂时不用部分细节。抽象包括两个方面,一是过程抽象,二是数据抽象。 2.继承:  继承是一种联结类的层次模型,并且允许和鼓励类的重用,它提供了一种明确表述共性的方法。对象的一个新类可以从现有的类中派生,这个过程称为类继承。新类继承了原始类的特性,新类称为原始类的派生类(子类),而原始类称为新类的基类(父类)。派生类可以从它的基类那里继承方法和实例变量,并且类可以修改或增加新的方法使之更适合特殊的需要。 3.封装:  封装是把过程和数据包围起来,对数据的访问只能通过已定义的界面。面向对象计算始于这个基本概念,即现实世界可以被描绘成一系列完全自治、封装的对象,这些对象通过一个受保护的接口访问其他对象。 4. 多态性:  多态性是指允许不同类的对象对同一消息作出响应。多态性包括参数化多态性和包含多态性。多态性语言具有灵活、抽象、行为共享、代码共享的优势,很好的解决了应用程序函数同名问题。 5、String是最基本的数据类型吗?  基本数据类型包括byte、int、char、long、float、double、boolean和short。  java.lang.String类是final类型的,因此不可以继承这个类、不能修改这个类。为了提高效率节省空间,我们应该用StringBuffer类 6、int 和 Integer 有什么区别  Java 提供两种不同的类型:引用类型和原始类型(或内置类型)。Int是java的原始数据类型,Integer是java为int提供的封装类。Java为每个原始类型提供了封装类。 原始类型 封装类 boolean Boolean char Character byte Byte short Short int Integer long Long float Float double Double  引用类型和原始类型的行为完全不同,并且它们具有不同的语义。引用类型和原始类型具有不同的特征和用法,它们包括:大小和速度问题,这种类型以哪种类型的数据结构存储,当引用类型和原始类型用作某个类的实例数据时所指定的缺省值。对象引用实例变量的缺省值为 null,而原始类型实例变量的缺省值与它们的类型有关。 7、String 和StringBuffer的区别  JAVA平台提供了两个类:String和StringBuffer,它们可以储存和操作字符串,即包含多个字符的字符数据。这个String类提供了数值不可改变的字符串。而这个StringBuffer类提供的字符串进行修改。当你知道字符数据要改变的时候你就可以使用StringBuffer。典型地,你可以使用 StringBuffers来动态构造字符数据。 8、运行时异常与一般异常有何异同?  异常表示程序运行过程中可能出现的非正常状态,运行时异常表示虚拟机的通常操作中可能遇到的异常,是一种常见运行错误。java编译器要求方法必须声明抛出可能发生的非运行时异常,但是并不要求必须声明抛出未被捕获的运行时异常。 9、说出Servlet的生命周期,并说出Servlet和CGI的区别。  Servlet被服务器实例化后,容器运行其init方法,请求到达时运行其service方法,service方法自动派遣运行与请求对应的doXXX方法(doGet,doPost)等,当服务器决定将实例销毁的时候调用其destroy方法。 与cgi的区别在于servlet处于服务器进程中,它通过多线程方式运行其service方法,一个实例可以服务于多个请求,并且其实例一般不会销毁,而CGI对每个请求都产生新的进程,服务完成后就销毁,所以效率上低于servlet。 10、说出ArrayList,Vector, LinkedList的存储性能和特性  ArrayList 和Vector都是使用数组方式存储数据,此数组元素数大于实际存储的数据以便增加和插入元素,它们都允许直接按序号索引元素,但是插入元素要涉及数组元素移动等内存操作,所以索引数据快而插入数据慢,Vector由于使用了synchronized方法(线程安全),通常性能上较ArrayList差,而LinkedList使用双向链表实现存储,按序号索引数据需要进行前向或后向遍历,但是插入数据时只需要记录本项的前后项即可,所以插入速度较快。 11、EJB是基于哪些技术实现的?并说出SessionBean和EntityBean的区别,StatefulBean和StatelessBean的区别。 EJB包括Ses

110,539

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧