加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

java – preemptive authentication为什么

发布时间:2020-12-15 02:28:13 所属栏目:Java 来源:网络整理
导读:为什么需要抢占式身份验证? System.setProperty(“httpclient.authentication.preemptive”,“true”); 我在java中编写了Web服务访问客户端程序.我们在调用对象中设置用户名和密码的位置,并且工作正常. 最近,我们的服务提供商在他们身边做了一些更改,之后他
为什么需要抢占式身份验证?

System.setProperty(“httpclient.authentication.preemptive”,“true”);

我在java中编写了Web服务访问客户端程序.我们在调用对象中设置用户名和密码的位置,并且工作正常.

最近,我们的服务提供商在他们身边做了一些更改,之后他们没有收到用户名& Web服务调用中的密码,因为他们没有收到用户名& passwod所以我们无法连接到他们的(提供商)服务.

然后我做了谷歌搜索,发现了抢先认证.
在调用Web服务时,我们将“httpclient.authentication.preemptive”设置为“true” – System.setProperty(“httpclient.authentication.preemptive”,“true”);,那么我们就能收到服务提供商的回复.

当我们删除System.setProperty(“httpclient.authentication.preemptive”,“true”);然后我们无法连接到他们的服务.

解决方法

当我们在client-config.wsdd文件中更改transport pivot =“java:org.apache.axis.transport.http.HTTPSender”以传输pivot =“java:org.apache.axis.transport.http.CommonsHTTPSender”时.无需设置System.setProperty(“httpclient.authentication.preemptive”,“true”)即可解决此问题; .

client-config.wsdd –

<?xml version="1.0" encoding="UTF-8"?> 
<deployment 
    name="commonsHTTPConfig" 
    xmlns="http://xml.apache.org/axis/wsdd/" 
    xmlns:java="http://xml.apache.org/axis/wsdd/providers/java">

  <!-- use CommonsHTTPSender instead of the default HTTPSender -->
  <transport name="http" pivot="java:org.apache.axis.transport.http.CommonsHTTPSender" />  

  <transport name="local" pivot = "java:org.apache.axis.transport.local.LocalSender" /> 
  <transport name="java" pivot="java:org.apache.axis.transport.java.JavaSender" /> 
</deployment>

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读