六狼论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博账号登陆

只需一步,快速开始

搜索
查看: 187|回复: 0

SharePoint WebService 之更新审批状态

[复制链接]

升级  52%

40

主题

40

主题

40

主题

秀才

Rank: 2

积分
128
 楼主| 发表于 2012-12-29 11:20:57 | 显示全部楼层 |阅读模式
<div id="cnblogs_post_body">      SharePoint列表使用WebService操作,可以进行增删改查,但是操作开启审批功能列表的时候,会遇到列表项审批的问题,只要进行修改,该项目就会变成待定状态,然后想要修改审批状态,就使用UpdateListItems方法,一直自以为是的以为,修改审批状态,不就是更新么Cmd='Update'不就可以了,事实却不是如此。
审批方法名称UpdateListItems(string ListName, XmlNode updates)
参数名称
ListName  为列表名称,string类型
Updates   为XmlNode类型,用于更新
<Method ID='1' Cmd='Update'> Cmd参数,Update为更新
<Field Name='ID'>1</Field> Name参数,字段名称;Field中的值,ID字段的值
_ModerationStatus  为审批状态字段
审批状态:0为已批准 1为已拒绝 2为待定 3为草稿

示例代码[C#]
WebReference.Lists   listService = new WebReference.Lists();

listService.Credentials = System.Net.CredentialCache.DefaultCredentials;

string strBatch = "<Method   ID='1' Cmd='Update'>" +

                      "<Field   Name='ID'>1</Field>" +

                      "<Field   Name='_ModerationStatus'>0</Field></Method>";

XmlDocument xmlDoc = new   System.Xml.XmlDocument();

System.Xml.XmlElement   elBatch = xmlDoc.CreateElement("Batch");

elBatch.InnerXml = strBatch;

XmlNode ndReturn = listService.UpdateListItems("通知公告", elBatch);

Console.Write("操作成功");

      如上面的代码,居然执行完毕,也输出“操作成功”,真是见鬼了,但是审批状态,一直为待定,无论修改一次,或者修改几次,都是不会改变的,后来继续查资料,发现更新审批状态时的cmd不是update,真见鬼,居然是Moderate,如下面表格。
string strBatch = "<Method   ID='1' Cmd='Moderate'>" +

                      "<Field   Name='ID'>1</Field>" +

                      "<Field   Name='_ModerationStatus'>0</Field></Method>";

      修改完了strBatch的Cmd以后,执行,执行成功!
******************************************************************************
作者:霖雨
出处:http://www.cnblogs.com/jianyus
本文版权归 霖雨和博客园共有,欢迎转载,但请注明出处。
您需要登录后才可以回帖 登录 | 立即注册 新浪微博账号登陆

本版积分规则

快速回复 返回顶部 返回列表