使用编程的方式来启动SharePoint的工作流

来源:互联网 发布:思迅不能连接到数据库 编辑:程序博客网 时间:2024/05/17 14:15
 

工作流是SharePoint很重要的一部分。我写的这篇文章是通过编程的方式启动工作流。一共分两个部分:启动无参数和有参数的工作流。

参考示例:http://www.sharepointkings.com/2008/09/how-to-pass-parameters-to-workflow.html

首先,通过SharePoint Designer 2010针对一个文档库设计两个工作流:

NameDescriptionMyWorkflow没有参数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="http://www.w3.org/2001/XMLSchema">  <YourName>Jim</YourName>  <YourAge>20</YourAge>  <YourDate>2009-06-01T00:00:00</YourDate></WFParameters>
代码比较简单,没有加特别的说明。

拓展:在工作中,有时候我们会需要根据某一列的值发生变化时来启动工作流,这个时候的解决方案是通过Event Handler的方式来做逻辑的判断,然后启动工作流。这种时候,我们只需要在ItemUpdated等事件来添加以上代码。