JAVA WSIMPORT生成WEBSERVICE客户端401认证过程图解

网友投稿 445 2022-11-18


JAVA WSIMPORT生成WEBSERVICE客户端401认证过程图解

概述

wsimport是jdk自带的命令,可以根据wsdl文档生成客户端中间代码,基于生成的代码编写客户端,可以省很多麻烦。

先看两张截图:

使用浏http://览器打开webservice出现的界面:

使用wsimport生成webservice客户端出现401错误:

需用到的命令参数如下:

1. -d 在指定的目录生成class文件

2. -p 指定生成文件的包结构

3. -Xauthfile 在格式文件进行授权信息

4. -keep 在生成class文件,或者jar包时,同时保留java源文件

第一步 创建wsimport生成ws命令行

wsimport -d D:\JAVA\wrokspace\您的项目\src -p com.xx.web -Xauthfile D:\JAVA\wrokspace\您的项目\authfile.txt -keep http://xxxx:9000/Service.asmx?wsdl

1、通过-d命令指定您的java项目src路径

2、通过-p命令指定需生成包结构(指定之后会自动生成)

3、通过-Xauthfile命令指定访问带有401认证的webservice授权iKPMkLnIaI文件(文件路径或文件名可以随意更改 特别简单,请放心)。

4、通过-keep命令指定webservice路径

第二步 创建授权文件(authfile.txt)

http://test:123456@192.168.110.21:9000/Service.asmx?wsdl

第三步 在MyEclipse工具中找到对应的项目右键刷新

备注:生成完成之后项目可能会出现错误,将错误稍作修改至没有异常即可。

第四步 尝试调用webservice接口函数并运行项目

出现了 Server returned HTTP response code: 401异常,虽然ws成功导入到项目中了但是项目访问接口的时候没有进行身份认证导致出现该异常。我已经在论坛里面找到这个方法的解决方案,

原链接(参考#10):http://bbs.csdn.net/topics/370023850

import java.net.Authenticator;

import java.net.PasswordAuthentication;

public class MyAuthenticator extends Authenticator {

protected PasswordAuthentication getPasswordAuthentication() {

return new PasswordAuthentication("用户名", "密码".toCharArray());

}

}

调用的时候只需要在调用接口之前调用执行该方法即可:

Authenticator.setDefault(new MyAuthenticator());

终于搞定了

直接用HttpURLConnection是不行的,这个默认只是80端口。

最后是用 Java.Net的Authenticator类 把Username和Password直接投过去(他之后对位流的处理遵守http的basic身份验证机制)

代码很短:

import java.net.Authenticator;

import java.net.PasswordAuthentication;

class MyAuthenticator extends Authenticator {

protected PasswordAuthentication getPasswordAuthentication() {

return new PasswordAuthentication ( "username ", "password ");

}

}

在程序中调用:

Authenticator.setDefault (new MyAuthenticator ());

希望对以后碰到这个问题的人有用


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Java中将File转化为MultipartFile的操作
下一篇:Java 将List中的实体类按照某个字段进行分组并存放至Map中操作
相关文章

 发表评论

暂时没有评论,来抢沙发吧~