0

多亏了 stackoverflow(主要是),我创建了一个 WCF 服务,该服务能够从我们的 ms sql 数据库中提取数据并以 json 格式将其中继回。该服务在本地和我们网络内的家庭服务器上按预期工作。但是,我似乎无法在网络外访问该服务。

代码中是否需要其他参数来适应通过 Web 发布,或者它可能只是主机设置,与 WCF 或服务无关?

服务器是 2008 R2 和 IIS 7.5,目前托管着我们的十几个网站。我们也为该服务设置了一个端口。

这是我正在使用的 web.config 文件:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <system.web>
    <customErrors mode="Off" />
    <compilation debug="true" targetFramework="4.0">
      <assemblies>
        <add assembly="System.Data.Entity, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
      </assemblies>
    </compilation>
  </system.web>
  <system.serviceModel>
    <serviceHostingEnvironment multipleSiteBindingsEnabled="true">
    </serviceHostingEnvironment>
    <services>
      <service behaviorConfiguration="SrvcBehavior" name="Service.svc">
        <endpoint address="JSON" behaviorConfiguration="JSONEndpointBehavior" binding="webHttpBinding" bindingConfiguration="" name="RESTEP" contract="Service.Isvc" />
        <endpoint address="SOAP" binding="basicHttpBinding" name="Basic" contract="Service.Isvc" />
        <endpoint address="mex" binding="mexHttpBinding" contract="IMetadataExchange" />
      </service>
    </services>
    <behaviors>
      <endpointBehaviors>
        <behavior name="JSONEndpointBehavior">
          <webHttp />
        </behavior>
      </endpointBehaviors>
      <serviceBehaviors>
        <behavior name="SrvcBehavior">
          <serviceMetadata httpGetEnabled="true" />
          <serviceDebug />
        </behavior>
      </serviceBehaviors>
    </behaviors>
  </system.serviceModel>
  <connectionStrings>
    <add name="conn" connectionString="server=SERVER-DATABASE\SQL2005;database=myDatabase;uid=USERID;password=USERPASSWORD;" />
  </connectionStrings>
</configuration>
4

0 回答 0