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


Java SecretKeyFactory.getInstance方法代碼示例

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


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

示例1: encrypt

import javax.crypto.SecretKeyFactory; //導入方法依賴的package包/類
/**
 * Description 根據鍵值進行加密
 * @param data
 * @param key  加密鍵byte數組
 * @return
 * @throws Exception
 */
private static byte[] encrypt(byte[] data, byte[] key) throws Exception {
    // 生成一個可信任的隨機數源
    SecureRandom sr = new SecureRandom();

    // 從原始密鑰數據創建DESKeySpec對象
    DESKeySpec dks = new DESKeySpec(key);

    // 創建一個密鑰工廠,然後用它把DESKeySpec轉換成SecretKey對象
    SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES);
    SecretKey securekey = keyFactory.generateSecret(dks);

    // Cipher對象實際完成加密操作
    Cipher cipher = Cipher.getInstance(DES);

    // 用密鑰初始化Cipher對象
    cipher.init(Cipher.ENCRYPT_MODE, securekey, sr);

    return cipher.doFinal(data);
}
 
開發者ID:JesseHu1520,項目名稱:mall,代碼行數:27,代碼來源:DesUtil.java

示例2: getCipher

import javax.crypto.SecretKeyFactory; //導入方法依賴的package包/類
protected Cipher getCipher(byte[] key, byte[] ivec, int mode)
    throws GeneralSecurityException {
    // NoSuchAlgorithException
    SecretKeyFactory factory = SecretKeyFactory.getInstance("desede");

    // InvalidKeyException
    KeySpec spec = new DESedeKeySpec(key, 0);

    // InvalidKeySpecException
    SecretKey secretKey = factory.generateSecret(spec);

    // IV
    if (ivec == null) {
        ivec = ZERO_IV;
    }

    // NoSuchAlgorithmException, NoSuchPaddingException
    // NoSuchProviderException
    Cipher cipher = Cipher.getInstance("DESede/CBC/NoPadding");
    IvParameterSpec encIv = new IvParameterSpec(ivec, 0, ivec.length);

    // InvalidKeyException, InvalidAlgorithParameterException
    cipher.init(mode, secretKey, encIv);

    return cipher;
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:27,代碼來源:Des3DkCrypto.java

示例3: PBKDF2

import javax.crypto.SecretKeyFactory; //導入方法依賴的package包/類
private static byte[] PBKDF2(char[] secret, byte[] salt,
    int count, int keyLength) throws GeneralSecurityException {

    PBEKeySpec keySpec = new PBEKeySpec(secret, salt, count, keyLength);
    SecretKeyFactory skf =
            SecretKeyFactory.getInstance("PBKDF2WithHmacSHA1");
    SecretKey key = skf.generateSecret(keySpec);
    byte[] result = key.getEncoded();

    return result;
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:12,代碼來源:AesDkCrypto.java

示例4: decrypt

import javax.crypto.SecretKeyFactory; //導入方法依賴的package包/類
/**
 * 解密
 *
 * @param src 數據源
 * @param key 密鑰,長度必須是8的倍數
 * @return 返回解密後的原始數據
 * @throws Exception
 */
public static byte[] decrypt(byte[] src, byte[] key) throws Exception {

    // DES算法要求有一個可信任的隨機數源
    SecureRandom sr = new SecureRandom();
    // 從原始密匙數據創建一個DESKeySpec對象
    DESKeySpec dks = new DESKeySpec(key);

    // 創建一個密匙工廠,然後用它把DESKeySpec對象轉換成
    // 一個SecretKey對象
    SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES);

    SecretKey securekey = keyFactory.generateSecret(dks);

    // Cipher對象實際完成解密操作
    Cipher cipher = Cipher.getInstance(DES);

    // 用密匙初始化Cipher對象
    cipher.init(Cipher.DECRYPT_MODE, securekey, sr);

    // 現在,獲取數據並解密
    // 正式執行解密操作
    return cipher.doFinal(src);

}
 
開發者ID:paradoxie,項目名稱:DizzyPassword,代碼行數:33,代碼來源:DesUtil.java

示例5: MyPBKDF2SecretKey

import javax.crypto.SecretKeyFactory; //導入方法依賴的package包/類
/**
 * The key is generating by SecretKeyFactory and its value just copying
 * in the key field of MySecretKey class. So, this is real key derived
 * using the given algo.
 */
public MyPBKDF2SecretKey(String passPhrase, String algo, byte[] salt1,
        int iterationCount, int keySize)
        throws InvalidKeySpecException, NoSuchAlgorithmException {
    algorithm = algo;
    salt = salt1;
    itereationCount = iterationCount;
    pass = passPhrase;

    PBEKeySpec spec = new PBEKeySpec(passPhrase.toCharArray(), salt,
            iterationCount, keySize);

    SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(algo);

    SecretKey realKey = keyFactory.generateSecret(spec);

    keyLength = realKey.getEncoded().length;

    key = new byte[keyLength];
    System.arraycopy(realKey.getEncoded(), 0, key, 0, keyLength);
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:26,代碼來源:PBKDF2TranslateTest.java

示例6: generateAndTranslateKey

import javax.crypto.SecretKeyFactory; //導入方法依賴的package包/類
/**
 * The test case scenario implemented in the method: - derive PBKDF2 key
 * using the given algorithm; - translate the key - check if the translated
 * and original keys have the same key value.
 *
 * @return true if the test case passed; false - otherwise.
 * @throws NoSuchAlgorithmException
 * @throws InvalidKeySpecException
 * @throws InvalidKeyException
 */
public boolean generateAndTranslateKey() throws NoSuchAlgorithmException,
        InvalidKeySpecException, InvalidKeyException {
    // derive PBKDF2 key
    SecretKey key1 = getSecretKeyForPBKDF2(algoToTest);

    // translate key
    SecretKeyFactory skf = SecretKeyFactory.getInstance(algoToTest);
    SecretKey key2 = skf.translateKey(key1);

    // check if it still the same after translation
    if (!Arrays.equals(key1.getEncoded(), key2.getEncoded())) {
        System.err.println("generateAndTranslateKey test case failed: the "
                + "key1 and key2 values in its primary encoding format are "
                + "not the same for " + algoToTest + "algorithm.");
        return false;
    }

    return true;
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:30,代碼來源:PBKDF2Translate.java

示例7: hash

import javax.crypto.SecretKeyFactory; //導入方法依賴的package包/類
/**
 * This method will hash the password and salt combination. Be careful, this method will erase the password after hashed it.
 * You must be sure that you do not need it after using this method.
 *
 * @param password the password who needs to be hashed
 * @param salt     some list of <code>byte</code> which will be included in the password
 * @return a hash of the password and salting combination.
 */
public static byte[] hash(char[] password, byte[] salt) {
    final PBEKeySpec spec = new PBEKeySpec(password, salt, SecurityUtils.ITERATIONS, SecurityUtils.KEY_LENGTH);

    try {
        SecretKeyFactory secretKeyFactory = SecretKeyFactory.getInstance(SecurityUtils.ALGORITHM);
        SecretKey key = secretKeyFactory.generateSecret(spec);
        return key.getEncoded();
    } catch (NoSuchAlgorithmException | InvalidKeySpecException e) {
        LOGGER.debug(e.getMessage(), e);
        throw new SecurityException(e);
    } finally {
        // erase the password in the char array in order to not retrieve it in the java memory
        spec.clearPassword();
    }
}
 
開發者ID:Crunchy-Torch,項目名稱:coddy,代碼行數:24,代碼來源:SecurityUtils.java

示例8: decrypt

import javax.crypto.SecretKeyFactory; //導入方法依賴的package包/類
/**
 * Decrypt cipher text.
 * @param str Cipher text to decrypt.
 * @return Decrypted plain text.
 */
public String decrypt(final String str) {
    // Handle null or empty string decryption more gracefully
    if (str == null || str.isEmpty()) {
        return str;
    }

    try {
        final byte[] ciphertext = DatatypeConverter.parseBase64Binary(str);
        if (ciphertext.length < 48) {
            return null;
        }
        final byte[] salt = Arrays.copyOfRange(ciphertext, 0, 16);
        final byte[] iv = Arrays.copyOfRange(ciphertext, 16, 32);
        final byte[] ct = Arrays.copyOfRange(ciphertext, 32, ciphertext.length);

        final SecretKeyFactory factory = SecretKeyFactory.getInstance("PBKDF2WithHmacSHA1");
        final KeySpec spec = new PBEKeySpec(passphrase.toCharArray(), salt, 65536, 128);
        final SecretKey tmp = factory.generateSecret(spec);
        final SecretKey secret = new SecretKeySpec(tmp.getEncoded(), "AES");
        final Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");

        cipher.init(Cipher.DECRYPT_MODE, secret, new IvParameterSpec(iv));
        final byte[] plaintext = cipher.doFinal(ct);

        return new String(plaintext, StandardCharsets.UTF_8);
    } catch (final Exception exception) {
        throw new RuntimeException(exception.getMessage(), exception);
    }
}
 
開發者ID:SourceLabOrg,項目名稱:kafka-webview,代碼行數:35,代碼來源:SecretManager.java

示例9: secret

import javax.crypto.SecretKeyFactory; //導入方法依賴的package包/類
private static SecretKey secret() throws NoSuchAlgorithmException, InvalidKeySpecException {
	byte salt[] = new byte[] { (byte)0x33, (byte)0x7b, (byte)0x09, (byte)0x0e, (byte)0xcf, (byte)0x5a, (byte)0x58, (byte)0xd9 };
	SecretKeyFactory factory = SecretKeyFactory.getInstance("PBKDF2WithHmacSHA1");
	KeySpec spec = new PBEKeySpec(ApplicationProperty.UrlEncoderSecret.value().toCharArray(), salt, 1024, 128);
	SecretKey key = factory.generateSecret(spec);
	return new SecretKeySpec(key.getEncoded(), "AES");
}
 
開發者ID:Jenner4S,項目名稱:unitimes,代碼行數:8,代碼來源:QueryEncoderBackend.java

示例10: decryptByCBC

import javax.crypto.SecretKeyFactory; //導入方法依賴的package包/類
/**
 * 
 * (根據CBC 加密模式、指定加密key輸出對應的BASE64編碼解密串)<br>
 *
 * @param content
 * @param decryptKey
 * @return
 * @throws Exception
 * String
 * @Author fanyaowu
 * @data 2015年2月2日
 * @exception 
 * @version
 *
 */
public static String decryptByCBC(String content, String decryptKey) throws Exception
{
	try
	{
		DESKeySpec dks = new DESKeySpec(decryptKey.getBytes());

		// 創建一個密匙工廠,然後用它把DESKeySpec對象轉換成
		SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(ENCRYPT_TYPE);
		
		SecretKey secretKey = keyFactory.generateSecret(dks);

		// using DES in CBC mode
		Cipher cipher = Cipher.getInstance(CBC_ALGORITHM);

		// 用密匙初始化Cipher對象
		IvParameterSpec param = new IvParameterSpec(iv);
		
		cipher.init(Cipher.DECRYPT_MODE, secretKey, param);

		// 正式執行解密操作
		byte decryptedData[] = cipher.doFinal(Base64.decodeBase64(content));

		return new String(decryptedData);

	}
	catch (Exception e)
	{
		throw new EncryptException("Failed to encrypt for content: "
				+ content + ", encrypt key: " + decryptKey, e);
	}
}
 
開發者ID:marlonwang,項目名稱:raven,代碼行數:47,代碼來源:DESUtils.java

示例11: decode

import javax.crypto.SecretKeyFactory; //導入方法依賴的package包/類
/***
 *  解密
 * @param encryptText 要解密文字
 * @return 解密文字
 * @throws Exception
 */
public static String decode(String encryptText) throws Exception {
    if (TextUtils.isEmpty(secretKey) || TextUtils.isEmpty(iv))
        throw new NullPointerException("u should init first");
    SecretKey deskey = null;
    DESedeKeySpec spec = new DESedeKeySpec(secretKey.getBytes());
    SecretKeyFactory keyfactory = SecretKeyFactory.getInstance("desede");
    deskey = keyfactory.generateSecret(spec);
    Cipher cipher = Cipher.getInstance(DESEDE_CBC_PKCS5_PADDING);
    IvParameterSpec ips = new IvParameterSpec(iv.getBytes());
    cipher.init(2, deskey, ips);
    byte[] decryptData = cipher.doFinal(Base64Util.decode(encryptText));
    return new String(decryptData, encoding);
}
 
開發者ID:ronghao,項目名稱:CacheManage,代碼行數:20,代碼來源:Des3Util.java

示例12: decrypt

import javax.crypto.SecretKeyFactory; //導入方法依賴的package包/類
/**
* decripta il messaggio
* 
* @param message messaggio per la decritptazione
* @return stringa decriptata
* @throws Exception 
*/
 private String decrypt(String message) throws Exception {
   byte[] bytesrc = convertHexString(message);
   Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
   DESKeySpec desKeySpec = new DESKeySpec(key.getBytes("UTF-8"));
   SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
   SecretKey secretKey = keyFactory.generateSecret(desKeySpec);
   IvParameterSpec iv = new IvParameterSpec(key.getBytes("UTF-8"));

   cipher.init(Cipher.DECRYPT_MODE, secretKey, iv);
   byte[] retByte = cipher.doFinal(bytesrc);
   return new String(retByte);
 }
 
開發者ID:IngSW-unipv,項目名稱:Progetto-A,代碼行數:20,代碼來源:Criptazione.java

示例13: loadPrivateKey2

import javax.crypto.SecretKeyFactory; //導入方法依賴的package包/類
private static PrivateKey loadPrivateKey2() throws Exception {

	    String privateKeyPEM = getKeyFromFile("./keys/privatekey-pkcs8.pem");
	    // strip of header, footer, newlines, whitespaces
	    privateKeyPEM = privateKeyPEM
	            .replace("-----BEGIN ENCRYPTED PRIVATE KEY-----", "")
	            .replace("-----END ENCRYPTED PRIVATE KEY-----", "")
	            .replaceAll("\\s", "");

	    // decode to get the binary DER representation
	    byte[] privateKeyDER = Base64.getDecoder().decode(privateKeyPEM);


	    EncryptedPrivateKeyInfo epkInfo = new EncryptedPrivateKeyInfo(privateKeyDER);
	    System.out.println("Algo: ");
	    System.out.println(epkInfo.getAlgName());
	    SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(epkInfo.getAlgName());
	    PBEKeySpec pbeKeySpec = new PBEKeySpec("123".toCharArray());
	    SecretKey pbeKey = keyFactory.generateSecret(pbeKeySpec);

	    Cipher cipher = Cipher.getInstance(epkInfo.getAlgName());
	    cipher.init(Cipher.DECRYPT_MODE, pbeKey, epkInfo.getAlgParameters());

	    // return epkInfo.getKeySpec(cipher);


	    KeyFactory keyFactory2 = KeyFactory.getInstance("RSA");
	    PrivateKey privateKey = keyFactory2.generatePrivate(epkInfo.getKeySpec(cipher));
	    return privateKey;
	}
 
開發者ID:gahana,項目名稱:edge-jwt-sample,代碼行數:31,代碼來源:JWTUtil.java

示例14: init

import javax.crypto.SecretKeyFactory; //導入方法依賴的package包/類
private static void init(byte[] byteData) throws DESException {
    try {
        DKS = new DESKeySpec(byteData);
        SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES);
        SECRET_KEY = keyFactory.generateSecret(DKS);
        CIPHER = Cipher.getInstance(DES);
    } catch (Exception e) {
        throw new DESException("use the parameter key initial DES exception.", e);
    }
}
 
開發者ID:DomKing,項目名稱:springbootWeb,代碼行數:11,代碼來源:PropertyDESUtil.java

示例15: encrypt

import javax.crypto.SecretKeyFactory; //導入方法依賴的package包/類
protected String encrypt(String value ) {

        try {
            final byte[] bytes = value!=null ? value.getBytes(UTF8) : new byte[0];
            SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("PBEWithMD5AndDES");
            SecretKey key = keyFactory.generateSecret(new PBEKeySpec(SEKRIT));
            Cipher pbeCipher = Cipher.getInstance("PBEWithMD5AndDES");
            pbeCipher.init(Cipher.ENCRYPT_MODE, key, new PBEParameterSpec(Secure.getString(context.getContentResolver(), Secure.ANDROID_ID).getBytes(UTF8), 20));
            return new String(Base64.encode(pbeCipher.doFinal(bytes), Base64.NO_WRAP),UTF8);
        } catch( Exception e ) {
            throw new RuntimeException(e);
        }

    }
 
開發者ID:iamBedant,項目名稱:InstantAppStarter,代碼行數:15,代碼來源:ObscuredSharedPreferences.java


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