如果你在工作流开发中没有适当的处理异常,当异常出现时你会在工作流列表的Status列中看到‘Error Occurred’,而得不到任何有关异常如何产生的线索。在这种情况下,你只能对你的工作流进行调试,但如果你不了解正确的调试方法,那会使你陷入窘境。
调试工作流的方式和调试其他.Net应用程序几乎一样。在工作流的代码视图中,选择你想调试的行并且加入断点。同样你也可以在工作流设计器中调试Activity.
右键点击你想调试的Activity,然后选择调试->插入断点。
接下来要做的事情是在Visual Studio调试器中附加w3wp.exe进程。在Visual Studio中点击Debug下拉菜单,选择附加进行,在进程列表中选择w3wp进程并点击附加。如果有多个w3wp进行,全部都选择附加。如果进程列表中没有这个进程,首先用浏览器打开你的SharePoint站点,然后重新回到进程列表中点击刷新按钮。附加了进程后就可以运行工作流了,当运行到断点所在行或Activity时,Visual Studio将会自动进入断点。
在工作流中进行异常处理和普通的.Net应用程序有一些区别。在工作流设计器中,没有地方加入Try/Catch语句块。许多开发者从不处理异常,而是花费大量的时间去调试,试图找到错误发生的地方。然而,更好的方法是在工作流的根节点中使用FaultHandler Activity,当然也可以在其他一些Activity中使用,比如:sequence,parallel,IfElse等等。
在FaultHandler Ativity内部,你可以插入一些activities来处理错误。在SharePoint中通常使用工作流历史记录列表来记录错误、错误发生的地方和跟踪信息。这使得定位错误更加容易。
在每一个工作流中,至少需要在工作流根节点中定义一个fault handler。点击工作流设计器的根节点(绿色箭头)下拉菜单,选择View Fault Handlers。
在fault handlers 区域中,你可以拖拽多个FaultHandler activities.每一个activity都有一个FaultType的属性,你需要将这个属性设置为你想要处理的异常类型(类似与Catch的参数)。如果要处理所有的异常,可以设置为System.Exception。另外,你也可以针对你的工作流设置一个自定义异常类型。这是一个非常好的做法,它能够使调试更加简单,因为你知道你的自定义异常会在什么时候,什么原因产生。
在你指定了要处理的异常类型后,你需要添加一些Actions去适当的处理错误。使用Log to History List activity来记录错误日志和跟踪信息通常对于调试是非常有帮助的。