使用HTTP身份验证和maven-jaxb2-plugin为WSDL生成模式

Swp*_*pno 6 maven maven-jaxb2-plugin

我想使用jaxb2插件生成可从安全URL访问的WSDL(具有用户ID和密码的基本身份验证).

我应该在哪里指定凭据来生成架构?没有提供它们,我在模式生成期间得到一个401错误.

<plugin>
    <groupId>org.jvnet.jaxb2.maven2</groupId>
    <artifactId>maven-jaxb2-plugin</artifactId>
    <version>0.13.1</version>
    <executions>
        <execution>
            <goals>
                <goal>generate</goal>
            </goals>
        </execution>
    </executions>
    <configuration>
        <schemaLanguage>WSDL</schemaLanguage>
        <generatePackage>hello.wsdl</generatePackage>
        <schemas>
            <schema>
                <url>http://www.webservicex.com/stockquote.asmx?WSDL</url>
            </schema>
        </schemas>
    </configuration>
</plugin>
Run Code Online (Sandbox Code Playgroud)

Tun*_*aki 5

目前不支持下载模式的 HTTP 身份验证,并且添加它的拉取请求已被拒绝,因此不会实现。这是因为下载 WSDL 并在本地处理它总是更好,而不是在每次构建期间下载它:

  • 它使得构建高度依赖于 WSDL 的可用性,而这可能无法得到保证,并且最终可能会无缘无故地导致构建失败;
  • 构建不再是可重复的,这与 Maven 所追求的目标相反,因为您不一定控制远程 WSDL 更新的方式和时间。

一种有点古怪的方法可以使用 Apache CXF Codegen 插件来完成此操作,但我真的不推荐它。