zoukankan      html  css  js  c++  java
  • SharePoint Workflow Debugging

    如果你在工作流开发中没有适当的处理异常,当异常出现时你会在工作流列表的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来记录错误日志和跟踪信息通常对于调试是非常有帮助的。
    每个人都会经过这个阶段,见到一座山,就想知道山后面是什么。我很想告诉他,可能翻过山后面,你会发现没什么特别。回望之下,可能会觉得这一边更好。 每个人都会坚持自己的信念,在别人看来,是浪费时间,她却觉得很重要。
  • 相关阅读:
    UVA 11997 K Smallest Sums
    POJ 1007 DNA Sorting
    POJ 3669 Meteor Shower
    POJ 2376 Cleaning Shifts
    POJ 3050 Hopscotch
    操作系统第6次实验报告:使用信号量解决进程互斥访问
    操作系统第5次实验报告:内存管理
    操作系统第4次实验报告:文件系统
    操作系统第3次实验报告:管道
    操作系统第2次实验报告:创建进程
  • 原文地址:https://www.cnblogs.com/amingo/p/2041474.html
Copyright © 2011-2022 走看看