工作流是SharePoint很重要的一部分。我写的这篇文章是通过编程的方式启动工作流。一共分两个部分:启动无参数和有参数的工作流。
参考示例:http://www.sharepointkings.com/2008/09/how-to-pass-parameters-to-workflow.html
首先,通过SharePoint Designer 2010针对一个文档库设计两个工作流:
Name | Description |
MyWorkflow | 没有参数 |
MyInitialDataWF | 三个参数:YourName(string); YourAge(Int); YourDate(DateTime) |
首先看一下无参数工作流。
这个比较简单,直接使用SPWorkflowManager.StartWorkflow Method(http://msdn.microsoft.com/en-us/library/ms467505.aspx)来启动工作流,代码如下:
public void StartWorkflow(SPWeb web) { SPList testDocLib = web.GetList("TestDocLib"); SPListItem wfItem = testDocLib.GetItemById(2); SPWorkflowAssociationCollection wfAssociationColls = testDocLib.WorkflowAssociations; CultureInfo ci=CultureInfo.CurrentCulture; SPWorkflowAssociation spWFAss = wfAssociationColls.GetAssociationByName("MyWorkflow", ci); Console.WriteLine(spWFAss.Name); web.Site.WorkflowManager.StartWorkflow(wfItem, spWFAss, spWFAss.AssociationData, true); }
接下来看一下启动带参数的工作流。这里唯一一个注意的地方就是这个参数是需要我们进行序列化的。
我们需要定义一个参数类:
[Serializable()] public class WFParameters { public string YourName { get;set;} public int YourAge{get;set;} public DateTime YourDate { get; set; } public string GetInitXmlString(WFParameters objParameters) { WFParameters wfData = new WFParameters(); wfData.YourName = objParameters.YourName; wfData.YourAge = objParameters.YourAge; wfData.YourDate = objParameters.YourDate; using (MemoryStream stream = new MemoryStream()) { XmlSerializer serializer = new XmlSerializer( typeof(WFParameters)); serializer.Serialize(stream, wfData); stream.Position = 0; byte[] bytes = new byte [stream.Length]; stream.Read(bytes, 0, bytes.Length); return Encoding.UTF8.GetString(bytes); } } }
然后我们来传递这个参数给SPWorkflowAssociation.AssociationData
代码如下:
public void StartWorkflow(SPWeb web) { SPList testDocLib = web.GetList("TestDocLib"); SPListItem wfItem = testDocLib.GetItemById(2); SPWorkflowAssociationCollection wfAssociationColls = testDocLib.WorkflowAssociations; CultureInfo ci=CultureInfo.CurrentCulture; SPWorkflowAssociation spWFInitialAss = wfAssociationColls.GetAssociationByName("MyInitialDataWF", ci); WFParameters objParameters = new WFParameters(); objParameters.YourName = "Jim"; objParameters.YourAge = 20; objParameters.YourDate = DateTime.Parse("6/1/2009"); string serializedParameters = objParameters.GetInitXmlString(objParameters); Console.WriteLine(serializedParameters); spWFInitialAss.AssociationData=serializedParameters; web.Site.WorkflowManager.StartWorkflow( wfItem, spWFInitialAss, spWFInitialAss.AssociationData, true); }
我们如果跟踪SPWorkflowAssociation.AssociationData这个参数,会发现是一个XML格式的字符串。如下:
<?xml version="1.0"?> <WFParameters xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="h ttp://www.w3.org/2001/XMLSchema"> <YourName>Jim</YourName> <YourAge>20</YourAge> <YourDate>2009-06-01T00:00:00</YourDate> </WFParameters>代码比较简单,没有加特别的说明。
拓展:在工作中,有时候我们会需要根据某一列的值发生变化时来启动工作流,这个时候的解决方案是通过Event Handler的方式来做逻辑的判断,然后启动工作流。这种时候,我们只需要在ItemUpdated等事件来添加以上代码。