对 SharePoint 进行 SOAP 调用时引发异常
当我尝试运行我的应用程序时,我收到此异常:
抛出了“Microsoft.SharePoint.SoapServer.SoapServerException”类型的异常
我正在对 SharePoint 进行肥皂调用,并且在执行肥皂调用时它会阻塞。
下面是我正在运行的代码,有什么想法为什么会发生这种情况吗?
public string getListData()
{
Lists myservice = new Lists();
myservice.Credentials = System.Net.CredentialCache.DefaultCredentials;
try
{
/* Assign values to pass the GetListItems method*/
string listName = "*list name*";
string viewName = "*view name*";
string rowLimit = "100";
//string successtest;
//string failtest;
// Instantiate an XmlDocument object
System.Xml.XmlDocument xmlDoc = new System.Xml.XmlDocument();
System.Xml.XmlElement query = xmlDoc.CreateElement("Query");
System.Xml.XmlElement viewFields = xmlDoc.CreateElement("ViewFields");
System.Xml.XmlElement queryOptions = xmlDoc.CreateElement("QueryOptions");
/*Use CAML query*/
query.InnerXml = "<Where><Gt><FieldRef Name=\"ID\" />" + "<Value Type=\"Counter\">0</Value></Gt></Where>";
viewFields.InnerXml = "<FieldRef Name=\"Title\" />";
queryOptions.InnerXml = "";
viewFields.InnerXml = "<FieldRef Name=\"Name\" />";
queryOptions.InnerXml = "";
System.Xml.XmlNode nodes = myservice.GetListItems(listName, viewName, query, viewFields, rowLimit, null, null);
foreach (System.Xml.XmlNode node in nodes)
{
if (node.Name == "rs:data")
{
for (int i = 0; i < node.ChildNodes.Count; i++)
{
if (node.ChildNodes[i].Name == "z:row")
{
//List<String> testList;
test = node.ChildNodes[i].Attributes["ows_Title"].Value;
//Console.WriteLine(node.ChildNodes[i].Attributes["ows_Title"].Value + "</br>");
}
}
}
}
}
catch (Microsoft.SharePoint.SoapServer.SoapServerException ex)
{
test = ex.Detail.InnerText;
//Console.WriteLine(ex.Message);
}
return test;
}
I am getting this exception when I try to run my application:
Exception of type 'Microsoft.SharePoint.SoapServer.SoapServerException' was thrown
I am making a soap call to SharePoint and it is choking when the soap call is being executed.
below is the code I am running any ideas why this is happening?
public string getListData()
{
Lists myservice = new Lists();
myservice.Credentials = System.Net.CredentialCache.DefaultCredentials;
try
{
/* Assign values to pass the GetListItems method*/
string listName = "*list name*";
string viewName = "*view name*";
string rowLimit = "100";
//string successtest;
//string failtest;
// Instantiate an XmlDocument object
System.Xml.XmlDocument xmlDoc = new System.Xml.XmlDocument();
System.Xml.XmlElement query = xmlDoc.CreateElement("Query");
System.Xml.XmlElement viewFields = xmlDoc.CreateElement("ViewFields");
System.Xml.XmlElement queryOptions = xmlDoc.CreateElement("QueryOptions");
/*Use CAML query*/
query.InnerXml = "<Where><Gt><FieldRef Name=\"ID\" />" + "<Value Type=\"Counter\">0</Value></Gt></Where>";
viewFields.InnerXml = "<FieldRef Name=\"Title\" />";
queryOptions.InnerXml = "";
viewFields.InnerXml = "<FieldRef Name=\"Name\" />";
queryOptions.InnerXml = "";
System.Xml.XmlNode nodes = myservice.GetListItems(listName, viewName, query, viewFields, rowLimit, null, null);
foreach (System.Xml.XmlNode node in nodes)
{
if (node.Name == "rs:data")
{
for (int i = 0; i < node.ChildNodes.Count; i++)
{
if (node.ChildNodes[i].Name == "z:row")
{
//List<String> testList;
test = node.ChildNodes[i].Attributes["ows_Title"].Value;
//Console.WriteLine(node.ChildNodes[i].Attributes["ows_Title"].Value + "</br>");
}
}
}
}
}
catch (Microsoft.SharePoint.SoapServer.SoapServerException ex)
{
test = ex.Detail.InnerText;
//Console.WriteLine(ex.Message);
}
return test;
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论