如何配置WCF REST以使用SSL?

时间:2012-12-11 22:29:41

标签: wcf rest ssl

我有一个很好的WCF REST-ful JSON服务。当我尝试将其用于HTTPS时,问题就出现了。 Web.config如下:

 <system.serviceModel>
    <bindings>
      <webHttpBinding>
        <binding name="StreamedRequestWebBinding" bypassProxyOnLocal="true" useDefaultWebProxy="false" hostNameComparisonMode="WeakWildcard" sendTimeout="10:15:00" openTimeout="10:15:00" receiveTimeout="10:15:00" maxReceivedMessageSize="2147483647" maxBufferSize="2147483647" maxBufferPoolSize="2147483647" transferMode="StreamedRequest">
          <security mode="Transport">
            <transport clientCredentialType = "None"  />
          </security>
          <readerQuotas maxArrayLength="2147483647" maxStringContentLength="2147483647" />
        </binding>
      </webHttpBinding>
    </bindings>
    <services>
      <service name="WcfRESTFullJSON.Service1" behaviorConfiguration="ServiceBehaviour">
        <endpoint address="" binding="webHttpBinding" bindingConfiguration="StreamedRequestWebBinding" contract="WcfRESTFullJSON.IService1" />
        <endpoint address="mex" binding="mexHttpsBinding" contract="IMetadataExchange" />
      </service>
    </services>
    <behaviors>
      <serviceBehaviors>
        <behavior name="ServiceBehaviour">
          <serviceMetadata httpsGetEnabled="true" />
          <serviceDebug includeExceptionDetailInFaults="false" />
        </behavior>
      </serviceBehaviors>
      <endpointBehaviors>
        <behavior name="web">
          <!--Him-->
          <webHttp automaticFormatSelectionEnabled="true" />
        </behavior>
      </endpointBehaviors>
    </behaviors>
    <serviceHostingEnvironment multipleSiteBindingsEnabled="true" aspNetCompatibilityEnabled="true" />
  </system.serviceModel>

我在IIS上配置了自制证书。 在客户端我有:

WebClient WC;
...
WC.UploadData(URL, "POST", asciiBytes);

我们得到了什么:

The remote server returned an error: (500) Internal Server Error.

可能是什么问题?

3 个答案:

答案 0 :(得分:1)

问题已解决。它是以下行中对端点行为的缺失引用 ...端点 behaviorConfiguration =“web” address =“”binding =“webHttpBinding”bindingConfiguration =“StreamedRequestWebBinding”contract =“WcfRESTFullJSON.IService1”... 在下面的Web.config中。谢谢你的帮助朋友们!最终在文章Implementing 5 important principles of REST using WCF Services

中找到了解决方案
    <services>
  <service name="WcfRESTFullJSON.Service1" behaviorConfiguration="ServiceBehaviour">
    <endpoint  behaviorConfiguration="web" address="" binding="webHttpBinding" bindingConfiguration="StreamedRequestWebBinding" contract="WcfRESTFullJSON.IService1" />
    <endpoint address="mex" binding="mexHttpsBinding" contract="IMetadataExchange" />
  </service>
</services>
<behaviors>
  <serviceBehaviors>
    <behavior name="ServiceBehaviour">
      <serviceMetadata httpsGetEnabled="true" />
      <serviceDebug includeExceptionDetailInFaults="false" />
    </behavior>
  </serviceBehaviors>
  <endpointBehaviors>
    <behavior name="web">
      <!--Him-->
      <webHttp automaticFormatSelectionEnabled="true" />
    </behavior>
  </endpointBehaviors>

答案 1 :(得分:0)

由于SSL是HTTP下的协议,因此在web.config中通常没有额外的配置(只有新的绑定)。如果您使用SSL,则更改的另一件事是端口...您可能需要更新防火墙或检查您的请求是否已发送到正确的端口。

答案 2 :(得分:0)

 See Complete config file
<configuration>   <system.web>
        <compilation debug="true" targetFramework="4.0" />
        <webServices>
          <protocols>
            <add name="HttpsGet"/>
            <add name="HttpsPost"/>
          </protocols>
        </webServices>   </system.web>   <system.serviceModel>
        <services>
          <service  name="RESTTEST.RestTestService" behaviorConfiguration="ServiceBehavior">

            <endpoint address="" binding="webHttpBinding" 
                      contract="RESTTEST.IRestTestService" 
                      bindingConfiguration="sslBinding"
                      behaviorConfiguration="web"
                      ></endpoint>
            <endpoint address="mex"
                  binding="mexHttpsBinding"
                  contract="IMetadataExchange" />
          </service>
        </services>
        <behaviors>
          <serviceBehaviors>
            <behavior name="ServiceBehavior">
              <!-- To avoid disclosing metadata information, set the value below to false and remove the metadata endpoint above before
    deployment -->
              <serviceMetadata httpGetEnabled="true" httpsGetEnabled="true"/>
              <!-- To receive exception details in faults for debugging purposes, set the value below to true.  Set to false before
    deployment to avoid disclosing exception information -->
              <serviceDebug includeExceptionDetailInFaults="true"/>
            </behavior>
          </serviceBehaviors>
          <endpointBehaviors>
            <behavior name="web">
              <webHttp/>
            </behavior>
          </endpointBehaviors>
        </behaviors>
        <bindings>
          <webHttpBinding>
            <binding name="sslBinding" crossDomainScriptAccessEnabled="true">
              <security mode="Transport">
              </security>
            </binding>
          </webHttpBinding>    
          </bindings>
        <serviceHostingEnvironment aspNetCompatibilityEnabled="true" multipleSiteBindingsEnabled="false">
        </serviceHostingEnvironment>
        <standardEndpoints>
          <webHttpEndpoint>
            <standardEndpoint crossDomainScriptAccessEnabled="true"></standardEndpoint>
          </webHttpEndpoint>
          <webScriptEndpoint>
            <standardEndpoint name="" crossDomainScriptAccessEnabled="true" />
          </webScriptEndpoint>
        </standardEndpoints>   </system.serviceModel>   <system.webServer>
        <modules runAllManagedModulesForAllRequests="true" />
        <httpProtocol>
          <customHeaders>
            <add name="Access-Control-Allow-Origin" value="*" />
            <add name="Access-Control-Allow-Headers" value="Content-Type" />
          </customHeaders>
        </httpProtocol>   </system.webServer> </configuration>