SharePoint Web Service系列:进行列表的增删改
异构应用访问SharePoint的文档库或列表时,使用WebService的方式再恰当不过了。有朋友问我如何在dotNet Framework 3.0下的应用程序中控制SharePoint 2003中的列表项。想一想类似的场景应该比较常见,所以写了下面的demo。以下的代码在VS2005中测试通过。
using System;
using System.Xml;
using System.Collections.Generic;
using System.Text;
namespace ConsoleDemo
{
class Program
{
static void Main(string[] args)
{
try
{
test();
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
Console.WriteLine("END");
Console.Read();
}
private static void test()
{
LabPortal.Lists listService = new ConsoleDemo.LabPortal.Lists();
listService.Credentials = System.Net.CredentialCache.DefaultCredentials;
string strBatch = "<Method ID='1' Cmd='New'>"+ //
//ID是Method的唯一标识,如果有多个Method就都列在下面
//Cmd的类型有:New,Update,Delete。分别对应增加,删除,更新
"<Field Name='ID'>New</Field>"+ //
//ID在增加操作时只是个唯一标记,可以随便指定,并不对应到实际
//listitem的ID。但在删除和更新时就必须是实际的ID了,因为要靠这个来唯一指定一条记录
"<Field Name='Title'>Smf</Field>"+
"</Method>";
XmlDocument xmlDoc = new XmlDocument();
XmlElement elBatch = xmlDoc.CreateElement("Batch");
//Batch元素下面的这些Attribue是可选的
elBatch.SetAttribute("OnError", "Continue"); //指定出错后是返回还是继续下一步
elBatch.SetAttribute("ListVersion","1"); //指定列表的版本
elBatch.SetAttribute("ViewName", "654446D3-8E70-4483-B2B6-F87329EAC2D9"); //指定所操作的列表视图GUID
elBatch.InnerXml = strBatch;
XmlNode ndReturn = listService.UpdateListItems("Contracts", elBatch); //在名为Contracts的联系人列表中增加一条记录
Console.WriteLine(ndReturn.OuterXml);
}
}
}
using System.Xml;
using System.Collections.Generic;
using System.Text;
namespace ConsoleDemo
{
class Program
{
static void Main(string[] args)
{
try
{
test();
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
Console.WriteLine("END");
Console.Read();
}
private static void test()
{
LabPortal.Lists listService = new ConsoleDemo.LabPortal.Lists();
listService.Credentials = System.Net.CredentialCache.DefaultCredentials;
string strBatch = "<Method ID='1' Cmd='New'>"+ //
//ID是Method的唯一标识,如果有多个Method就都列在下面
//Cmd的类型有:New,Update,Delete。分别对应增加,删除,更新
"<Field Name='ID'>New</Field>"+ //
//ID在增加操作时只是个唯一标记,可以随便指定,并不对应到实际
//listitem的ID。但在删除和更新时就必须是实际的ID了,因为要靠这个来唯一指定一条记录
"<Field Name='Title'>Smf</Field>"+
"</Method>";
XmlDocument xmlDoc = new XmlDocument();
XmlElement elBatch = xmlDoc.CreateElement("Batch");
//Batch元素下面的这些Attribue是可选的
elBatch.SetAttribute("OnError", "Continue"); //指定出错后是返回还是继续下一步
elBatch.SetAttribute("ListVersion","1"); //指定列表的版本
elBatch.SetAttribute("ViewName", "654446D3-8E70-4483-B2B6-F87329EAC2D9"); //指定所操作的列表视图GUID
elBatch.InnerXml = strBatch;
XmlNode ndReturn = listService.UpdateListItems("Contracts", elBatch); //在名为Contracts的联系人列表中增加一条记录
Console.WriteLine(ndReturn.OuterXml);
}
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· [AI/GPT/综述] AI Agent的设计模式综述