微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

通过具有WindowsNTLM身份验证的代理访问具有基本身份验证的Web Service

如何解决通过具有WindowsNTLM身份验证的代理访问具有基本身份验证的Web Service

|| 我有一个使用基本身份验证的Web服务。我也有一个使用Web服务的Windows Forms应用程序。启动时,系统会要求用户提供凭据,然后在向服务提出任何请求时使用这些凭据。 问题是,该应用程序由公司网络中的客户端使用。他们的所有Internet通信都通过使用Windows身份验证的代理进行路由。我正在尝试将我的应用程序配置为在发出请求时正确使用该代理。 到目前为止,我的客户端应用程序的app.config中包含以下内容
<system.serviceModel>
<bindings>
  <basicHttpBinding>
    <binding name=\"mySoap\" closeTimeout=\"00:02:00\" openTimeout=\"00:02:00\"
      receiveTimeout=\"00:10:00\" sendTimeout=\"00:02:00\" allowCookies=\"false\"
      bypassproxyOnLocal=\"true\" hostNameComparisonMode=\"StrongWildcard\"
      maxBufferSize=\"65536\" maxBufferPoolSize=\"524288\" maxReceivedMessageSize=\"65536\"
      messageEncoding=\"Text\" textEncoding=\"utf-8\" transferMode=\"Buffered\"
      useDefaultWebProxy=\"true\">
      <readerQuotas maxDepth=\"32\" maxStringContentLength=\"8192\" maxArrayLength=\"16384\"
        maxBytesPerRead=\"4096\" maxNaMetableCharCount=\"16384\" />
      <security mode=\"TransportCredentialOnly\">
        <transport clientCredentialType=\"Basic\" proxyCredentialType=\"Windows\"
          realm=\"myrealm\" />
        <message clientCredentialType=\"UserName\" algorithmSuite=\"Default\" />
      </security>
    </binding>
  </basicHttpBinding>
</bindings>
<client>
  <endpoint address=\"http://www.myservice.com/service.asmx\"
    binding=\"basicHttpBinding\" bindingConfiguration=\"mySoap\"
    contract=\"MyPublicService.mySoap\" name=\"mySoap\" />
</client>
</system.serviceModel>
<system.net>
   <defaultProxy useDefaultCredentials=\"true\" />
</system.net>
您认为这行得通吗?我无法轻松对其进行测试。应用程序和服务已在没有代理的情况下进行了测试,它们可以正常工作,我只需要正确配置代理即可。 从理论上讲,此配置将确保所有请求都使用认代理,该认代理使用Windows身份验证。它将使用认凭据,该凭据将在其Windows设置中设置。然后,它将使用用户提供的凭据对Web服务执行基本身份验证。 更新 客户端尝试了此操作,并返回了400错误
System.ServiceModel.ProtocolException: The Remote Server returned an unexpected response: (400) Bad Request. ---> System.Net.WebException: The Remote Server returned an error: (400) Bad Request.
    at System.Net.HttpWebRequest.GetResponse()
    at System.ServiceModel.Channels.HttpChannelFactory.HttpRequestChannel.HttpChannelRequest.WaitForReply(TimeSpan timeout)
    --- End of inner exception stack trace ---

Server stack trace: 
    at System.ServiceModel.Channels.HttpChannelUtilities.ValidateRequestReplyResponse(HttpWebRequest request,HttpWebResponse response,HttpChannelFactory factory,WebException responseException,ChannelBinding channelBinding)
    at System.ServiceModel.Channels.HttpChannelFactory.HttpRequestChannel.HttpChannelRequest.WaitForReply(TimeSpan timeout)
    at System.ServiceModel.Channels.RequestChannel.Request(Message message,TimeSpan timeout)
    at System.ServiceModel.dispatcher.RequestChannelBinder.Request(Message message,TimeSpan timeout)
    at System.ServiceModel.Channels.ServiceChannel.Call(String action,Boolean oneway,ProxyOperationRuntime operation,Object[] ins,Object[] outs,TimeSpan timeout)
    at System.ServiceModel.Channels.ServiceChannelProxy.InvokeService(IMethodCallMessage methodCall,ProxyOperationRuntime operation)
    at System.ServiceModel.Channels.ServiceChannelProxy.Invoke(IMessage message)
当我在没有代理的机器上尝试时,它工作正常。知道为什么吗?     

解决方法

        400错误与问题无关。 NTLM代理的授权似乎与此配置一起使用。 更新: 我将服务器的安全配置更改为也接受Digest。然后,在设置用户名和密码时必须对代码进行少量更改,然后它才能开始工作。看起来绑定存在基本身份验证问题。     

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。