0

我使用 JAX-WS (v2.1.3 - Sun JDK 1.6.0_05) 开发了一个 Web 服务,当我使用 Java 客户端或 SoapUI 或其他 Web 服务测试工具时它工作得很好。我需要使用 2005 Microsoft SQL Server Reporting Services 使用此服务,我收到以下错误

<?xml version='1.0' encoding='UTF-8'?>
<S:Envelope xmlns:S="http://schemas.xmlsoap.org/soap/envelope/">
    <S:Body>
        <S:Fault xmlns:ns4="http://www.w3.org/2003/05/soap-envelope">
            <faultcode>S:Client</faultcode>
            <faultstring>Couldn't create SOAP message due to exception: XML reader error: unexpected character content:
                "?"
            </faultstring>
        </S:Fault>
    </S:Body>
</S:Envelope>

如果我使用 HTTP 代理来检测 SSRS 发送的内容,我会将 EF BB BF 视为帖子正文的开头,而 JAX-WS 不喜欢这样。如果我删除特殊字符并使用 Fiddler 重新提交请求,那么 Web 服务调用将起作用。

我的问题是为什么 SSRS 会引入这些特殊字符,我怎样才能让它停止?如果我不能阻止它,我怎样才能让 JAX-WS 忽略它们?这是我的 SSRS 查询:

<Query>
<Method Name="getOneUser" Namespace="http://vinny.com" >
</Method>
</Query>

我也尝试过如下查询:

<Query>
<Method Name="getOneUser" Namespace="http://vinny.com" >
</Method>
 <SoapAction>http://vinny.com/getOneUser</SoapAction>
<ElementPath IgnoreNamespaces="true">*</ElementPath>
</Query>

有人对我可以尝试什么有任何想法吗?我已经在 J​​AX-WS 端尝试了几种不同类型的注释来更改 SOAPBinding 的类型等,但似乎没有任何东西可以使其与 Microsoft SSRS 一起使用。

4

1 回答 1

0

“特殊字符”是表示帖子正文是 UTF-8 的“字节顺序标记”(BOM)。http://unicode.org/faq/utf_bom.html#BOM

Java 服务应该足够聪明,不会吐出这些字符;恐怕我不知道如何帮助它。

于 2009-10-27T21:13:34.317 回答