我有一个名为'Template'的抽象类,定义如下:
[DataContract]
public abstract class Template
{
[DataMember]
public virtual int? Id { get; set; }
[DataMember]
public virtual string Title { get; set; }
[DataMember]
public virtual byte[] TemplateDoc { get; set; }
[DataMember]
public virtual bool IsSystemTemplate { get; set; }
}
两个派生类:UserTemplate和SystemTemplate实现上述抽象类,定义为:
public class UserTemplate : Template
{
[DataMember]
public virtual Int32? OfficeId { get; set; }
[DataMember]
public virtual Int32? UserId { get; set; }
protected UserTemplate() { }
public UserTemplate(string title, byte[] templateDoc, string templateDocName, TemplateType templateType, int officeId, int? userId)
{
this.Title = title;
this.TemplateDoc = templateDoc;
this.IsSystemTemplate = false;
this.OfficeId = officeId;
this.UserId = userId;
}
}
public class SystemTemplate : Template
{
[DataMember]
public virtual Int32? MultiListGroupId { get; set; }
protected SystemTemplate() { }
public SystemTemplate(string title, byte[] templateDoc, string templateDocName, TemplateType templateType, int multiListGroupId)
{
this.Title = title;
this.TemplateDoc = templateDoc;
this.IsSystemTemplate = true;
this.MultiListGroupId = multiListGroupId;
}
}
现在,当我尝试调用以下服务方法时:
List<Template> GetTemplatesByTemplateType(int officeId, int? userId, TemplateType templateType)
我得到这个错误:
System.Net.Sockets.SocketException:远程主机强制关闭了现有连接
是因为我试图返回一个抽象类的原因吗?
如果我尝试使用单元测试调用这个方法,它运行良好。
4条答案
按热度按时间sqxo8psd1#
是的,问题是你的抽象基类需要用KnownType和XmlInclude属性来修饰。Link
5gfr0r5j2#
除了grenment的答案,即使用
KnownType
(或ServiceKnownType
)属性使这些子类为WCF所知之外,您还必须使用[DataContract]
属性来修饰子类本身。在WCF中,这些属性几乎不会从父级继承到子级--您需要非常明确地说明您在每一级的意图。
查看这篇博客文章All About KnownTypes,了解有关KnownTypes和ServiceKnownTypes属性的更多信息。
twh00eeo3#
在Web配置文件中添加以下datacontractserializer行
3z6pesqy4#
我有一次得到了这个错误,而且相当混乱。我的问题是服务引用由于某种原因不是最新的,所以更新服务引用有帮助。