javax.xml.soap.SOAPException : java. security.ProviderException:无法派生 key

标签 java soap ws-security

我正在向端点发送 SOAP 请求。我正在使用Axis2。下面的代码在我的环境中运行良好,但在 Linux 设置上出现异常。 Linux 设置在客户端和服务器之间使用消息代理。

public SOAPMessage createSOAPMessage(SOAPMessage request, String endpoint) throws Exception {


    ConfigurationContext configurationContext = getConfigurationContext();

    // initialize URL
    URL url;
    try {
        url = new URL(endpoint);
    } catch (MalformedURLException e) {
        throw new Exception("Invalid Endpoint: " + endpoint + ", " + e.getMessage(), e);
    }

    // initialize and set Options
    Options options = new Options();
    options.setTo(new EndpointReference(url.toString()));

    try {
        serviceClient = new ServiceClient(configurationContext, null);
        operationClient = serviceClient.createClient(ServiceClient.ANON_OUT_IN_OP);
    } catch (AxisFault e) {
        throw new SOAPException(e.getMessage(), e);
    }

    options.setProperty(Constants.Configuration.CHARACTER_SET_ENCODING, 
            request.getProperty(SOAPMessage.CHARACTER_SET_ENCODING));
    operationClient.setOptions(options);
    MessageContext requestMsgCtx = new MessageContext();
    SOAPEnvelope envelope = SAAJUtil.toOMSOAPEnvelope(request.getSOAPPart().getDocumentElement());
    requestMsgCtx.setProperty(HTTPConstants.CHUNKED, "false");

    Map<String,String> httpHeaders = null;
    for (Iterator it = request.getMimeHeaders().getAllHeaders(); it.hasNext(); ) {
        MimeHeader header = (MimeHeader)it.next();
        String name = header.getName().toLowerCase();
        if (name.equals("soapaction")) {
            requestMsgCtx.setSoapAction(header.getValue());
        } else {
            if (httpHeaders == null) {
                httpHeaders = new HashMap<String,String>();
            }
            httpHeaders.put(header.getName(), header.getValue());
        }
    }

    if (httpHeaders != null) {
        requestMsgCtx.setProperty(HTTPConstants.HTTP_HEADERS, httpHeaders);
    }

    MessageContext responseMsgCtx;

    try {
        requestMsgCtx.setEnvelope(envelope);
        operationClient.addMessageContext(requestMsgCtx);
        operationClient.execute(true);
        responseMsgCtx = operationClient.getMessageContext(WSDLConstants.MESSAGE_LABEL_IN_VALUE);
    } catch (AxisFault ex) {
        throw new SOAPException(ex.getMessage(), ex);
    }

    return getSOAPMessage(responseMsgCtx.getEnvelope());
}

错误是:

javax.xml.soap.SOAPException: java.security.ProviderException: Could not derive key

这两个环境都使用 WS-security 并使用 Java 1.8u51。我仔细检查了证书,看起来不错。

请指教。

最佳答案

该问题是由于 Linux 计算机上的 JVM 中加载了 Bouncy CaSTLe jar 造成的。充气城堡 jar 是我们项目的一部分。我们使用下面的代码行列出了 JVM 中用于 Linux 设置的证券库,bouncy caSTLe 就是其中之一。我们从环境中删除了 jar,它就开始工作了。请注意Linux机器上的java版本是1.8u51。

try {
        Provider pArray[] = Security.getProviders();
        if (log.isDebugEnabled()) {
            log.debug("Availble number of Providers are -> " + pArray.length);
        }

        for (int i = 0; i < pArray.length; i++) {
            Provider p = pArray[i];
            if (log.isDebugEnabled()) {
                log.debug(p + ", Info-> " + p.getInfo() + ", Class -> " + p.getClass().getName());
            }
            for (Enumeration e = p.keys(); e.hasMoreElements();) {
                if (log.isDebugEnabled()) {
                    log.debug("\t" + e.nextElement());
                }
            }
        }
    } catch (Exception e) {
        if (log.isErrorEnabled()) {
            log.error("List all security provider failed. " + e);
        }
    }

我们可以尝试将 java 升级到最新的 Java 8 版本,而不是删除 jar。

关于javax.xml.soap.SOAPException : java. security.ProviderException:无法派生 key ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51932932/

相关文章:

java - 当您不知道输入流的类型时,如何将其保存到变量中?

java - 线程应用程序将重复行写入日志文件

java - 通过单独的锁保证锁定每个值

node.js - 使用 Node.JS Node SOAP 使用 Dynamics NAV Web 服务

java - Web 服务-用户名 token -根据安全策略验证消息时出错错误代码 :1000

java - 在 Eclipse 中,如何访问另一个项目中的资源?

java - SOAP Java 1.4.2

php - 在 php 中解析 SOAP 响应

wcf - 使用 .Net Core 3.1 签署 Soap 1.1 主体

java - 如何使用 Pkcs12 keystore 证书使用 WSDL Web 服务