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


Java BufferedBlockCipher.reset方法代碼示例

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


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

示例1: decrypt

import org.bouncycastle.crypto.BufferedBlockCipher; //導入方法依賴的package包/類
@Override
    public String decrypt(byte[] encrypted) {
//        Cipher cipher = null;
        String plain;
        try {
//            Security.addProvider(new BouncyCastlePQCProvider());
//            cipher = Cipher.getInstance("AES/CBC/PKCS5Padding", new BouncyCastlePQCProvider());
//            cipher.init(Cipher.DECRYPT_MODE, new SecretKeySpec(encryptionKey, "AES"), new IvParameterSpec(iv));
//            plain = new String(cipher.doFinal(encrypted), "UTF-8");
            KeyParameter keyParam = new KeyParameter(encryptionKey);
            CipherParameters params = new ParametersWithIV(keyParam, iv);
            BlockCipherPadding padding = new PKCS7Padding();
            BufferedBlockCipher cipher = new PaddedBufferedBlockCipher(
                    new CBCBlockCipher(new AESEngine()), padding);
            cipher.reset();
            cipher.init(false, params);
            byte[] buffer = new byte[cipher.getOutputSize(encrypted.length)];
            int len = cipher.processBytes(encrypted, 0, encrypted.length, buffer, 0);
            len += cipher.doFinal(buffer, len);
            byte[] out = Arrays.copyOfRange(buffer, 0, len);
            plain = new String(out, "UTF-8");
        } catch (Exception e) {
            throw new RuntimeException("decrypt error in SimpleAesManaged", e);
        }
        return plain;
    }
 
開發者ID:timerickson,項目名稱:lastpass-java,代碼行數:27,代碼來源:SimpleAesManaged.java

示例2: EncryptAes256

import org.bouncycastle.crypto.BufferedBlockCipher; //導入方法依賴的package包/類
private static byte[] EncryptAes256(byte[] data, byte[] encryptionKey)
{
    try {
        KeyParameter keyParam = new KeyParameter(encryptionKey);
        BlockCipherPadding padding = new PKCS7Padding();
        BufferedBlockCipher cipher = new PaddedBufferedBlockCipher(
                new CBCBlockCipher(new AESEngine()), padding);
        cipher.reset();
        cipher.init(true, keyParam);
        byte[] buffer = new byte[cipher.getOutputSize(data.length)];
        int len = cipher.processBytes(data, 0, data.length, buffer, 0);
        len += cipher.doFinal(buffer, len);
        return Arrays.copyOfRange(buffer, 0, len);
    } catch (Exception e) {
        throw new RuntimeException("decrypt error in SimpleAesManaged", e);
    }
}
 
開發者ID:timerickson,項目名稱:lastpass-java,代碼行數:18,代碼來源:ParserHelperTest.java

示例3: encrypt

import org.bouncycastle.crypto.BufferedBlockCipher; //導入方法依賴的package包/類
public static byte[] encrypt(byte[] input, BufferedBlockCipher cipher) {
    synchronized(cipher) {
        cipher.reset();

        byte[] cipherText = new byte[cipher.getOutputSize(input.length + pad.length)];

        //Write out the pad
        int outputLen = cipher.processBytes(pad, 0, pad.length, cipherText, 0);

        outputLen += cipher.processBytes(input, 0, input.length, cipherText, outputLen);

        try {
            cipher.doFinal(cipherText, outputLen);
        } catch(CryptoException e) {
            Logger.die("process", e);
        }

        return cipherText;
    }

}
 
開發者ID:dimagi,項目名稱:commcare-j2me,代碼行數:22,代碼來源:CryptUtil.java

示例4: getHashedPassword

import org.bouncycastle.crypto.BufferedBlockCipher; //導入方法依賴的package包/類
/**
 * @return AES(BCrypt(clear_password, 10), SHA256(master_password_key))
 */
public byte[] getHashedPassword(String clear_password) throws SecurityException {
	String tested_password = testIfPasswordIsStrong(clear_password);
	try {
		byte[] hashed = (BCrypt.hashpw(tested_password, BCrypt.gensalt(10))).getBytes("UTF-8");
		
		BlockCipherPadding padding = new PKCS7Padding();
		BufferedBlockCipher cipher = new PaddedBufferedBlockCipher(new CBCBlockCipher(new AESEngine()), padding);
		cipher.reset();
		cipher.init(true, params);
		
		byte[] buf = new byte[cipher.getOutputSize(hashed.length)];
		int len = cipher.processBytes(hashed, 0, hashed.length, buf, 0);
		len += cipher.doFinal(buf, len);
		
		byte[] out = new byte[len];
		System.arraycopy(buf, 0, out, 0, len);
		
		return out;
	} catch (Exception e) {
		Loggers.Auth.error("Can't prepare password", e);
	}
	return null;
}
 
開發者ID:hdsdi3g,項目名稱:MyDMAM,代碼行數:27,代碼來源:Password.java

示例5: checkPassword

import org.bouncycastle.crypto.BufferedBlockCipher; //導入方法依賴的package包/類
public boolean checkPassword(String candidate_password, byte[] raw_password) {
	try {
		BlockCipherPadding padding = new PKCS7Padding();
		BufferedBlockCipher cipher = new PaddedBufferedBlockCipher(new CBCBlockCipher(new AESEngine()), padding);
		cipher.reset();
		cipher.init(false, params);
		
		byte[] buf = new byte[cipher.getOutputSize(raw_password.length)];
		int len = cipher.processBytes(raw_password, 0, raw_password.length, buf, 0);
		len += cipher.doFinal(buf, len);
		
		return BCrypt.checkpw(candidate_password, new String(buf, 0, len));
	} catch (Exception e) {
		Loggers.Auth.error("Can't extract hashed password", e);
	}
	return false;
}
 
開發者ID:hdsdi3g,項目名稱:MyDMAM,代碼行數:18,代碼來源:Password.java

示例6: transform

import org.bouncycastle.crypto.BufferedBlockCipher; //導入方法依賴的package包/類
private static String transform(byte[] key, byte[] iv, String encString, boolean encrypt)
    throws Exception {

  // setup cipher parameters with key and IV
  KeyParameter keyParam = new KeyParameter(key);
  CipherParameters params = new ParametersWithIV(keyParam, iv);

  // setup AES cipher in CBC mode with PKCS7 padding
  BlockCipherPadding padding = new PKCS7Padding();
  BufferedBlockCipher cipher =
      new PaddedBufferedBlockCipher(new CBCBlockCipher(new AESEngine()), padding);
  cipher.reset();
  cipher.init(encrypt, params);

  // create a temporary buffer to decode into (it'll include padding)
  byte[] encData = ByteUtilities.toByteArray(encString);
  byte[] buf = new byte[cipher.getOutputSize(encData.length)];
  int len = cipher.processBytes(encData, 0, encData.length, buf, 0);
  len += cipher.doFinal(buf, len);

  // remove padding
  byte[] out = new byte[len];
  System.arraycopy(buf, 0, out, 0, len);

  // return string representation of decoded bytes
  return ByteUtilities.toHexString(out);
}
 
開發者ID:Braveno,項目名稱:cosigner,代碼行數:28,代碼來源:Aes.java

示例7: deserialize

import org.bouncycastle.crypto.BufferedBlockCipher; //導入方法依賴的package包/類
public static Curve25519PrivateKey deserialize(InputStream in, char[] password) throws IOException {

		try {

			// check magic number
			byte[] mn = new byte[MagicNumbers.PRIVATE_KEY.length];
			IOUtils.readFully(in, mn, 0, mn.length);
			if (!Arrays.areEqual(mn, MagicNumbers.PRIVATE_KEY))
				throw new IllegalArgumentException("Wrong key file format");

			// read initial vector
			byte[] iv = new byte[16];
			IOUtils.readFully(in, iv, 0, iv.length);

			// read salt
			byte[] salt = new byte[64];
			IOUtils.readFully(in, salt, 0, salt.length);

			// initialize cipher
			CipherParameters params = new ParametersWithIV(new KeyParameter(deriveKey(password, salt)), iv);
			BufferedBlockCipher cipher = new PaddedBufferedBlockCipher(new CBCBlockCipher(new AESEngine()), new PKCS7Padding());
			cipher.reset();
			cipher.init(false, params);

			// decrypt key
			CipherInputStream cin = new CipherInputStream(in, cipher);
			byte[] key = new byte[Curve25519.KEY_SIZE];
			IOUtils.readFully(cin, key, 0, key.length);

			// return key instance
			return new Curve25519PrivateKey(key);

		} catch (UnsupportedEncodingException ex) {

			throw new UnsupportedOperationException(ex.getMessage(), ex);
		}
	}
 
開發者ID:Gherynos,項目名稱:secrete,代碼行數:38,代碼來源:Curve25519PrivateKey.java

示例8: encryptBouncyCastle

import org.bouncycastle.crypto.BufferedBlockCipher; //導入方法依賴的package包/類
private static String encryptBouncyCastle(SecretKey secret, String plainText) {
    try {
        // prepending with md5 hash allows us to do an integrity check on decrypt to prevent returning garbage if the decrypt key is incorrect
        String md5 = HashUtils.md5(plainText);
        plainText = md5 + plainText;

        // the iv acts as a per use salt, this ensures things encrypted with the same key always have a unique salt
        // 128 bit iv because NIST AES is standardized with 128 bit blocks and iv needs to match block size, even when using 256 bit key
        byte[] iv = new byte[16];
        SECURE_RANDOM.nextBytes(iv);

        // setup cipher parameters with key and IV
        byte[] key = secret.getEncoded();


        // setup AES cipher in CBC mode with PKCS7 padding
        BufferedBlockCipher cipher = new PaddedBufferedBlockCipher(new CBCBlockCipher(new AESEngine()), new PKCS7Padding());

        cipher.reset();
        cipher.init(true, new ParametersWithIV(new KeyParameter(key), iv));

        byte[] plainTextBuf = plainText.getBytes(StandardCharsets.UTF_8);

        byte[] buf = new byte[cipher.getOutputSize(plainTextBuf.length)];

        int len = cipher.processBytes(plainTextBuf, 0, plainTextBuf.length, buf, 0);
        len += cipher.doFinal(buf, len);

        // copy the encrypted part of the buffer to out
        byte[] out = new byte[len];
        System.arraycopy(buf, 0, out, 0, len);

        // iv$encrypted
        return byteArrayToHexString(iv) + "$" + new String(Base64.encodeBase64URLSafe(out), StandardCharsets.UTF_8);
    } catch (DataLengthException | InvalidCipherTextException e) {
        throw new IllegalStateException("cannot encrypt", e);
    }
}
 
開發者ID:Inbot,項目名稱:inbot-utils,代碼行數:39,代碼來源:AESUtils.java

示例9: dec

import org.bouncycastle.crypto.BufferedBlockCipher; //導入方法依賴的package包/類
public static String dec(String password, String salt, String encString)
        throws Exception {

    byte[] ivData = toByte(encString.substring(0, 32));
    byte[] encData = toByte(encString.substring(32));

    // get raw key from password and salt
    PBEKeySpec pbeKeySpec = new PBEKeySpec(password.toCharArray(),
            toByte(salt), 50, 256);
    SecretKeyFactory keyFactory = SecretKeyFactory
            .getInstance("PBEWithSHA256And256BitAES-CBC-BC");
    SecretKeySpec secretKey = new SecretKeySpec(keyFactory.generateSecret(
            pbeKeySpec).getEncoded(), "AES");
    byte[] key = secretKey.getEncoded();

    // setup cipher parameters with key and IV
    KeyParameter keyParam = new KeyParameter(key);
    CipherParameters params = new ParametersWithIV(keyParam, ivData);

    // setup AES cipher in CBC mode with PKCS7 padding
    BlockCipherPadding padding = new PKCS7Padding();
    BufferedBlockCipher cipher = new PaddedBufferedBlockCipher(
            new CBCBlockCipher(new AESEngine()), padding);
    cipher.reset();
    cipher.init(false, params);

    // create a temporary buffer to decode into (it'll include padding)
    byte[] buf = new byte[cipher.getOutputSize(encData.length)];
    int len = cipher.processBytes(encData, 0, encData.length, buf, 0);
    len += cipher.doFinal(buf, len);

    // remove padding
    byte[] out = new byte[len];
    System.arraycopy(buf, 0, out, 0, len);

    // return string representation of decoded bytes
    return new String(out, "UTF-8");
}
 
開發者ID:danidemi,項目名稱:jlubricant,代碼行數:39,代碼來源:VerifiedTextEncryptor.java

示例10: encryptDecrypt

import org.bouncycastle.crypto.BufferedBlockCipher; //導入方法依賴的package包/類
private byte[] encryptDecrypt(byte[] datas, int pos, int len, int mode) throws GeneralSecurityException, DataLengthException, IllegalStateException, InvalidCipherTextException {
	if (log.isTraceEnabled()) {
		if (mode == Cipher.ENCRYPT_MODE) {
			log.trace("Raw data input (no crypted)" + Hexview.LINESEPARATOR + Hexview.tracelog(datas, pos, len));
		} else {
			log.trace("Raw data input (crypted)" + Hexview.LINESEPARATOR + Hexview.tracelog(datas, pos, len));
		}
	}
	
	BlockCipherPadding padding = new PKCS7Padding();
	BufferedBlockCipher cipher2 = new PaddedBufferedBlockCipher(new CBCBlockCipher(new AESEngine()), padding);
	cipher2.reset();
	cipher2.init(mode == Cipher.ENCRYPT_MODE, params);
	
	byte[] buf = new byte[cipher2.getOutputSize(len)];
	int len2 = cipher2.processBytes(datas, pos, len, buf, 0);
	len2 += cipher2.doFinal(buf, len2);
	
	byte[] result = new byte[len2];
	System.arraycopy(buf, 0, result, 0, len2);
	
	if (log.isTraceEnabled()) {
		if (mode == Cipher.ENCRYPT_MODE) {
			log.trace("Raw data input (crypted)" + Hexview.LINESEPARATOR + Hexview.tracelog(result, 0, result.length));
		} else {
			log.trace("Raw data input (decrypted)" + Hexview.LINESEPARATOR + Hexview.tracelog(result, 0, result.length));
		}
	}
	return result;
}
 
開發者ID:hdsdi3g,項目名稱:MyDMAM,代碼行數:31,代碼來源:Protocol.java

示例11: serialize

import org.bouncycastle.crypto.BufferedBlockCipher; //導入方法依賴的package包/類
public void serialize(OutputStream out, char[] password) throws IOException {

		try {

			// generate initial vector
			SecureRandom random = SecureRandom.getInstance("SHA1PRNG");
			byte[] iv = new byte[16];
			random.nextBytes(iv);

			// generate salt
			byte[] salt = new byte[64];
			random.nextBytes(salt);

			// initialize cipher
			CipherParameters params = new ParametersWithIV(new KeyParameter(deriveKey(password, salt)), iv);
			BufferedBlockCipher cipher = new PaddedBufferedBlockCipher(new CBCBlockCipher(new AESEngine()), new PKCS7Padding());
			cipher.reset();
			cipher.init(true, params);

			// write magic number
			out.write(MagicNumbers.PRIVATE_KEY);
			out.flush();

			// write initial vector and salt
			out.write(iv);
			out.write(salt);
			out.flush();

			// write encrypted key to output stream
			ByteArrayOutputStream buf = new ByteArrayOutputStream();
			CipherOutputStream cout = new CipherOutputStream(buf, cipher);
			cout.write(key);
			cout.close();
			out.write(buf.toByteArray());
			out.flush();

		} catch (UnsupportedEncodingException | NoSuchAlgorithmException ex) {

			throw new UnsupportedOperationException(ex.getMessage(), ex);
		}
	}
 
開發者ID:Gherynos,項目名稱:secrete,代碼行數:42,代碼來源:Curve25519PrivateKey.java


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