Sharepoint通过Web服务访问“用户信息列表”

时间:2009-08-20 10:44:45

标签: c# sharepoint sharepoint-2007 moss

我正在尝试获取“用户信息列表”的内容。此列表只能作为管理员用户进行访问。我有一个以admin用户身份登录的方法,然后执行以下操作:

var xmlDoc = new XmlDocument();
var query = xmlDoc.CreateElement("Query");
query.InnerXml = "<Where><Eq><FieldRef Name='ContentType' /><Value Type='Choice'>Person</Value></Eq></Where>";
XmlElement viewFields = xmlDoc.CreateElement("ViewFields");
viewFields.InnerXml = "<FieldRef Name='Title' />";
XmlElement queryOptions = xmlDoc.CreateElement("QueryOptions");
var items = ws.GetListItems("User Information List", "", query, viewFields, string.Empty, queryOptions, "8A391AE3-2783-489B-8BDF-D2AE971D73CD");

我的列表名称是正确的,我通过SharePoint Explorer从下面获取的GUID也是如此

<List DocTemplateUrl="" DefaultViewUrl="/_catalogs/users/detail.aspx" MobileDefaultViewUrl="" ID="{8A391AE3-2783-489B-8BDF-D2AE971D73CD}" Title="User Information List" Description="All people." ImageUrl="/_layouts/images/users.gif" Name="{8A391AE3-2783-489B-8BDF-D2AE971D73CD}" BaseType="0" FeatureId="" ServerTemplate="112" Created="20080430 02:48:38" Modified="20090819 08:31:52" LastDeleted="20090604 12:32:50" Version="141" Direction="none" ThumbnailSize="" WebImageWidth="" WebImageHeight="" Flags="41971988" ItemCount="46" AnonymousPermMask="0" RootFolder="/_catalogs/users" ReadSecurity="1" WriteSecurity="1" Author="1" EventSinkAssembly="" EventSinkClass="" EventSinkData="" EmailInsertsFolder="" EmailAlias="" WebFullUrl="/" WebId="767c0b20-058d-4b53-8362-81e005bf5098" SendToLocation="" ScopeId="64857900-37cf-431c-be07-5528d1ae46af" MajorVersionLimit="0" MajorWithMinorVersionsLimit="0" WorkFlowId="" HasUniqueScopes="False" AllowDeletion="False" AllowMultiResponses="False" EnableAttachments="True" EnableModeration="False" EnableVersioning="False" Hidden="True" MultipleDataList="False" Ordered="False" ShowUser="True" EnableMinorVersion="False" RequireCheckout="False" />

我收到以下错误:

<?xml version="1.0" encoding="utf-8"?>
    <soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
        <soap:Body>
            <soap:Fault>
                <faultcode>soap:Server</faultcode>
                <faultstring>Exception of type 'Microsoft.SharePoint.SoapServer.SoapServerException' was thrown.</faultstring>
                <detail>
                    <errorstring xmlns="http://schemas.microsoft.com/sharepoint/soap/">The system cannot find the file specified. (Exception from HRESULT: 0x80070002)</errorstring>
                </detail>
            </soap:Fault>
        </soap:Body>
    </soap:Envelope>

你知道我为什么会收到这个错误吗?

更新

该行

var items = ws.GetListItems("User Information List", "", query, viewFields, string.

在C#代码中抛出异常。抛出的异常是:

Exception of type 'Microsoft.SharePoint.SoapServer.SoapServerException' was thrown.

没有太多帮助......

更新2

我在网上发现了这个http://www.aidangarnish.net/blog/post/2008/04/Retrieving-items-from-a-MOSS-2007-list-using-web-services.aspx并将我的代码更改为:

var node = ws.GetListItems("User Information List", String.Empty, null, null, String.Empty, null, null);

我现在收到了结果!仍然不确定我的初始查询有什么问题,所以问题就在于......

3 个答案:

答案 0 :(得分:3)

如果您遇到问题“系统找不到指定的文件。(HRESULT异常:0x80070002)”再次尝试将最后一个参数“webId”设置为null。

请看Microsoft的Web服务规范:

  

webID:可选。包含父网站的GUID的字符串   对于由花括号({})包围的列表。设置此参数   to null表示由URL属性指定的Web站点   将使用服务,如果服务的URL属性不是   指定后,将使用根网站。

来源:http://msdn.microsoft.com/en-us/library/lists.lists.getlistitems(v=office.12).aspx

答案 1 :(得分:1)

我不确定这会回答你的问题,但是,如果你使用以下方式访问用户信息表,我有更多的运气,包括不必以管理员身份登录:

  • “的UserInfo”

而不是:

  • “用户信息列表”

它在此处的文档中列出: http://msdn.microsoft.com/en-us/library/lists.lists.getlist.aspx

LISTNAME 包含列表的标题或GUID的字符串。查询UserInfo表时,该字符串包含“UserInfo”。

也许给这一点。

答案 2 :(得分:1)

var node = ws.GetListItems("User Information List", String.Empty, null, null, String.Empty, null, null);

似乎从试错中工作正常。