Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/385.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java PGP图书馆赢得';t加密base64字符串_Java_Encryption_Java Io_Pgp - Fatal编程技术网

Java PGP图书馆赢得';t加密base64字符串

Java PGP图书馆赢得';t加密base64字符串,java,encryption,java-io,pgp,Java,Encryption,Java Io,Pgp,我有一个PGP Encryption/Decryption的实现作为类助手,但是我在用base64字符串加密有效负载时遇到了问题 下面是我尝试加密的有效负载示例: { "superagentCode": "AB0003", "agentCode": "004FJM01023", "bankCode": "000015", "requestId": "000001201910240846150999883774", "bankVerificationNumb

我有一个PGP Encryption/Decryption的实现作为类助手,但是我在用base64字符串加密有效负载时遇到了问题

下面是我尝试加密的有效负载示例:

{
    "superagentCode": "AB0003",
    "agentCode": "004FJM01023",
    "bankCode": "000015",
    "requestId": "000001201910240846150999883774",
    "bankVerificationNumber": "22123456789",
    "firstName": "Samuel",
    "middleName": "John",
    "lastName": "Smith",
    "gender": "Male",
    "dateOfBirth": "1978-Oct-20",
    "houseNumber": "10B",
    "streetName": "Almond street",
    "city": "Igando",
    "lgaCode": "502",
    "emailAddress": "aa@gmail.com",
    "phoneNumber": "08012345678",
    "customerImage": "",
    "customerSignature": "",
    "accountOpeningBalance": 1000
}
下面是我的加密功能:

public String encrypt(String text, String publicKeyLocation) {
    logger.info(" -|- step 1 ======== ");
    try {
        PGPLib pgp = new PGPLib();
        boolean armor = true;
        boolean withIntegrityCheck = false;
        logger.info(" -|- step  2 ======== ");
        PipedInputStream pin = new PipedInputStream();
        OutputStream o = new PipedOutputStream(pin);
        InputStream is = new ByteArrayInputStream(text.getBytes("UTF-8"));
        logger.info(" -|- step 3 ======== ");
        if (publicKeyFile == null) {
            publicKeyFile = new File(publicKeyLocation);
        }
        logger.info(" -|- step 4 ======== ");
        InputStream publicKeyStream = new FileInputStream(publicKeyFile);
        logger.info(" -|- step 5 ======== ");
        pgp.encryptStream(is, publicKeyLocation, publicKeyStream, o, armor,
                withIntegrityCheck);
        logger.info(" -|- step 6 ======== ");
        do {
            logger.info(" -|-  pin.available(): " + pin.available());
        } while (pin.available() <= 0);
        logger.info(" -|- starting encryption 7 ======== ");
        byte[] body = new byte[pin.available()];
        int numberRead = pin.read(body);
        logger.info(" -|- SSModuleClient :: pickMessage :: numberRead: "
                + numberRead);

        return byte2hex(body);
    } catch (Exception ex) {
        logger.info(" -|- SSModule :: MessageProcessor :: encrypt () :: Error Occurred ..."
                + ex.getMessage());
        logger.info("SSModule", ex);
    }

    return "";
}
公共字符串加密(字符串文本、字符串公钥位置){
logger.info(“-|-步骤1===”;
试一试{
PGPLib pgp=新的PGPLib();
布尔值=真;
整度检查为false的布尔值;
logger.info(“-|-步骤2===”;
PipedInputStream引脚=新的PipedInputStream();
OutputStream o=新管道输出流(pin);
InputStream is=newbytearrayinputstream(text.getBytes(“UTF-8”);
logger.info(“-|-步骤3==”;
如果(publicKeyFile==null){
publicKeyFile=新文件(publicKeyLocation);
}
logger.info(“-|-步骤4===”;
InputStream publicKeyStream=新文件InputStream(publicKeyFile);
logger.info(“-|-步骤5===”;
pgp.encryptStream(is、publicKeyLocation、publicKeyStream、o、armor、,
使用完整性检查);
logger.info(“-|-步骤6===”;
做{
logger.info(“-|-pin.available():”+pin.available());

}while(pin.available()这是因为代码等待
encryptStream
完成后才开始从
PipedInputStream
读取。管道流:读取线程在写入线程写入时读取。等待读取直到写入完成,导致死锁

因此,修复代码的一种方法是在一个单独的线程中生成
encryptStream
,可以直接使用线程,也可以使用执行器,等等。然后,您必须处理所有线程注意事项

当您加密的字符串很大时,这种设置可能会有好处,并且您可以在加密字符串的其余部分准备就绪之前,对部分字符串执行一些有效的操作,例如将其发送到文件或网络连接。但是,您的代码似乎没有设置为利用您对结果所做的所有操作encryptStream的ts将它们转换为十六进制字符串并返回。这指向了一个更简单的解决方案:不要使用管道流

您尝试使用
PipedOutputStream
的方式由类以更简单的方式提供,不需要线程:

ByteArrayOutputStream o = new ByteArrayOutputStream();
pgp.encryptStream(is, publicKeyLocation, publicKeyStream, o, armor,
        withIntegrityCheck);
byte[] body = o.toByteArray();
int numberRead = body.length;