我是 xml 加密的新手,我想加密 .net 中的 xml 文件并使用 x509 证书解密 java 中的加密文件。这可以做到吗?
问问题
2366 次
2 回答
1
是的,这是完全可能的。您可以使用某种编程语言使用任何众所周知的算法加密文件,并使用另一种编程语言对其进行解密。对于在 c# 中使用 x509 进行加密,请查看:http: //msdn.microsoft.com/en-us/library/ms229744.aspx
于 2012-04-24T12:38:03.027 回答
0
请看下面的例子
public class CryptoUtil {
public static byte[] rsaEncrypt(byte[] publicKey, byte[] data) throws IOException, InvalidKeySpecException,
NoSuchAlgorithmException, NoSuchPaddingException, InvalidKeyException {
X509EncodedKeySpec publicKeySpec = new X509EncodedKeySpec(publicKey);
KeyFactory kf = KeyFactory.getInstance("RSA");
PublicKey pk = kf.generatePublic(publicKeySpec);
Cipher rsa = Cipher.getInstance("RSA");
rsa.init(Cipher.ENCRYPT_MODE, pk);
ByteArrayOutputStream byteOutputStream = new ByteArrayOutputStream();
CipherOutputStream os = new CipherOutputStream(byteOutputStream, rsa);
os.write(data);
os.flush();
os.close();
return byteOutputStream.toByteArray();
}
public static byte[] rsaDecrypt(byte[] privateKey, byte[] data) throws IOException, InvalidKeySpecException,
NoSuchAlgorithmException, NoSuchPaddingException, InvalidKeyException {
PKCS8EncodedKeySpec privateKeySpec = new PKCS8EncodedKeySpec(privateKey);
KeyFactory kf = KeyFactory.getInstance("RSA");
PrivateKey pk = kf.generatePrivate(privateKeySpec);
Cipher rsa = Cipher.getInstance("RSA");
rsa.init(Cipher.DECRYPT_MODE, pk);
ByteArrayInputStream byteInputStream = new ByteArrayInputStream(data);
InputStream is = new CipherInputStream(byteInputStream, rsa);
byte[] message = IOUtils.toByteArray(is);
is.close();
return message;
}
}
于 2012-04-24T13:51:39.110 回答