javax.crypto.BadPaddingException:不是PKCS#1块类型2或零填充

时间:2015-12-10 20:39:24

标签: java encryption rsa modulus exponent

我在解密RSA加密文本时遇到错误。以下是我正在使用的代码。请注意,这两种方法将从不同的方式调用 系统。为了PoC,我已经在同一个java类中实现了。

进口

import java.math.BigInteger;
import java.security.InvalidAlgorithmParameterException;
import java.security.InvalidKeyException;
import java.security.KeyFactory;
import java.security.NoSuchAlgorithmException;
import java.security.PrivateKey;
import java.security.PublicKey;
import java.security.SecureRandom;
import java.security.spec.RSAPrivateKeySpec;
import java.security.spec.RSAPublicKeySpec;
import java.util.logging.Logger;

import javax.crypto.BadPaddingException;
import javax.crypto.Cipher;
import javax.crypto.IllegalBlockSizeException;
import javax.crypto.KeyGenerator;
import javax.crypto.NoSuchPaddingException;
import javax.crypto.SecretKey;
import javax.crypto.spec.IvParameterSpec;

import com.ibm.ws.util.Base64;    

方法

public String decryptUsingRSA(String encryptedString) {

    byte[] encryptedBytes = null;
    String modulusElem = "......";
    String dElem = ".....";
    String result = "";

    try {
        /*
         * ================================================================================================
         *      DECODING FROM BASE64
         * ================================================================================================
         */
        logger.info("decryptUsingRSA : DECODING FROM BASE64");
        byte[] modBytes = Base64.decode(modulusElem);
        byte[] dBytes = Base64.decode(dElem);
        encryptedBytes = Base64.decode(encryptedString);

        /*
         * ================================================================================================
         *      CONVERTING TO BIGINTEGER
         * ================================================================================================
         */
        logger.info("decryptUsingRSA : CONVERTING TO BIGINTEGER");
        BigInteger modules = new BigInteger(1, modBytes);
        BigInteger d = new BigInteger(1, dBytes);

        /*
         * ================================================================================================
         *      INSTANTIATING KEYFACTORY AND CIPHER
         * ================================================================================================
         */
        logger.info("decryptUsingRSA : INSTANTIATING KEYFACTORY AND CIPHER");
        KeyFactory factory = KeyFactory.getInstance("RSA");
        Cipher cipher = Cipher.getInstance("RSA");

        /*
         * ================================================================================================
         *      GENERATING PRIVATE KEY OBJECT
         * ================================================================================================
         */
        logger.info("decryptUsingRSA : GENERATING PRIVATE KEY OBJECT");
        RSAPrivateKeySpec privSpec = new RSAPrivateKeySpec(modules, d);
        PrivateKey privKey = factory.generatePrivate(privSpec);

        /*
         * ================================================================================================
         *      DECRYPTING
         * ================================================================================================
         */
        logger.info("decryptUsingRSA : DECRYPTING");
        cipher.init(Cipher.DECRYPT_MODE, privKey);
        byte[] decrypted = cipher.doFinal(encryptedBytes);

        result = new String(decrypted);
        logger.info("decryptUsingRSA : result = " + result);
    } catch (Exception ex) {
        logger.info("decryptUsingRSA : Exception occurred ");
        ex.printStackTrace();
    }

    return result;
}

public String encryptUsingRSA(String decryptedString) {

    decryptedString = "Encrypted using RSA";
    String modulusElem = "....";
    String dElem = "....";
    String result = "";

    try {
        /*
         * ================================================================================================
         *      DECODING FROM BASE64
         * ================================================================================================
         */
        logger.info("encryptUsingRSA : Step 1/5 - DECODING FROM BASE64");   
        byte[] modBytes = Base64.decode(modulusElem);
        byte[] dBytes = Base64.decode(dElem);

        /*
         * ================================================================================================
         *      CONVERTING TO BIGINTEGER
         * ================================================================================================
         */
        logger.info("encryptUsingRSA : Step 2/5 - CONVERTING TO BIGINTEGER");   
        BigInteger modules = new BigInteger(1, modBytes);
        BigInteger d = new BigInteger(1, dBytes);

        /*
         * ================================================================================================
         *      INSTANTIATING KEYFACTORY AND CIPHER
         * ================================================================================================
         */
        logger.info("encryptUsingRSA : Step 3/5 - INSTANTIATING KEYFACTORY AND CIPHER");    
        KeyFactory factory = KeyFactory.getInstance("RSA");
        Cipher cipher = Cipher.getInstance("RSA/ECB/PKCS1Padding");
        // tried "RSA", "RSA/NONE/PKCS1Padding" etc but same error

        /*
         * ================================================================================================
         *      GENERATING PRIVATE KEY OBJECT
         * ================================================================================================
         */
        logger.info("encryptUsingRSA : Step 4/5 - GENERATING PRIVATE KEY OBJECT");
        RSAPrivateKeySpec privSpec = new RSAPrivateKeySpec(modules, d);
        PrivateKey privKey = factory.generatePrivate(privSpec);
        //logger.info("encryptUsingRSA : Step 4/5 - privKey = " + Base64.encode(privKey.getEncoded()));

        RSAPublicKeySpec publicSpec = new RSAPublicKeySpec(modules, d);
        PublicKey pubKey = factory.generatePublic(publicSpec);
        //logger.info("encryptUsingRSA : Step 4/5 - pubKey = " + Base64.encode(pubKey.getEncoded()));

        /*
         * ================================================================================================
         *      DECRYPTING
         * ================================================================================================
         */
        logger.info("encryptUsingRSA : Step 5/5 - DECRYPTING");
        cipher.init(Cipher.ENCRYPT_MODE, pubKey);
        byte[] decryptedByteArray = decryptedString.getBytes();
        byte[] encryptedbyteArray = cipher.doFinal(decryptedByteArray);

        decryptUsingRSA(Base64.encode(encryptedbyteArray));
    } catch (Exception ex) {
        logger.info("encryptUsingRSA : ERROR encrypting input: " + ex.getMessage());
        ex.printStackTrace();
    }

    return result;
}

错误

INFO: decryptUsingRSA : Exception occurred 
javax.crypto.BadPaddingException: Not PKCS#1 block type 2 or Zero padding
at com.ibm.crypto.provider.RSA.engineDoFinal(Unknown Source)
at javax.crypto.Cipher.doFinal(Unknown Source)

0 个答案:

没有答案