我编写了一个 ASMX Web 服务,该服务已在生产中运行多年。今天,Java 客户端在尝试解析响应时突然抛出错误。我们追踪到出现在 XML 声明之前的 BOM(字节顺序标记):
HTTP/1.1 200 OK
Cache-Control: no-cache
Pragma: no-cache
Content-Type: text/xml; charset=utf-8
Content-Encoding: gzip
Expires: -1
Vary: Accept-Encoding
Server: Microsoft-IIS/7.0
X-AspNet-Version: 2.0.50727
X-Powered-By: ASP.NET
MicrosoftSharePointTeamServices: 12.0.0.6300
Date: Wed, 22 Jun 2011 19:59:49 GMT
Content-Length: 3629
<?xml version="1.0" encoding="utf-8"?>
<soap:Envelope xmlns:soap="http://schemas.xmlsoap...
代码一年多来没有改变。 Web 服务在 IIS 中的 MOSS 2007 站点下运行,从上面的 HTTP 标头可以看到,但有自己的 web.config。
据我们所知,服务器的配置没有发生任何重大变化,但一定是有什么变化。有什么想法可能导致此情况吗?
如果我们无法追踪并恢复更改,下一个问题是,我可以在代码中修复此问题吗?
这是一个普通的 ASMX Web 服务,其 .asmx 文件如下所示:
<%@ WebService Language="c#" Codebehind="MyStuff.asmx.cs" Class="MyStuff.MyService" %>
和 .asmx.cs 文件,如下所示:
public class MyService : System.Web.Services.WebService {
...
[WebMethod(CacheDuration = 30, Description = "This does something", MessageName = "GetMyStuff")]
public XmlDocument GetMyStuff(string param) {
return doGetStuff(param)
}
private XmlDocument doGetStuff(string param) {
...
}
}
我看过一些帖子谈论BOM问题,但是由于我只是返回一个XML文档并且框架正在负责流回客户端,我不确定我是否可以做任何事情它。
更新:我发现我们的阶段服务器上不存在 BOM 问题。另一个线索可能是;当soapUI显示来自产品的原始响应时,它具有BOM并且SOAP XML看起来是格式化的(多行和缩进)。当我在舞台上看时,没有 BOM,整个响应都在一行上。所以其他也随 BOM 添加。
跟踪问题到 web.config 中的以下条目:
<webServices>
<soapExtensionTypes>
<add type="Cognos.Portal.Services.SoapPatchExtension, Cognos.BI.WebPart, Version=1.0.0.0, Culture=neutral, PublicKeyToken=cb3c72729d0875cd" priority="1" group="0" />
</soapExtensionTypes>
</webServices>
这是作为 Cognos Web Part 推出的一部分添加的配置,然后被注释掉。由于某种原因,SharePoint 决定将其放回原处。
进一步阅读建议修复是“升级到 IBM Cognos Business Intelligence 10.1 Fix Pack 1”。
此外,用户同时报告称 SharePoint 的“在数据表中编辑”和“导出到 Excel”功能出现故障。 根本原因是一样的。