Как я могу использовать веб-службу, защищенную базовой аутентификацией HTTP, с использованием инфраструктуры CXF?

Я попытался заставить его работать с помощью CXF User Guide, но мне не повезло.

Я пытаюсь вызвать веб-службу с помощью java-кода.

Ответ 1

Это описано в спецификации JAX-WS. В принципе, укажите имя пользователя/пароль как свойства в контексте запроса:

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

Среда выполнения помещает их в HTTP-заголовок.

Ответ 2

Вы можете предоставить свой собственный аутентификатор. Таким образом, он будет работать, если сам 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());

}

Ответ 3

Существует намного лучший способ:

при генерации Java из WSDL, добавьте опцию "-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);