基础连接已经关闭 连接被意外关闭
又被我碰到。
有这样一个场景,数据库的表中有一个字段表示的是产品,但是这个产品的类型是不同的,也就是说属性不同。为了方便管理因此都使用在该字段中了,使用clob类型,保存一段对应产品类的json的字符串。json的用法可能大家都比较熟悉。
于是我在服务端打算写这样几个方法。
产品类的模型:
该类表示这个通用字段,
[DataContract]
public class AbstractModel
{
private string id;
[DataMember]
public string ID
{
get { return id; }
set { id = value; }
}
}
这个类表示产品1的结构,
[DataContract]
public class ChildModel1:AbstractModel
{
private string child1ID;
private string child1ProductName;
[DataMember]
public string Child1ID
{
get { return child1ID; }
set { child1ID = value; }
}
[DataMember]
public string Child1ProductName
{
get { return child1ProductName; }
set { child1ProductName = value; }
}
}
这个类表示产品2的结构,
[DataContract]
public class ChildModel2
{
private string child2ID;
private string child2ProductName;
[DataMember]
public string Child2ID
{
get { return child2ID; }
set { child2ID = value; }
}
[DataMember]
public string Child2ProductName
{
get { return child2ProductName; }
set { child2ProductName = value; }
}
}
服务方法如下,
契约接口,
[ServiceContract]
public interface IService1
{
//该方法是为了客户端能访问到ChildModel1的结构
[OperationContract]
ChildModel1 DoGetChild1Model();
[OperationContract]
ChildModel2 DoGetChild2Model();
//该方法是为了让AbstractModel可以表示不同的产品模型
[OperationContract]
AbstractModel DoGetProduct();
}
实现,
public class Service1 : IService1
{
public ChildModel1 DoGetChild1Model()
{
ChildModel1 child1 = new ChildModel1();
child1.Child1ID = "child1";
child1.Child1ProductName = "产品1";
return child1;
}
public ChildModel2 DoGetChild2Model()
{
ChildModel2 child2 = new ChildModel2();
child2.Child2ID = "child2";
child2.Child2ProductName = "产品2";
return child2;
}
public AbstractModel DoGetProduct()
{
ChildModel1 child1 = new ChildModel1();
child1.Child1ID = "child1";
child1.Child1ProductName = "产品1";
AbstractModel abmodel = child1;
return abmodel;
}
}
创建wcf应用程序运行,显示WCF调试工具界面
我们先分别运行获取产品1和产品2的方法
都正确。
运行通过父类指向的获取产品1的方法,
报错
所以这种用法是行不通的,如果想要获取两个不同的产品,则需要定义两个对应的产品字段,分别赋值了。
我的理解依然是序列化时出错了,序列化时应该是序列化了子类,但是恢复时是按照父类的结构恢复的所以出现异常,反序列化失败,造成了连接断开。