когда я перехожу на свою страницу WCF svc https://mywebstie.project.com/myproject/myuploadservice.svc, я нажимаю svc, как и ожидалось, но URL-адрес svcutil, который он предоставляет, использует фактическое имя сервера; например, а не URL-адрес mywebsite.project.com.
Когда я перехожу по предоставленной ссылке на файл WSDL, только текст https://mywebstie.project.com/myproject/myuploadservice.svc/SQLMembershipProvider отображается в браузере. URL-адрес в браузере фактически использует имя сервера вместо mywebstie.project.com.
Содержимое WSDL XML не отображается.
В чем может быть проблема? Я не менял конфигурацию клиента или сервера, но моя служба не работает.
Ошибка при получении HTTP-ответа на https://mywebstie.project.com/myproject/myuploadservice.svc/SqlMembershipProvider. Это может быть связано с тем, что привязка конечной точки службы не использует протокол HTTP. Это также может быть связано с прерыванием контекста HTTP-запроса сервером (возможно, из-за завершения работы службы). См. Журналы сервера для более подробной информации.
Вот моя конфигурация сервера
<system.serviceModel>
<behaviors>
<serviceBehaviors>
<behavior name="MembershipBehaviour">
<serviceMetadata httpsGetEnabled="true" />
<serviceCredentials>
<serviceCertificate findValue="44 44 44 44 44 44 44 44 44 44 44 44 44 44 44 44 44 44 44 44"
storeLocation="LocalMachine" storeName="My" x509FindType="FindByThumbprint" />
<userNameAuthentication userNamePasswordValidationMode="MembershipProvider"
membershipProviderName="SqlMembershipProvider" />
</serviceCredentials>
</behavior>
</serviceBehaviors>
</behaviors>
<bindings>
<wsHttpBinding>
<binding name="SqlMembershipProvider">
<security mode="TransportWithMessageCredential">
<message clientCredentialType="UserName" />
</security>
</binding>
</wsHttpBinding>
<mexHttpsBinding>
<binding name="mex" />
</mexHttpsBinding>
</bindings>
<services>
<service behaviorConfiguration="MembershipBehaviour" name="Test.Web.Services.MyUploadService">
<endpoint name="SqlMembershipProvider"
address="https://mywebstie.project.com/myproject/myuploadservice.svc/SQLMembershipProvider"
binding="wsHttpBinding" bindingConfiguration="SqlMembershipProvider"
contract="Test.Web.Services.IMyUploadService" />
<endpoint address="mex" binding="mexHttpsBinding" bindingConfiguration="mex" name="mex" contract="IMetadataExchange" />
</service>
</services>
</system.serviceModel>
Клиент выглядит так:
<system.serviceModel>
<bindings>
<wsHttpBinding>
<binding name="SqlMembershipProvider" closeTimeout="00:01:00"
openTimeout="00:01:00" receiveTimeout="00:10:00" sendTimeout="00:01:00"
bypassProxyOnLocal="false" transactionFlow="false" hostNameComparisonMode="StrongWildcard"
maxBufferPoolSize="524288" maxReceivedMessageSize="65536"
messageEncoding="Text" textEncoding="utf-8" useDefaultWebProxy="true"
allowCookies="false">
<readerQuotas maxDepth="32" maxStringContentLength="8192" maxArrayLength="16384"
maxBytesPerRead="4096" maxNameTableCharCount="16384" />
<reliableSession ordered="true" inactivityTimeout="00:10:00"
enabled="false" />
<security mode="TransportWithMessageCredential">
<transport clientCredentialType="Certificate" proxyCredentialType="None"
realm="" />
<message clientCredentialType="UserName" negotiateServiceCredential="true"
algorithmSuite="Default" establishSecurityContext="true" />
</security>
</binding>
</wsHttpBinding>
</bindings>
<client>
<endpoint address="https://mywebstie.project.com/myproject/myuploadservice.svc/SQLMembershipProvider"
binding="wsHttpBinding" bindingConfiguration="SqlMembershipProvider"
contract="IHoldingFileUploadService" name="SqlMembershipProvider">
<identity>
<certificate encodedValue="SomeEncodedValue" />
</identity>
</endpoint>
</client>
</system.serviceModel>