4

我正在尝试在 WCF 服务中检索已登录的 Windows 用户。我试过使用 ServiceSecurityContext 但 Current 始终为空。

ServiceSecurityContext.Current.WindowsIdentity.Name

我也尝试过使用 OperationContext。在这种情况下,ServiceSecurityContext 返回为 null。

OperationContext.Current.ServiceSecurityContext.PrimaryIdentity.Name

这是我的 web.config:

 <bindings>
  <basicHttpBinding>
    <binding name="HttpWindowsBinding">
      <security mode="TransportCredentialOnly">
        <transport clientCredentialType="Windows" />
      </security>
    </binding>
  </basicHttpBinding>
</bindings> 

<authentication mode="Windows"/> 

谁能看到我做错了什么?

更新:我放弃了尝试让 ServiceSecurityContext 工作。最后,我通过设置aspNetCompatibilityEnabled="true"找到了解决方案。

<serviceHostingEnvironment multipleSiteBindingsEnabled="true" aspNetCompatibilityEnabled="true" />

我还在我的服务类中添加了以下属性:

[System.ServiceModel.Activation.AspNetCompatibilityRequirements(RequirementsMode = System.ServiceModel.Activation.AspNetCompatibilityRequirementsMode.Required)]

这使我可以使用以下方法检索 Windows 用户:

HttpContext.Current.User.Identity.Name
4

1 回答 1

1

我得到了同样的错误并设法解决了它,你不需要使用 basichttpBinding。下面是我的配置:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <system.serviceModel>
      <bindings>
        <wsHttpBinding>
          <binding name="MSADC">
            <security mode ="Message">
              <transport clientCredentialType="Windows" />
              <message establishSecurityContext="true" />
            </security>
          </binding>
        </wsHttpBinding>
      </bindings>
        <behaviors>
            <serviceBehaviors>
                <behavior name="">
                    <serviceMetadata httpGetEnabled="true" httpsGetEnabled="true" />
                    <serviceDebug includeExceptionDetailInFaults="false" />
                </behavior>
            </serviceBehaviors>
        </behaviors>
        <services>
            <service name="WCFAuthentication.WCFAuthentication">
                <endpoint bindingConfiguration="MSADC" address="" binding="wsHttpBinding" contract="WCFAuthentication.IWCFAuthentication">
                    <identity>
                        <dns value="localhost" />
                    </identity>
                </endpoint>
                <endpoint address="mex" binding="mexHttpBinding" contract="IMetadataExchange" />
                <host>
                    <baseAddresses>
                        <add baseAddress="http://localhost:8088" />
                    </baseAddresses>
                </host>
            </service>
        </services>
    </system.serviceModel>
  <appSettings>
    <add key="wcf:disableOperationContextAsyncFlow" value="false" />
  </appSettings>
</configuration>
于 2018-10-02T15:49:30.137 回答