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

Axis1.4 在weblogic9.2中报 (401)Unauthorized 的处理

发布时间:2020-12-17 02:05:12 所属栏目:安全 来源:网络整理
导读:WebService server 在tomcat上部署,client在Weblogic9.2中部署,在使用安全方式调用的时候,报错: (401)Unauthorized at org.apache.axis.transport.http.HTTPSender.readFromSocket(HTTPSender.java:744) 如果server 和client 都在 tomcat,则不存在问题

WebService server 在tomcat上部署,client在Weblogic9.2中部署,在使用安全方式调用的时候,报错:
(401)Unauthorized at org.apache.axis.transport.http.HTTPSender.readFromSocket(HTTPSender.java:744)

如果server 和client 都在 tomcat,则不存在问题。

webService 的 client 代码是有 WDSL2JAVA 自动产生的代码。

经过多方跟踪,发现在client构造的java.net.URL 实例的 toString() 在tomcat下输出如下:
http://7564945504235898643:123@192.168.0.175:9080/tunnel-web/secure/axis/Plat_UserService

在weblogic下输出如下:
http://192.168.0.175:9080/tunnel-web/secure/axis/Plat_UserService

多方查找,也找不到原因。后来通过手工创建call,可以调用,代码如下:


然后下载axis1.4的源代码,对源代码做中org.apache.axis.wsdl.toJava.JavaStubWriter 类的产生createCall的代码做如下修正:



使得在url中找不到用户信息的时候,通过userInfo中获取用户信息。

?

修改后产生的Stub代码如下:


JavaStubWriter.java

(编辑:李大同)

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

    推荐文章
      热点阅读