首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用Bouncy Castle (Java语言)和GPG4Win加密时文件大小不同

使用Bouncy Castle (Java语言)和GPG4Win加密时文件大小不同
EN

Stack Overflow用户
提问于 2014-08-01 02:12:37
回答 1查看 378关注 0票数 1

这就是问题所在:我使用Bouncy Castle (Java)库来加密文件,但我得到的加密文件的大小比我使用其他实用程序(如GPG4Win、FileAssurity)时要大得多。与我的代码生成的文件相比,这些实用程序生成的加密文件非常小。

我想知道当使用RSA公钥和DSA公钥时,是否有不同的加密方法。

其他信息:

公钥证书类型:2,047位RSA

我用来加密数据文件的代码(文件被读取并作为字节数组传递):

代码语言:javascript
复制
private static byte[] encrypt(byte[] clearData, PGPPublicKey encKey, boolean withIntegrityCheck, boolean armor) 
    throws IOException, PGPException, NoSuchProviderException {

    ByteArrayOutputStream encOut = new ByteArrayOutputStream();

    OutputStream out = encOut;
    if(armor) {
        out = new ArmoredOutputStream(out);
    }

    ByteArrayOutputStream bOut = new ByteArrayOutputStream();

    PGPLiteralDataGenerator lData = new PGPLiteralDataGenerator();

    OutputStream pOut = lData.open(bOut/*cos*/, // the compressed output stream
        PGPLiteralData.BINARY, PGPLiteralData.CONSOLE, // "filename" to store (if provided)
        clearData.length, // length of clear data
        new Date() // current time
        );
    pOut.write(clearData);

    PGPEncryptedDataGenerator cPk = new PGPEncryptedDataGenerator(PGPEncryptedData.CAST5, withIntegrityCheck, new SecureRandom(), C_BC_PROVIDER_NAME);
    cPk.addMethod(encKey);

    byte[] bytes = bOut.toByteArray();
    bOut.close();

    OutputStream cOut = cPk.open(out, bytes.length);

    cOut.write(bytes); 

    cOut.close();
    out.close();
    return encOut.toByteArray();
} // encrypt
EN

回答 1

Stack Overflow用户

发布于 2014-08-01 08:10:28

尝试:

代码语言:javascript
复制
import org.bouncycastle.openpgp.PGPCompressedDataGenerator;
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25066106

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档