5

我正在尝试使用客户端对象模型更新 Sharepoint 讨论板中的“ModifiedBy”字段。通过更改“编辑者”和“作者”字段,我可以更改列表视图中显示的“修改者”。但是,一旦您单击讨论帖子,那里出现的“ModifiedBy”字段(上面有图片的那个)不会反映更改。经过实验,我发现我需要更改以更正此问题的字段称为“MyEditor”。不幸的是,这个字段是只读的。

在下面的代码中,我尝试将字段的只读设置更改为 false。当我在第一个块底部的 ExecuteQuery() 行之后查看 Visual Studio 调试器中的 MyEditor 字段时,它表明 ReadOnlyField 值实际上已设置为 false。

        sharepointContext.Load(discussionList);
        sharepointContext.ExecuteQuery();
        var fields = discussionList.Fields;
        sharepointContext.Load(fields);
        sharepointContext.ExecuteQuery();
        var field = fields.GetByInternalNameOrTitle("MyEditor");
        field.ReadOnlyField = false;
        field.Update();
        sharepointContext.Load(field);
        sharepointContext.ExecuteQuery();

上面的代码执行没有问题。问题来自下一个块:

        //...Code to initialize discussionItem...
        discussionItem["MyEditor"] = 0;
        discussionItem["Editor"] = 0;
        discussionItem["Author"] = 0;
        discussionItem["Body"] = "Testing";
        discussionItem["Title"] = "Hello Worlds";
        discussionItem.Update();
        sharepointContext.Load(discussionItem);
        sharepointContext.ExecuteQuery();

当代码到达第二个块底部的 ExecuteQuery() 时,它会抛出带有以下消息的 ServerException:

        Invalid data has been used to update the list item. 
        The field you are trying to update may be read only.

为了确保 MyEditor 字段是引发异常的字段,我注释掉了我设置它的行并再次运行代码。一切正常。我不明白出了什么问题,有人可以帮助我吗?

4

2 回答 2

3

如果有人需要按名称查找用户,则如下所示:

    private static FieldUserValue GetUser(ClientContext clientContext, string userName)
    {
        var userValue = new FieldUserValue();
        var newUser = clientContext.Web.EnsureUser(userName);
        clientContext.Load(newUser);
        clientContext.ExecuteQuery();
        userValue.LookupId = newUser.Id;
        return userValue;
    }

返回值可以通过 item["Author"] 设置

于 2012-12-14T16:05:07.217 回答
1

ModifiedBy 和 CreadtedBy 从 Author 和 Editor 自动计算,您只需更改 Author 和 Editor 字段,如下所示:

        using (var clientContext = new ClientContext(@"http://server"))
        {
            var web = clientContext.Web;
            var lst = web.Lists.GetByTitle("Discus");

            var item = lst.GetItemById(2);
            item["Author"] = 3;
            item["Editor"] = 2;
            item.Update();
            clientContext.ExecuteQuery();                        

            Console.WriteLine("done");
        }
于 2012-07-13T10:58:50.163 回答