今天在一个新的SharePonit开发环境上执行代码出错,错误信息是“Exception of type 'Microsoft.SharePoint.SoapServer.SoapServerException' was thrown.”。
这段代码是很普通的调用SharePoint web service lists.asmx的方法,之前都是正常的,用来获取list中的item:
XmlDocument xmlDoc = new XmlDocument();
XmlNode query = xmlDoc.CreateNode(XmlNodeType.Element, "Query", "");
query.InnerXml = "<Where>... ...</Where>";
XmlNode viewFields = xmlDoc.CreateNode(XmlNodeType.Element, "ViewFields", "");
viewFields.InnerXml = "<FieldRef Name='Title' />";
XmlNode options = xmlDoc.CreateNode(XmlNodeType.Element, "QueryOptions", "");
options.InnerXml = "<ViewAttributes Scope='RecursiveAll' />";
XmlNode node = listWebService.GetListItems(listName, null, query, viewFields, null, options, null);
于是debug的时候查看了一下details,发现innertext中的错误信息是“Method not found...”
这应该是不可能的,这个是SharePoint web service提供的很常用的一个方法(GetListItems),怎么会找不到呢。我们知道,web serivce最终调用的方法是在stssoap.dll这个程序集中,难道是这个程序集出了问题?我在这个路径下找到了这个程序集“C:\Program Files\Common Files\Microsoft Shared\Web Server Extensions\14\CONFIG\BIN”,打开属性,看到的具体版本信息是14.0.6108:
然后我查看了一下GAC中的stssoap.dll文件的属性,发现版本号竟然不一样,GAC中的stssoap.dll文件的版本号是14.0.4762:
挺奇怪这两个文件的版本号竟然不同,web service使用的是GAC中的dll,可能是这个版本是有问题的。于是我把GAC中的stssoap.dll卸载了,将6108版本的stssoap.dll放到GAC中,这个问题就没有了。还不清楚为什么会这样。