java – preemptive authentication为什么
为什么需要抢占式身份验证?
System.setProperty(“httpclient.authentication.preemptive”,“true”); 我在java中编写了Web服务访问客户端程序.我们在调用对象中设置用户名和密码的位置,并且工作正常. 最近,我们的服务提供商在他们身边做了一些更改,之后他们没有收到用户名& Web服务调用中的密码,因为他们没有收到用户名& passwod所以我们无法连接到他们的(提供商)服务. 然后我做了谷歌搜索,发现了抢先认证. 当我们删除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> (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |