gpt4 book ai didi

java - WSO2 ESB 如何对 Custom Mediator 的消息进行签名

转载 作者:太空宇宙 更新时间:2023-11-04 09:34:36 24 4
gpt4 key购买 nike

美好的一天!当我使用算法 http://www.w3.org/2001/04/xmldsig-more#rsa-sha256 签名时,我尝试使用 java 并使用政府 SDK 在自定义中介中对 XML 进行签名效果很好,

但是当我尝试使用算法 http://www.w3.org/2001/04/xmldsig-more#gost34310-gost34311 进行签名时我收到一个错误:

org.apache.xml.security.signature.XMLSignatureException: The requested algorithm http://www.w3.org/2001/04/xmldsig-more#gost34310-gost34311 does not exist. Original Message was: null
Original Exception was java.lang.NullPointerException
at org.apache.xml.security.algorithms.SignatureAlgorithm.getSignatureAlgorithmSpi(SignatureAlgorithm.java:160)
at org.apache.xml.security.algorithms.SignatureAlgorithm.<init>(SignatureAlgorithm.java:73)
at org.apache.xml.security.signature.SignedInfo.<init>(SignedInfo.java:118)
at org.apache.xml.security.signature.XMLSignature.<init>(XMLSignature.java:256)
at org.apache.xml.security.signature.XMLSignature.<init>(XMLSignature.java:185)
at kz.EsbGcvp.SignGcvp.SignXML(SignGcvp.java:113)

Java 上的代码可以很好地使用两种算法,无需在 Wso esb 中部署,但是当我从 Wso esb 调用它时,如果将使用 gost34310-gost34311,则会出现错误。

我认为版本 xmlsec-000 存在问题,我已经使用过版本 1.4.4、1.4.8、1.5.8,但没有成功。

那么我如何设置 WSO2 ESB 或了解我必须使用哪个版本或类型的 Framework.jar?我一直在使用 WSO2 ESB 版本 6.4.0

中介代码:

private static String SignXML(String xmlDoc, String keyPath, String keyPass) throws TransformerFactoryConfigurationError, Exception
{

KalkanProvider provider = new KalkanProvider();
Security.addProvider(provider);
KncaXS.loadXMLSecurity();
KeyStore ks = KeyStore.getInstance("PKCS12", provider.getName());
System.getProperty("user.dir");
ks.load(new FileInputStream(keyPath), keyPass.toCharArray());
String alias = ks.aliases().nextElement();
PrivateKey key = (PrivateKey) ks.getKey(alias, keyPass.toCharArray());
X509Certificate certificate = (X509Certificate) ks.getCertificate(alias);
String signMethod = null;
String digestMethod = null;
String sigAlgOid = certificate.getSigAlgOID();
if (sigAlgOid.equals(PKCSObjectIdentifiers.sha1WithRSAEncryption.getId())) {
signMethod = Constants.MoreAlgorithmsSpecNS + "rsa-sha1";
digestMethod = Constants.MoreAlgorithmsSpecNS + "sha1";
} else if (sigAlgOid.equals(PKCSObjectIdentifiers.sha256WithRSAEncryption.getId())) {
signMethod = Constants.MoreAlgorithmsSpecNS + "rsa-sha256";
digestMethod = XMLCipherParameters.SHA256;
} else {

signMethod = Constants.MoreAlgorithmsSpecNS + "gost34310-gost34311";
digestMethod = Constants.MoreAlgorithmsSpecNS + "gost34311";
}

DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
dbf.setNamespaceAware(true);
DocumentBuilder documentBuilder = dbf.newDocumentBuilder();
org.w3c.dom.Document doc = (org.w3c.dom.Document) documentBuilder.parse(new ByteArrayInputStream(xmlDoc.getBytes("UTF-8")));

StringWriter os = new StringWriter();
XMLSignature signature;
try {

signature = new XMLSignature(doc, "", signMethod);
if (doc.getFirstChild() != null) {
doc.getFirstChild().appendChild(signature.getElement());
Transforms transforms = new Transforms(doc);
transforms.addTransform(Transforms.TRANSFORM_ENVELOPED_SIGNATURE);
transforms.addTransform(XMLCipherParameters.N14C_XML_CMMNTS);
signature.addDocument("", transforms, digestMethod);
signature.addKeyInfo(certificate);
signature.addKeyInfo(certificate.getPublicKey());
signature.sign(key);
TransformerFactory tf = TransformerFactory.newInstance();
Transformer trans = tf.newTransformer();
trans.transform(new DOMSource(doc), new StreamResult(os));
os.close();
return os.toString().replaceAll("\\<\\?xml(.+?)\\?\\>", "").trim();
}
else
{
throw new NullPointerException("doc.getFirstChild() value is null.");
}
} catch (Exception e) {

e.printStackTrace();
throw e;
}
}

最佳答案

也许它对某人有用。因为此代码作为独立的可运行 JAR 文件工作,所以我将逻辑提取到远程可运行 JAR 文件并将其添加为 WSO2 ESB 的附加工具,因此它运行良好。也许它会对 WSO2 ESB 的性能产生不良影响......,但我没有使用 Java 和 ESB 的丰富经验。

关于java - WSO2 ESB 如何对 Custom Mediator 的消息进行签名,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56661536/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com