6

我有一个连接到 WCF 服务的 Silverlight 应用程序。在我习惯的基本配置下,将此应用程序连接到其对应的 WCF 服务是没有问题的。

然而,最近,我的一个客户开始使用 Apache 反向代理。此代理是公共服务器,它仅用于通过客户端和它之间的 SSL (HTTPS) 加密 HTTP 流量。此代理将所有流量从它传递到托管我的应用程序的实际 Web 服务器。公共代理和 IIS 服务器之间的流量只是普通的 HTTP。

所以流量像这样流动: 最终用户浏览器---HTTPS---->公共反向代理----HTTP---->承载WCF服务的IIS服务器。

反向代理和 IIS 位于两个单独的服务器上。

我无法让 Silverlight 应用程序正常运行。我不确定如何配置端点?每当我使用公共代理的地址作为我的端点地址时,我都会遇到问题。

Silverlight 应用程序通常具有以下配置:

<configuration>
    <system.serviceModel>
        <bindings>
            <basicHttpBinding>
                <binding name="BasicHttpBinding_IPOTemplateEditorSrv" maxBufferSize="2147483647"
                    maxReceivedMessageSize="2147483647">
                    <security mode="TransportWithMessageCredential" />
                </binding>
            </basicHttpBinding>
        </bindings>
        <client>
            <endpoint address="https://public-reverse-proxy-url/POTemplateEditorSrv.svc"
                binding="basicHttpBinding" bindingConfiguration="BasicHttpBinding_IPOTemplateEditorSrv"
                contract="POEditorSrvRef.IPOTemplateEditorSrv" name="BasicHttpBinding_IPOTemplateEditorSrv" />
        </client>
    </system.serviceModel>
</configuration>

请注意,我正在使用并且我的端点地址指向反向代理的公共 HTTPS 地址。

我错过了什么吗?是否有任何其他信息可以配置代理?任何可以让我的 Silverlight 客户端连接到服务的解决方法?

4

1 回答 1

5

也许这个答案有点太明显了,但它听起来就像 WSDL 正在将一个内部主机名作为 WCF 地址进行广告 - 当该地址不是实际的公共地址时。因为 IIS 正在生成 WSDL,它只会在端点地址中使用它的主机名——这不是你想要的,你想要的是代理的地址。

尝试创建 WSDL 文件的静态副本,并将其发布到 Web 服务器上。确保将 ALL REFERENCES 替换为内部主机名,并使用公共代理主机名。然后修改您的 WCF 客户端配置以指向静态 WSDL。您可以在此处找到简短说明:在 WCF Web 服务的 WSDL 中提供不同的端点地址

如果这不起作用 - 尝试使用嗅探器(wireshark)来捕获来回发送的内容 - 禁用 HTTPS 可能是您需要从等式中删除的部分。您的 Web 服务请求似乎已发送到代理,但代理无法正确处理请求 - 尝试我们的嗅探工具的完美场景。

当您使用 Web 浏览器向 SVC 发出直接请求时,请求将如下所示

GET /POTemplateEditorSrv.svc HTTP/1.1
Host: public-reverse-proxy-url

但是当通过 Silverlight 发送时,它可能看起来像这样

GET /POTemplateEditorSrv.svc HTTP/1.1
Host: private-server-address

这可能是一个足以扰乱代理的微妙差异。

于 2012-09-04T23:03:48.213 回答