2
我正嘗試使用C#中的Web服務訪問文檔庫中的文件夾。 我使用SiteData的EnumerateFolder()
方法來獲取子文件夾和文件。但該方法只給我每個條目3個屬性。迭代SharePoint文件夾內容時出現的問題
- IsFolder
- 網址
- 最近更新日期
那麼,如何才能 '修改者' 字段的值。
還有另一種枚舉文件夾和子文件夾的解決方案。
謝謝。
我正嘗試使用C#中的Web服務訪問文檔庫中的文件夾。 我使用SiteData的EnumerateFolder()
方法來獲取子文件夾和文件。但該方法只給我每個條目3個屬性。迭代SharePoint文件夾內容時出現的問題
- IsFolder
- 網址
- 最近更新日期
那麼,如何才能 '修改者' 字段的值。
還有另一種枚舉文件夾和子文件夾的解決方案。
謝謝。
您需要使用List API才能從對象中獲取更多屬性。
[編輯 - 完整的代碼示例]
樣品需要進行清理,但應該給你什麼,你需要
public void SomeFunction()
{
Lists lists = new Lists(); //http://server/_vti_bin/Lists.asmx
XmlNode coll = lists.GetListCollection();
XmlNamespaceManager nsMgr = new XmlNamespaceManager(coll.OwnerDocument.NameTable);
nsMgr.AddNamespace("sp", "http://schemas.microsoft.com/sharepoint/soap/");
nsMgr.AddNamespace("z", "#RowsetSchema");
XmlDocument xmlDoc = new XmlDocument();
XmlElement query = xmlDoc.CreateElement("Query");
XmlElement viewFields = xmlDoc.CreateElement("ViewFields");
XmlElement queryOptions = xmlDoc.CreateElement("QueryOptions");
viewFields.InnerXml = "<FieldRef Name=\"Modified_x0020_By\" />";
queryOptions.InnerXml = "<ViewAttributes Scope=\"RecursiveAll\"/>";
XmlNodeList siteLists = coll.SelectNodes("//sp:List", nsMgr);
foreach (XmlNode list in siteLists)
{
if (list.Attributes["ServerTemplate"].Value != "101") continue; //101=DocLib
XmlNode listItemCollection = lists.GetListItems(list.Attributes["Name"].Value, string.Empty, query,
viewFields, "4000",
queryOptions, null);
XmlNodeList listItems = listItemCollection.SelectNodes("//z:row", nsMgr);
foreach (XmlNode listItem in listItems)
{
if (listItem.Attributes["ows_FSObjType"] == null) continue;
if (!listItem.Attributes["ows_FSObjType"].Value.EndsWith("#1")) continue;
PrintModifiedBy(listItem);
}
}
}
private void PrintModifiedBy(XmlNode listItem)
{
string modifiedBy;
if (listItem.Attributes["Modified_x0020_By"] != null)
modifiedBy = listItem.Attributes["ows_Modified_x0020_By"].Value;
else
modifiedBy = listItem.Attributes["ows_Editor"].Value;
Console.WriteLine(modifiedBy);
}
我使用的Web服務。 – Royson 2010-03-12 08:25:51
編輯我的答案與ListService的一些Caml代碼。這不完整,但應該讓你開始。 – 2010-03-12 09:42:23
謝謝mikael ..我會嘗試CAML查詢。但PLZ更新與我的問題。 ;) – Royson 2010-03-12 10:15:38