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