如何使用C#中的SharePoint Online 2013 Rest API删除列表项

3

我正在尝试使用C#托管代码和REST API从SharePoint 2013 Online中删除列表项。

以下是我的代码要点:

using (var client = new WebClient())
{
    client.Headers.Add("X-FORMS_BASED_AUTH_ACCEPTED", "f");
    client.Credentials = mySPCreds;

    client.Headers.Add(HttpRequestHeader.ContentType, "application/json;odata=verbose");
    client.Headers.Add(HttpRequestHeader.Accept, "application/json;odata=verbose");

    client.Headers.Add("X-HTTP-Method", "DELETE");
    client.Headers.Add("IF-MATCH", "*");

    var requestUri = new Uri("https://mysharepointsite.../_api/web/lists/getbytitle('MyList')/items(123)");

    client.UploadString(requestUri, String.Empty);
}

我遇到了403权限被拒绝的问题,但是使用类似的模式我可以创建一个列表项。我正在使用WebClient的凭据,它是一个SharePointOnlineCredentials对象。我是一个SharePoint站点管理员。
因此,我想知道是否只是我的语法/方法不正确。有人能验证上面的代码“应该”可以工作,假设我没有权限问题吗?
1个回答

1

好的,我找到了解决方案:

客户端标头需要包括表单摘要:

client.Headers.Add("X-RequestDigest", GetFormDigest());

获取表单验证令牌,您可以使用以下代码:

    private string GetFormDigest()
    {
        var webClient = new WebClient();
        webClient.Headers.Add("X-FORMS_BASED_AUTH_ACCEPTED", "f");
        webClient.Credentials = this.Credentials;
        webClient.Headers.Add(HttpRequestHeader.ContentType, String.Format("application/json;odata=nometadata"));
        webClient.Headers.Add(HttpRequestHeader.Accept, String.Format("application/json;odata=nometadata"));

        var uri = new Uri(this.SharepointBaseURL);
        var endpointUri = new Uri(uri, "_api/contextinfo");
        var result = webClient.UploadString(endpointUri, "POST");
        JToken t = JToken.Parse(result);

        //Use this if odata = nometadata
        return t["FormDigestValue"].ToString();

        //Use this if odata = verbose
        //return t["d"]["GetContextWebInformation"]["FormDigestValue"].ToString();
    }

注意:凭证也很棘手,下面是相关代码:
        var securePassword = new SecureString();
        foreach (var c in myPassword)
        {
            securePassword.AppendChar(c);
        }

        this.Credentials = new SharePointOnlineCredentials(myUserName, securePassword);

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接