是的,我已经阅读了有关SO,MSDN和其他网站的其他问题,但我发现没有我能理解的答案。我需要设置我的Silverlight应用程序的WCF引用相对于它加载的站点,但我无法让它工作。服务本身没有问题,它正在运行。当我从本地移动到我的真实服务器时,我的SL应用程序中出现错误,抱怨没有连接到localhost。
这是我的ServiceReferences.ClientConfig
文件:
<configuration>
<system.serviceModel>
<bindings>
<customBinding>
<binding name="CustomBinding_AccountManager">
<binaryMessageEncoding />
<httpTransport maxReceivedMessageSize="2147483647" maxBufferSize="2147483647" />
</binding>
<binding name="CustomBinding_FileManager">
<binaryMessageEncoding />
<httpTransport maxReceivedMessageSize="2147483647" maxBufferSize="2147483647" />
</binding>
<binding name="CustomBinding_SiteManager">
<binaryMessageEncoding />
<httpTransport maxReceivedMessageSize="2147483647" maxBufferSize="2147483647" />
</binding>
</customBinding>
</bindings>
<client>
<endpoint address="http://localhost:60322/AccountManager.svc"
binding="customBinding" bindingConfiguration="CustomBinding_AccountManager"
contract="AccountManager.AccountManager" name="CustomBinding_AccountManager" />
<endpoint address="http://localhost:60322/FileManager.svc" binding="customBinding"
bindingConfiguration="CustomBinding_FileManager" contract="FileManager.FileManager"
name="CustomBinding_FileManager" />
<endpoint address="http://localhost:60322/SiteManager.svc" binding="customBinding"
bindingConfiguration="CustomBinding_SiteManager" contract="SiteManager.SiteManager"
name="CustomBinding_SiteManager" />
</client>
</system.serviceModel>
</configuration>
是的,我将优化缓冲区/邮件大小,我知道可能的DoS攻击,暂时忘记它,我需要它们进行大文件传输。我尝试的方法是在实例化客户端时,我使用了这段代码:
fileManager = new FileManagerClient(new BasicHttpBinding(), new EndpointAddress("http://" + Settings.Host + "/FileManager.svc"));
accManager = new AccountManagerClient(new BasicHttpBinding(), new EndpointAddress("http://" + Settings.Host + "/AccountManager.svc"));
其中Settings.Host
是我自己的方法,它返回SL应用程序运行的主机,经过测试,有效。当我上传我的XAP并尝试过时,它仍然想要http://localhost:60322/AccountManager.svc
,经过进一步调查后,我意识到在看不见的文件中仍有很多对localhost的引用:< / p>
AccountManager.disco
:
<?xml version="1.0" encoding="utf-8"?>
<discovery xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns="http://schemas.xmlsoap.org/disco/">
<contractRef ref="http://localhost:60322/AccountManager.svc?wsdl" docRef="http://localhost:60322/AccountManager.svc" xmlns="http://schemas.xmlsoap.org/disco/scl/" />
</discovery>
AccountManager.wsdl
的部分内容:
... <wsdl:import namespace="" location="http://localhost:60322/AccountManager.svc?wsdl=wsdl0" />...
...... [许多操作声明] ......
<wsdl:service name="AccountManager">
<wsdl:port name="CustomBinding_AccountManager" binding="tns:CustomBinding_AccountManager">
<soap12:address location="http://localhost:60322/AccountManager.svc" />
<wsa10:EndpointReference>
<wsa10:Address>http://localhost:60322/AccountManager.svc</wsa10:Address>
</wsa10:EndpointReference>
</wsdl:port>
</wsdl:service>
AccountManager1.xsd
的一部分:
<xs:import schemaLocation="http://localhost:60322/AccountManager.svc?xsd=xsd2" namespace="http://schemas.datacontract.org/2004/07/Leftouch.Data.Summary" />
configuration.svcinfo
的一部分:
<endpoint normalizedDigest="<?xml version="1.0" encoding="utf-16"?><Data address="http://localhost:60322/AccountManager.svc" binding="customBinding" bindingConfiguration="CustomBinding_AccountManager" contract="AccountManager.AccountManager" name="CustomBinding_AccountManager" />" digest="<?xml version="1.0" encoding="utf-16"?><Data address="http://localhost:60322/AccountManager.svc" binding="customBinding" bindingConfiguration="CustomBinding_AccountManager" contract="AccountManager.AccountManager" name="CustomBinding_AccountManager" />" contractName="AccountManager.AccountManager" name="CustomBinding_AccountManager" />
Reference.svcmap
的一部分:
</ClientOptions>
<MetadataSources>
<MetadataSource Address="http://localhost:60322/AccountManager.svc" Protocol="http" SourceId="1" />
</MetadataSources>
<Metadata>
<MetadataFile FileName="AccountManager2.xsd" MetadataType="Schema" ID="e473b2d5-7af3-4390-87c3-a4fc3f54fb96" SourceId="1" SourceUrl="http://localhost:60322/AccountManager.svc?xsd=xsd2" />
<MetadataFile FileName="AccountManager1.xsd" MetadataType="Schema" ID="fd3a1ae0-b38b-4586-8622-5b0ee07e39fb" SourceId="1" SourceUrl="http://localhost:60322/AccountManager.svc?xsd=xsd0" />
<MetadataFile FileName="AccountManager.xsd" MetadataType="Schema" ID="6a49ee64-6eac-40e2-bcff-26418435e777" SourceId="1" SourceUrl="http://localhost:60322/AccountManager.svc?xsd=xsd1" />
<MetadataFile FileName="AccountManager.disco" MetadataType="Disco" ID="9ec9a8cc-0cf0-4264-a526-b5a6c08f7d36" SourceId="1" SourceUrl="http://localhost:60322/AccountManager.svc?disco" />
<MetadataFile FileName="AccountManager1.wsdl" MetadataType="Wsdl" ID="54a5b2c0-9d0e-4043-a7e4-d27ae6674bfc" SourceId="1" SourceUrl="http://localhost:60322/AccountManager.svc?wsdl=wsdl0" />
<MetadataFile FileName="AccountManager.wsdl" MetadataType="Wsdl" ID="f8923013-3a6c-412b-b7da-bee5a5a7bb64" SourceId="1" SourceUrl="http://localhost:60322/AccountManager.svc?wsdl" />
..还有其他2项服务的所有这些。
我不是Web服务/绑定/端点/操作合同或任何相关内容的主人。我只是想让我完全已经很好的工作(当URI是硬编码的)系统工作的相对URI,这就是我所需要的。必须有一个简单的解决方案。有人可以解释完全那些文件类型和声明类似,哪些是重要的,哪些是可选的,以及如何以最干净的形式创建动态服务引用。请解释一下。我已经看过很多关于动态服务绑定和引用的帖子和文章,但老实说,一切都搞砸了,我最终都不理解它。任何建设性的批评和解决方案都是受欢迎的。
答案 0 :(得分:2)
您的服务(而不是客户端)的配置文件是否使用具有完全限定地址的端点(如客户端配置)?如果是这样,你看到所有那些localhost引用的原因是因为当你添加服务引用时,它将在生成的文件中传递该地址。
更新服务配置文件中的端点,以使用该计算机上的完全限定地址(即http://somname.com/service.svc
),或将配置文件中的baseAddresses设置为计算机名称。
此外,如果您正在使用WCF 4.0(VS 2010 / .NET 4.0),您可以让WCF通过从配置文件中完全省略端点来为您的服务创建默认端点(据我所知 - 我们现在只是在工作中移动到4.0,所以我没有使用新功能。)
已添加
新方法,相同的基本思想(从某处导入URI)。根据您在下面的评论,听起来您的服务配置设置正常,没有硬编码的URI指向localhost。
当您将应用程序移动到目标服务器时,是否还要更新对服务的引用(通过“添加服务引用”),或者只是将从本地框生成的文件移动到目标服务器?
如果你是,我想知道这可能是你问题的根源。我想认为在创建客户端时指定服务地址应覆盖WSDL相关文件中的任何内容,但可能不是。
要尝试的东西:
从Web.config中删除<client>
部分。然后,当您创建客户端时,请执行以下操作:
fileManager = new FileManagerClient(new BasicHttpBinding("CustomBinding_FileManager"), new EndpointAddress("http://" + Settings.Host + "/FileManager.svc"));
确保在BasicHttpBinding
构造函数中传递绑定配置部分的名称,否则您将获得默认值的绑定,而不是您指定的较大值。
这里的想法是消除客户端配置文件设置覆盖您在FileManagerClient创建时传递的内容的任何可能性。
我认为必须为每个服务器的每个部署更新服务引用都不太理想 - 你想要完成的事情是有意义的。我在我编写的n层应用程序中做了类似的事情 - 唯一的区别是我不使用服务引用,我通过SvcUtil生成代理,然后通过ChannelFactory<T>
生成通道,这是另一条路线你可能想看一下。
如果没有这方面的帮助,请随时给我发电子邮件(我的电子邮件地址在我的个人资料中) - 通过电子邮件交换可以更容易地解决这个问题,然后发布最终解决方案。< / p>