當前位置: 首頁>>代碼示例>>Java>>正文


Java Cipher.getBlockSize方法代碼示例

本文整理匯總了Java中javax.crypto.Cipher.getBlockSize方法的典型用法代碼示例。如果您正苦於以下問題:Java Cipher.getBlockSize方法的具體用法?Java Cipher.getBlockSize怎麽用?Java Cipher.getBlockSize使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在javax.crypto.Cipher的用法示例。


在下文中一共展示了Cipher.getBlockSize方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: testGetBlockSize

import javax.crypto.Cipher; //導入方法依賴的package包/類
@Test
public void testGetBlockSize()
    throws NoSuchProviderException, NoSuchAlgorithmException,
           NoSuchPaddingException {

    Cipher cipher;

    for (int i = 0; i < enabledJCEAlgos.size(); i++) {
        cipher = Cipher.getInstance(enabledJCEAlgos.get(i), "wolfJCE");

        if (cipher.getBlockSize() !=
                expectedBlockSizes.get((enabledJCEAlgos.get(i)))) {
            fail("Expected Cipher block size did not match, " +
                    "algo = " + enabledJCEAlgos.get(i));
        }
    }
}
 
開發者ID:wolfSSL,項目名稱:wolfcrypt-jni,代碼行數:18,代碼來源:WolfCryptCipherTest.java

示例2: s_encrypt_public

import javax.crypto.Cipher; //導入方法依賴的package包/類
/**
 * 公鑰加密
 * 
 * @param _key
 *            公鑰
 * @param _data
 *            待加密數據
 * @return 
 * @throws Exception
 */
public static byte[] s_encrypt_public( byte[] _key , byte[] _data ) throws Exception {

	// 取得公鑰
	X509EncodedKeySpec x509 = new X509EncodedKeySpec( _key );

	KeyFactory key_factory = KeyFactory.getInstance( KEY_ALGORITHM_RSA );

	PublicKey public_key = key_factory.generatePublic( x509 );

	// 對數據加密
	Cipher cipher = Cipher.getInstance( key_factory.getAlgorithm() );

	cipher.init( Cipher.ENCRYPT_MODE , public_key );

	int blockSize = cipher.getBlockSize();
	if ( blockSize > 0 ) {
		int outputSize = cipher.getOutputSize( _data.length );
		int leavedSize = _data.length % blockSize;
		int blocksSize = leavedSize != 0 ? _data.length / blockSize + 1 : _data.length / blockSize;
		byte[] raw = new byte[ outputSize * blocksSize ];
		int i = 0 , remainSize = 0;
		while ( ( remainSize = _data.length - i * blockSize ) > 0 ) {
			int inputLen = remainSize > blockSize ? blockSize : remainSize;
			cipher.doFinal( _data , i * blockSize , inputLen , raw , i * outputSize );
			i++;
		}
		return raw;
	}
	return cipher.doFinal( _data );
}
 
開發者ID:aiyoyoyo,項目名稱:jeesupport,代碼行數:41,代碼來源:RSAUtils.java

示例3: encrypt

import javax.crypto.Cipher; //導入方法依賴的package包/類
public String encrypt(String data) throws Exception {
	if (null == data)
		return null;
	Cipher cipher = Cipher.getInstance(DES);
	cipher.init(Cipher.ENCRYPT_MODE, key);
	StringBuffer sb = new StringBuffer();
	int blockSize = cipher.getBlockSize();
	int outputSize = cipher.getOutputSize(blockSize);
	byte[] src = data.getBytes();
	byte[] outBytes = new byte[outputSize];
	int i = 0;
	try {
		for (; i <= src.length - blockSize; i = i + blockSize) {
			int outLength = cipher.update(src, i, blockSize, outBytes);
			sb.append(bytesToString(outBytes, outLength));
		}
		if (i == src.length)
			outBytes = cipher.doFinal();
		else {
			outBytes = cipher.doFinal(src, i, src.length - i);
		}
		sb.append(bytesToString(outBytes));
		return sb.toString();
	} catch (Exception e) {
		e.printStackTrace();
	}
	return null;
}
 
開發者ID:jiangzongyao,項目名稱:kettle_support_kettle8.0,代碼行數:29,代碼來源:Random.java

示例4: decrypt

import javax.crypto.Cipher; //導入方法依賴的package包/類
public String decrypt(String data) throws Exception {
	if (null == data)
		return null;
	Cipher cipher = Cipher.getInstance(DES);
	cipher.init(Cipher.DECRYPT_MODE, key);
	StringBuffer sb = new StringBuffer();
	int blockSize = cipher.getBlockSize();
	int outputSize = cipher.getOutputSize(blockSize);
	byte[] src = stringToBytes(data);
	byte[] outBytes = new byte[outputSize];
	int i = 0;
	try {
		for (; i <= src.length - blockSize; i = i + blockSize) {
			int outLength = cipher.update(src, i, blockSize, outBytes);
			sb.append(new String(outBytes, 0, outLength));
		}
		if (i == src.length)
			outBytes = cipher.doFinal();
		else {
			outBytes = cipher.doFinal(src, i, src.length - i);
		}
		sb.append(new String(outBytes));
		return sb.toString();
	} catch (Exception e) {
		e.printStackTrace();
	}
	return null;
}
 
開發者ID:jiangzongyao,項目名稱:kettle_support_kettle8.0,代碼行數:29,代碼來源:Random.java

示例5: encrypt

import javax.crypto.Cipher; //導入方法依賴的package包/類
public static String encrypt(String data){
    try {
        Cipher cipher = Cipher.getInstance("AES/CBC/NoPadding");
        int blockSize = cipher.getBlockSize();

        byte[] dataBytes = data.getBytes();
        int plaintextLength = dataBytes.length;
        if (plaintextLength % blockSize != 0) {
            plaintextLength = plaintextLength + (blockSize - (plaintextLength % blockSize));
        }

        byte[] plaintext = new byte[plaintextLength];
        System.arraycopy(dataBytes, 0, plaintext, 0, dataBytes.length);
         
        SecretKeySpec keyspec = new SecretKeySpec(ZFMPWD.getBytes(), "AES");
        IvParameterSpec ivspec = new IvParameterSpec(iv.getBytes());

        cipher.init(Cipher.ENCRYPT_MODE, keyspec, ivspec);
        byte[] encrypted = cipher.doFinal(plaintext);

        return new BASE64Encoder().encode(encrypted);

    } catch (Exception e) {
        e.printStackTrace();
        return null;
    }
}
 
開發者ID:liuxuanhai,項目名稱:WeiXing_xmu-2016-MrCode,代碼行數:28,代碼來源:Aes.java

示例6: encryptedData

import javax.crypto.Cipher; //導入方法依賴的package包/類
/**
	 * 
	 * @param publicKey
	 * @param plainData
	 * @return
	 * @throws Exception
	 */
	public byte[] encryptedData(PublicKey publicKey, byte[] plainData)
			throws Exception {
		try {
//			Cipher cipher = CliperInstance.getInstance();
			Cipher cipher = Cipher.getInstance("RSA/ECB/PKCS1Padding","BC");
			cipher.init(Cipher.ENCRYPT_MODE, publicKey);
			int blockSize = cipher.getBlockSize();
			int outputSize = cipher.getOutputSize(plainData.length);
			int leavedSize = plainData.length % blockSize;
			int blocksSize = leavedSize != 0 ? plainData.length / blockSize + 1
					: plainData.length / blockSize;
			byte[] raw = new byte[outputSize * blocksSize];
			int i = 0;
			while (plainData.length - i * blockSize > 0) {
				if (plainData.length - i * blockSize > blockSize) {
					cipher.doFinal(plainData, i * blockSize, blockSize, raw, i
							* outputSize);
				} else {
					cipher.doFinal(plainData, i * blockSize, plainData.length
							- i * blockSize, raw, i * outputSize);
				}
				i++;
			}
			return raw;
		} catch (Exception e) {
			throw new Exception(e.getMessage());
		}
	}
 
開發者ID:superkoh,項目名稱:k-framework,代碼行數:36,代碼來源:SecureUtil.java

示例7: s_encrypt_private

import javax.crypto.Cipher; //導入方法依賴的package包/類
/**
 * 私鑰加密
 * 
 * @param _key
 *            私鑰
 * @param _data
 *            待加密數據
 * @return
 * @throws Exception
 */
public static byte[] s_encrypt_private( byte[] _key , byte[] _data ) throws Exception {

	// 取得私鑰
	PKCS8EncodedKeySpec pkcs8 = new PKCS8EncodedKeySpec( _key );

	KeyFactory key_factory = KeyFactory.getInstance( KEY_ALGORITHM_RSA );

	// 生成私鑰
	PrivateKey private_key = key_factory.generatePrivate( pkcs8 );

	// 對數據加密
	Cipher cipher = Cipher.getInstance( key_factory.getAlgorithm() );

	cipher.init( Cipher.ENCRYPT_MODE , private_key );

	int blockSize = cipher.getBlockSize();
	if ( blockSize > 0 ) {
		int outputSize = cipher.getOutputSize( _data.length );
		int leavedSize = _data.length % blockSize;
		int blocksSize = leavedSize != 0 ? _data.length / blockSize + 1 : _data.length / blockSize;
		byte[] raw = new byte[ outputSize * blocksSize ];
		int i = 0 , remainSize = 0;
		while ( ( remainSize = _data.length - i * blockSize ) > 0 ) {
			int inputLen = remainSize > blockSize ? blockSize : remainSize;
			cipher.doFinal( _data , i * blockSize , inputLen , raw , i * outputSize );
			i++;
		}
		return raw;
	}
	return cipher.doFinal( _data );
}
 
開發者ID:aiyoyoyo,項目名稱:jeesupport,代碼行數:42,代碼來源:RSAUtils.java

示例8: decryptRaw

import javax.crypto.Cipher; //導入方法依賴的package包/類
/**
 * Decrypts data using specified key and initial vector.
 * @param baseKey encryption key to use
 * @param ciphertext  encrypted data to be decrypted
 * @param usage ignored
 */
public byte[] decryptRaw(byte[] baseKey, int usage, byte[] ivec,
    byte[] ciphertext, int start, int len)
    throws GeneralSecurityException {

    if (debug) {
        System.err.println("usage: " + usage);
        if (ivec != null) {
            traceOutput("old_state.ivec", ivec, 0, ivec.length);
        }
        traceOutput("ciphertext", ciphertext, start, Math.min(len, 32));
        traceOutput("baseKey", baseKey, 0, baseKey.length);
    }

    Cipher decCipher = getCipher(baseKey, ivec, Cipher.DECRYPT_MODE);

    int blockSize = decCipher.getBlockSize();

    if ((len % blockSize) != 0) {
        throw new GeneralSecurityException(
            "length of data to be decrypted (" + len +
            ") is not a multiple of the blocksize (" + blockSize + ")");
    }

    byte[] decrypted = decCipher.doFinal(ciphertext, start, len);

    if (debug) {
        traceOutput("decrypted", decrypted, 0,
            Math.min(decrypted.length, 32));
    }

    return decrypted;
}
 
開發者ID:SunburstApps,項目名稱:OpenJSharp,代碼行數:39,代碼來源:DkCrypto.java

示例9: dr

import javax.crypto.Cipher; //導入方法依賴的package包/類
private byte[] dr(byte[] key, byte[] constant)
    throws GeneralSecurityException {

    Cipher encCipher = getCipher(key, null, Cipher.ENCRYPT_MODE);
    int blocksize = encCipher.getBlockSize();

    if (constant.length != blocksize) {
        constant = nfold(constant, blocksize * 8);
    }
    byte[] toBeEncrypted = constant;

    int keybytes = (getKeySeedLength()>>3);  // from bits to bytes
    byte[] rawkey = new byte[keybytes];
    int posn = 0;

    /* loop encrypting the blocks until enough key bytes are generated */
    int n = 0, len;
    while (n < keybytes) {
        if (debug) {
            System.err.println("Encrypting: " +
                bytesToString(toBeEncrypted));
        }

        byte[] cipherBlock = encCipher.doFinal(toBeEncrypted);
        if (debug) {
            System.err.println("K: " + ++posn + " = " +
                bytesToString(cipherBlock));
        }

        len = (keybytes - n <= cipherBlock.length ? (keybytes - n) :
            cipherBlock.length);
        if (debug) {
            System.err.println("copying " + len + " key bytes");
        }
        System.arraycopy(cipherBlock, 0, rawkey, n, len);
        n += len;
        toBeEncrypted = cipherBlock;
    }
    return rawkey;
}
 
開發者ID:SunburstApps,項目名稱:OpenJSharp,代碼行數:41,代碼來源:DkCrypto.java

示例10: s_decrypt_private

import javax.crypto.Cipher; //導入方法依賴的package包/類
/**
 * 私鑰解密
 * 
 * @param _key
 *            私鑰
 * @param _dat
 *            待解密數據
 * @return
 * @throws Exception
 */
public static byte[] s_decrypt_private( byte[] _key, byte[] _dat ) throws Exception {
	// 取得私鑰
	PKCS8EncodedKeySpec pkcs8 = new PKCS8EncodedKeySpec( _key );

	KeyFactory key_factory = KeyFactory.getInstance( KEY_ALGORITHM_RSA );

	// 生成私鑰
	PrivateKey private_key = key_factory.generatePrivate( pkcs8 );

	// 對數據解密
	Cipher cipher = Cipher.getInstance( key_factory.getAlgorithm() );

	cipher.init( Cipher.DECRYPT_MODE , private_key );

	int blockSize = cipher.getBlockSize();
	if ( blockSize > 0 ) {
		ByteArrayOutputStream bout = new ByteArrayOutputStream( 64 );
		int j = 0;
		while ( _dat.length - j * blockSize > 0 ) {
			bout.write( cipher.doFinal( _dat , j * blockSize , blockSize ) );
			j++;
		}
		return bout.toByteArray();
	}
	return cipher.doFinal( _dat );
}
 
開發者ID:aiyoyoyo,項目名稱:jeesupport,代碼行數:37,代碼來源:RSAUtils.java

示例11: encryptNoPadding

import javax.crypto.Cipher; //導入方法依賴的package包/類
public static String encryptNoPadding(String str, String str2) throws Exception {
    Cipher instance = Cipher.getInstance("AES/CBC/NoPadding");
    int blockSize = instance.getBlockSize();
    Object bytes = str.getBytes(str2);
    int length = bytes.length;
    if (length % blockSize != 0) {
        length += blockSize - (length % blockSize);
    }
    Object obj = new byte[length];
    System.arraycopy(bytes, 0, obj, 0, bytes.length);
    instance.init(1, new SecretKeySpec(pwd, "AES"), new IvParameterSpec(iv));
    return Base64.encodeBase64String(instance.doFinal(obj));
}
 
開發者ID:JackChan1999,項目名稱:boohee_v5.6,代碼行數:14,代碼來源:AesHelper.java

示例12: encryptRaw

import javax.crypto.Cipher; //導入方法依賴的package包/類
/**
 * Performs encryption using given key only; does not add
 * confounder, padding, or checksum. Incoming data to be encrypted
 * assumed to have the correct blocksize.
 * Ignore key usage.
 */
public byte[] encryptRaw(byte[] baseKey, int usage,
    byte[] ivec, byte[] plaintext, int start, int len)
    throws GeneralSecurityException, KrbCryptoException {

    if (debug) {
        System.err.println("usage: " + usage);
        if (ivec != null) {
            traceOutput("old_state.ivec", ivec, 0, ivec.length);
        }
        traceOutput("plaintext", plaintext, start, Math.min(len, 32));
        traceOutput("baseKey", baseKey, 0, baseKey.length);
    }

    // Encrypt
    Cipher encCipher = getCipher(baseKey, ivec, Cipher.ENCRYPT_MODE);
    int blockSize = encCipher.getBlockSize();

    if ((len % blockSize) != 0) {
        throw new GeneralSecurityException(
            "length of data to be encrypted (" + len +
            ") is not a multiple of the blocksize (" + blockSize + ")");
    }

    int cipherSize = encCipher.getOutputSize(len);
    byte[] ciphertext = new byte[cipherSize];

    encCipher.doFinal(plaintext, 0, len, ciphertext, 0);
    return ciphertext;
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:36,代碼來源:DkCrypto.java

示例13: encryptedPin

import javax.crypto.Cipher; //導入方法依賴的package包/類
/**
	 * 使用網關公鑰對持卡人密碼進行加密,並返回byte[]類型
	 * 
	 * @param publicKey
	 * @param plainPin
	 * @return
	 * @throws Exception
	 */
	public static byte[] encryptedPin(PublicKey publicKey, byte[] plainPin)
			throws Exception {
		try {
			// y
			// Cipher cipher = Cipher.getInstance("DES",
			// new org.bouncycastle.jce.provider.BouncyCastleProvider());

			// 本土的
//			Cipher cipher = CliperInstance.getInstance();
			Cipher cipher = Cipher.getInstance("RSA/ECB/PKCS1Padding","BC");
			cipher.init(Cipher.ENCRYPT_MODE, publicKey);
			int blockSize = cipher.getBlockSize();
			int outputSize = cipher.getOutputSize(plainPin.length);
			int leavedSize = plainPin.length % blockSize;
			int blocksSize = leavedSize != 0 ? plainPin.length / blockSize + 1
					: plainPin.length / blockSize;
			byte[] raw = new byte[outputSize * blocksSize];
			int i = 0;
			while (plainPin.length - i * blockSize > 0) {
				if (plainPin.length - i * blockSize > blockSize) {
					cipher.doFinal(plainPin, i * blockSize, blockSize, raw, i
							* outputSize);
				} else {
					cipher.doFinal(plainPin, i * blockSize, plainPin.length - i
							* blockSize, raw, i * outputSize);
				}
				i++;
			}
			return raw;
			
			/*Cipher cipher = CliperInstance.getInstance();
			cipher.init(Cipher.ENCRYPT_MODE, publicKey);
			byte[] output = cipher.doFinal(plainPin);
			return output;*/
			
		} catch (Exception e) {
			throw new Exception(e.getMessage());
		}
	}
 
開發者ID:superkoh,項目名稱:k-framework,代碼行數:48,代碼來源:SecureUtil.java

示例14: getDesCbcChecksum

import javax.crypto.Cipher; //導入方法依賴的package包/類
/**
 * Computes the DesCbc checksum based on the algorithm published in FIPS
 * Publication 113. This involves applying padding to the data passed
 * in, then performing DesCbc encryption on the data with a zero initial
 * vector, and finally returning the last 8 bytes of the encryption
 * result.
 *
 * @param key the bytes for the DES key
 * @param header a header to process first before the data is.
 * @param data the data to checksum
 * @param offset the offset where the data begins
 * @param len the length of the data
 * @throws GSSException when an error occuse in the encryption
 */
private byte[] getDesCbcChecksum(byte key[],
                                 byte[] header,
                                 byte[] data, int offset, int len)
    throws GSSException {

    Cipher des = getInitializedDes(true, key, ZERO_IV);

    int blockSize = des.getBlockSize();

    /*
     * Here the data need not be a multiple of the blocksize
     * (8). Encrypt and throw away results for all blocks except for
     * the very last block.
     */

    byte[] finalBlock = new byte[blockSize];

    int numBlocks = len / blockSize;
    int lastBytes = len % blockSize;
    if (lastBytes == 0) {
        // No need for padding. Save last block from application data
        numBlocks -= 1;
        System.arraycopy(data, offset + numBlocks*blockSize,
                         finalBlock, 0, blockSize);
    } else {
        System.arraycopy(data, offset + numBlocks*blockSize,
                         finalBlock, 0, lastBytes);
        // Zero padding automatically done
    }

    try {
        byte[] temp = new byte[Math.max(blockSize,
            (header == null? blockSize : header.length))];

        if (header != null) {
            // header will be null when doing DES-MD5 Checksum
            des.update(header, 0, header.length, temp, 0);
        }

        // Iterate over all but the last block
        for (int i = 0; i < numBlocks; i++) {
            des.update(data, offset, blockSize,
                       temp, 0);
            offset += blockSize;
        }

        // Now process the final block
        byte[] retVal = new byte[blockSize];
        des.update(finalBlock, 0, blockSize, retVal, 0);
        des.doFinal();

        return retVal;
    } catch (GeneralSecurityException e) {
        GSSException ge = new GSSException(GSSException.FAILURE, -1,
            "Could not use DES Cipher - " + e.getMessage());
        ge.initCause(e);
        throw ge;
    }
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:74,代碼來源:CipherHelper.java

示例15: aesEncrypt

import javax.crypto.Cipher; //導入方法依賴的package包/類
/**
 * 解密AES加密過的字符串
 *
 * @param content AES加密過過的內容
 * @return 明文
 */
public static String aesEncrypt(String content) {

    try {

        Cipher cipher = Cipher.getInstance("AES/CBC/NoPadding");

        int blockSize = cipher.getBlockSize();

        byte[] dataBytes = content.getBytes();

        int plaintextLength = dataBytes.length;

        if (plaintextLength % blockSize != 0) {
            plaintextLength = plaintextLength + (blockSize - (plaintextLength % blockSize));
        }

        Byte padding = (byte) Integer.parseInt(Integer.toHexString(blockSize - (dataBytes.length) % blockSize), 16);

        byte[] plaintext = new byte[plaintextLength];

        System.arraycopy(dataBytes, 0, plaintext, 0, dataBytes.length);

        for (int i = dataBytes.length; i < plaintextLength; i++) {
            plaintext[i] = padding;
        }

        SecretKeySpec keyspec = new SecretKeySpec(PASSWORD_KEY.getBytes(), "AES");
        IvParameterSpec ivspec = new IvParameterSpec(PASSWORD_KEY.getBytes());

        cipher.init(Cipher.ENCRYPT_MODE, keyspec, ivspec);
        byte[] encrypted = cipher.doFinal(plaintext);

        return new BASE64Encoder().encode(encrypted);

    } catch (Exception e) {
        e.printStackTrace();
    }
    return null;
}
 
開發者ID:hzwy23,項目名稱:hauth-java,代碼行數:46,代碼來源:CryptoAES.java


注:本文中的javax.crypto.Cipher.getBlockSize方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。