SharePoint工作流开发点滴(4) - 工作流中的自定义类与内部错误 (update 2008.12.25)
2007-02-07 11:10 Windie Chai 阅读(2274) 评论(6) 编辑 收藏 举报最近在开发SharePoint工作流总是发生一个错误 :工作流开始之后便显示"已完成"或者开始之后报错"内部错误".
查看当时的日志,发现下面的段落:
02/06/2007 10:31:03.92 w3wp.exe (0x0758) 0x0F3C Windows SharePoint Services Workflow Infrastructure 72eo Unexpected DehydrateInstance: System.Runtime.Serialization.SerializationException: 在分析完成之前就遇到流结尾。 在 System.Runtime.Serialization.Formatters.Binary.__BinaryParser.Run() 在 System.Runtime.Serialization.Formatters.Binary.ObjectReader.Deserialize(HeaderHandler handler, __BinaryParser serParser, Boolean fCheck, Boolean isCrossAppDomain, IMethodCallMessage methodCallMessage) 在 System.Runtime.Serialization.Formatters.Binary.BinaryFormatter.Deserialize(Stream serializationStream, HeaderHandler handler, Boolean fCheck, Boolean isCrossAppDomain, IMethodCallMessage methodCallMessage) 在 System.Runtime.Serialization.Formatters.Binary.BinaryFormatter.Deserialize(Stream serializationStream) 在 System.Workflow.ComponentModel.Activity.Load(Stream stream, Activity outerActivity, IFormatter formatter)...
02/06/2007 10:31:03.92* w3wp.exe (0x0758) 0x0F3C Windows SharePoint Services Workflow Infrastructure 72eo Unexpected ... 在 System.Workflow.ComponentModel.Activity.Load(Stream stream, Activity outerActivity) 在 System.Workflow.Runtime.Hosting.WorkflowPersistenceService.RestoreFromDefaultSerializedForm(Byte[] activityBytes, Activity outerActivity) 在 Microsoft.SharePoint.Workflow.SPWinOePersistenceService.LoadWorkflowInstanceState(Guid instanceId) 在 System.Workflow.Runtime.WorkflowRuntime.InitializeExecutor(Guid instanceId, CreationContext context, WorkflowExecutor executor, WorkflowInstance workflowInstance) 在 System.Workflow.Runtime.WorkflowRuntime.Load(Guid key, CreationContext context, WorkflowInstance workflowInstance) 在 System.Workflow.Runtime.WorkflowRuntime.GetWorkflow(Guid instanceId) 在 Microsoft.SharePoint.Workflow.SPWinOeHostServices.DehydrateInstance(SPWorkflowInstance wo...
02/06/2007 10:31:03.92* w3wp.exe (0x0758) 0x0F3C Windows SharePoint Services Workflow Infrastructure 72eo Unexpected ...rkflow)
02/06/2007 10:31:03.93 w3wp.exe (0x0758) 0x0F3C Windows SharePoint Services Workflow Infrastructure 88xr Unexpected WinWF Internal Error, terminating workflow Id# 472dae03-5465-4f04-876f-d4cc4caa902a |
看里边最长的一段中文描述:"在分析完成之前就遇到流结尾",如果是SharePoint英文版,这段错误信息应该是"End of Stream encountered before parsing was completed".
也就是说Workflow Runtime根本就没有完整的分析完整个流程.
再看这句中文之前的英文:"DehydrateInstance: System.Runtime.Serialization.SerializationException".
原来工作流是在钝化实例的时候发生了序列化异常.
回想一下工作流的持久性,Workflow Runtime会把空闲的工作流数据序列化为XML形式,然后把工作流实例从内存中清除,等到需要的时候再将其反序列化加载到内存.
会不会是因为我在工作流项目中添加了自定义类,而这个类又不支持序列化,所以导致工作流序列化失败?
在工作流中使用InfoPath Initiation(或者Association)表单时需要为其生成一个类,观察这个类,发现这个用XSD生成的类有如下特性来修饰:
[System.CodeDom.Compiler.GeneratedCodeAttribute("xsd", "2.0.50727.42")] [System.SerializableAttribute()] [System.Diagnostics.DebuggerStepThroughAttribute()] [System.ComponentModel.DesignerCategoryAttribute("code")] [System.Xml.Serialization.XmlTypeAttribute(AnonymousType=true)] [System.Xml.Serialization.XmlRootAttribute(Namespace="http://schemas.microsoft.com/office/infopath/2003/myXSD/2007-01-30T13:00:28", IsNullable=false)] |
下面来逐行分析一下:
[System.CodeDom.Compiler.GeneratedCodeAttribute("xsd", "2.0.50727.42")]
表示这个类是由XSD工具生成的.
[System.SerializableAttribute()]
表示这个类可以被序列化,我想关键就在这里.
[System.Diagnostics.DebuggerStepThroughAttribute()]
表示调试器会自动忽略被修饰的类内部的断点
[System.ComponentModel.DesignerCategoryAttribute("code")]
表示设计器的类别是"code"
[System.Xml.Serialization.XmlTypeAttribute(AnonymousType=true)]
表示系列化时生成的XSD架构是匿名类型
[System.Xml.Serialization.XmlRootAttribute(Namespace="http://schemas.microsoft.com/office/infopath/2003/myXSD/2007-01-30T13:00:28", IsNullable=false)]
设置序列化时根元素的命名空间
删去或修改我们不需要的特性(比如第一项),将其插入到我们的自定义类中,工作流就正常了.
update 2008.12.25
- 其实只需要将自定义类标识为[Serializable]即可。
- 其实不仅是自定义类,只要是在工作流类中的类级别变量,都必须实现了ISerializable的,而方法内的局部变量则可以不支持序列化。否则工作流在进行钝化是无法序列化某些变量,也会导致这个错误。比如在工作流累中定义了一个XmlDocument,就会发生此错误。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· [AI/GPT/综述] AI Agent的设计模式综述