16

我尝试使用CXF User Guide让它工作,但我没有运气。

我正在尝试使用 java 代码调用 Web 服务。

4

3 回答 3

25

JAX-WS 规范涵盖了这一点。基本上,将用户名/密码设置为请求上下文的属性:

((BindingProvider)proxy).getRequestContext().put(
    BindingProvider.USERNAME_PROPERTY, "joe");
((BindingProvider)proxy).getRequestContext().put(
    BindingProvider.PASSWORD_PROPERTY, "pswd");

运行时将它们放入 HTTP 标头中。

于 2009-04-01T16:00:27.873 回答
8

您可以提供自己的身份验证器。如果 WDSL 本身受到基本 HTTP 身份验证的保护,那么它将起作用。

@WebServiceRef(wsdlLocation = "https://laka/sito?wsdl")
static XxxService service;

public static void main(String[] args) {

    Authenticator.setDefault(new Authenticator() {
        @Override
        protected PasswordAuthentication getPasswordAuthentication() {
            return new PasswordAuthentication("user", "password".toCharArray());
        }
    });

    service = new XxxService();
    Xxx port = service.getXxxPort();

    // invoke webservice and print response
    XxxResponse resp = port.foo();
    System.out.println(resp.toString());

}
于 2011-10-28T12:27:50.590 回答
6

有一个更好的方法:

从 WSDL 生成 Java 时,添加选项“-exsh true”:

wsdl2java -exsh true -p edu.sharif.ce http://wsdl.ir/WebServices/WebService.asmx?WSDL

并在使用时添加 UserCredential:

UserCredentials user = new UserCredentials();
user.setUserid("user");
user.setPassword("pass");

ResearchWebService_Service service = new ResearchWebService_Service();
ResearchWebService port = service.getResearchWebService();
port.addNewProject(newProject, user);
于 2011-02-19T11:51:28.830 回答