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


Java KeyGenerator類代碼示例

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


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

示例1: encryptData

import javax.crypto.KeyGenerator; //導入依賴的package包/類
@Override
public void encryptData(String plaintext) {
   System.out.println("-------Encrypting data using AES algorithm-------");
   try {
       KeyGenerator keyGenerator = KeyGenerator.getInstance("AES");
       keyGenerator.init(128);
       SecretKey secretKey = keyGenerator.generateKey();
       byte[] plaintTextByteArray = plaintext.getBytes("UTF8");

       Cipher cipher = Cipher.getInstance("AES");
       cipher.init(Cipher.ENCRYPT_MODE, secretKey);
       byte[] cipherText = cipher.doFinal(plaintTextByteArray);

       System.out.println("Original data: " + plaintext);
       System.out.println("Encrypted data:");
       for (int i = 0; i < cipherText.length; i++) {
           System.out.print(cipherText[i] + " ");

       }
   }
       catch(Exception ex){
           ex.printStackTrace();
       }
   }
 
開發者ID:zhang-jh,項目名稱:GOF,代碼行數:25,代碼來源:AesEncryptionStrategy.java

示例2: main

import javax.crypto.KeyGenerator; //導入依賴的package包/類
public static void main(String[] args) throws Exception {
    Provider provider = Security.getProvider("SunJCE");

    KeyGenerator kg;

    kg = KeyGenerator.getInstance("SunTlsRsaPremasterSecret", provider);

    try {
        kg.generateKey();
        throw new Exception("no exception");
    } catch (IllegalStateException e) {
        System.out.println("OK: " + e);
    }

    int[] protocolVersions = {0x0300, 0x0301, 0x0302, 0x0400};
    for (int clientVersion : protocolVersions) {
        for (int serverVersion : protocolVersions) {
            test(kg, clientVersion, serverVersion);
            if (serverVersion >= clientVersion) {
                break;
            }
        }
    }

    System.out.println("Done.");
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:27,代碼來源:TestPremaster.java

示例3: createNewKey

import javax.crypto.KeyGenerator; //導入依賴的package包/類
/**
 * Create a new key in the Keystore
 */
private void createNewKey(){
  try {
    final KeyStore keyStore = KeyStore.getInstance(AndroidKeyStore);
    keyStore.load(null);

    final KeyGenerator keyGenerator = KeyGenerator.getInstance(KeyProperties.KEY_ALGORITHM_AES, AndroidKeyStore);

    // Build one key to be used for encrypting and decrypting the file
    keyGenerator.init(
        new KeyGenParameterSpec.Builder(ALIAS,
            KeyProperties.PURPOSE_ENCRYPT | KeyProperties.PURPOSE_DECRYPT)
            .setBlockModes(KeyProperties.BLOCK_MODE_GCM)
            .setEncryptionPaddings(KeyProperties.ENCRYPTION_PADDING_NONE)
            .build());
    keyGenerator.generateKey();
    Log.i(TAG, "Key created in Keystore");

  }catch (KeyStoreException | InvalidAlgorithmParameterException | NoSuchProviderException | NoSuchAlgorithmException | CertificateException | IOException  kS){
    Log.e(TAG, kS.getMessage());
  }
}
 
開發者ID:Esri,項目名稱:mapbook-android,代碼行數:25,代碼來源:CredentialCryptographer.java

示例4: DESCipherWrapper

import javax.crypto.KeyGenerator; //導入依賴的package包/類
public DESCipherWrapper(String algo, String mode, String pad)
        throws NoSuchAlgorithmException, NoSuchPaddingException {
    ci = Cipher.getInstance(algo + "/" + mode + "/" + pad);

    iv = new byte[8];
    for (int i = 0; i < 8; i++) {
        iv[i] = (byte) (i & 0xff);
    }

    KeyGenerator kg = KeyGenerator.getInstance(algo);
    key = kg.generateKey();
    keyStrength = algo.equalsIgnoreCase("DESede") ? 112
            : key.getEncoded().length * 8;

    this.algo = algo;
    this.mode = mode;
    this.pad = pad;
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:19,代碼來源:DESCipherWrapper.java

示例5: triggerMacKeyGeneration

import javax.crypto.KeyGenerator; //導入依賴的package包/類
/**
 * Generates the authentication encryption key in a background thread (if necessary).
 */
private static void triggerMacKeyGeneration() {
    synchronized (sLock) {
        if (sKey != null || sMacKeyGenerator != null) {
            return;
        }

        sMacKeyGenerator = new FutureTask<SecretKey>(new Callable<SecretKey>() {
            // SecureRandomInitializer addresses the bug in SecureRandom that "TrulyRandom"
            // warns about, so this lint warning can safely be suppressed.
            @SuppressLint("TrulyRandom")
            @Override
            public SecretKey call() throws Exception {
                KeyGenerator generator = KeyGenerator.getInstance(MAC_ALGORITHM_NAME);
                SecureRandom random = new SecureRandom();
                SecureRandomInitializer.initialize(random);
                generator.init(MAC_KEY_BYTE_COUNT * 8, random);
                return generator.generateKey();
            }
        });
        AsyncTask.THREAD_POOL_EXECUTOR.execute(sMacKeyGenerator);
    }
}
 
開發者ID:rkshuai,項目名稱:chromium-for-android-56-debug-video,代碼行數:26,代碼來源:WebappAuthenticator.java

示例6: AesDecrypt

import javax.crypto.KeyGenerator; //導入依賴的package包/類
/**
 * aes解密-128位
 */
public static String AesDecrypt(String encryptContent, String password) {
	try {
		KeyGenerator keyGen = KeyGenerator.getInstance("AES");
		SecureRandom secureRandom = SecureRandom.getInstance("SHA1PRNG");
		secureRandom.setSeed(password.getBytes());
		keyGen.init(128, secureRandom);
		SecretKey secretKey = keyGen.generateKey();
		byte[] enCodeFormat = secretKey.getEncoded();
		SecretKeySpec key = new SecretKeySpec(enCodeFormat, "AES");
		Cipher cipher = Cipher.getInstance("AES");
		cipher.init(Cipher.DECRYPT_MODE, key);
		return new String(cipher.doFinal(hex2Bytes(encryptContent)));
	} catch (Exception e) {
		logger.error("AesDecrypt exception", e);
		return null;
	}
}
 
開發者ID:yi-jun,項目名稱:aaden-pay,代碼行數:21,代碼來源:BaofooSecurityUtil.java

示例7: aesEncryptToBytes

import javax.crypto.KeyGenerator; //導入依賴的package包/類
private static byte[] aesEncryptToBytes(String content, String encryptKey) throws Exception {  
    KeyGenerator kgen = KeyGenerator.getInstance("AES");  
    kgen.init(128, new SecureRandom(encryptKey.getBytes()));  
  
    Cipher cipher = Cipher.getInstance("AES");  
    cipher.init(Cipher.ENCRYPT_MODE, new SecretKeySpec(kgen.generateKey().getEncoded(), "AES"));  
      
    return cipher.doFinal(content.getBytes("utf-8"));  
}
 
開發者ID:onsoul,項目名稱:os,代碼行數:10,代碼來源:AESUtils.java

示例8: getKey

import javax.crypto.KeyGenerator; //導入依賴的package包/類
private static SecretKey getKey(byte[] seed)
{
	try
	{
		KeyGenerator keyGenerator = KeyGenerator.getInstance("AES");
		SecureRandom secureRandom = SecureRandom.getInstance("SHA1PRNG");
		secureRandom.setSeed(seed);
		keyGenerator.init(128, secureRandom); // 128 is the safest one to
												// use for compatibility?
		SecretKey skey = keyGenerator.generateKey();
		return skey;
	}
	catch (Exception ex)
	{
		Logger.debug(ex, Encryption.class);
	}
	return null;
}
 
開發者ID:bp2008,項目名稱:blueirisviewer,代碼行數:19,代碼來源:Encryption.java

示例9: initFingerprintManager

import javax.crypto.KeyGenerator; //導入依賴的package包/類
private void initFingerprintManager() throws Throwable {
    mFpManager = (FingerprintManager) mContext.getSystemService(Context.FINGERPRINT_SERVICE);
    if (!mFpManager.isHardwareDetected())
        throw new IllegalStateException("Fingerprint hardware not present");

    KeyStore keyStore = KeyStore.getInstance("AndroidKeyStore");
    KeyGenerator keyGenerator = KeyGenerator.getInstance(
            KeyProperties.KEY_ALGORITHM_AES, "AndroidKeyStore");
    keyStore.load(null);
    keyGenerator.init(new KeyGenParameterSpec.Builder(
            KEY_NAME, KeyProperties.PURPOSE_ENCRYPT | KeyProperties.PURPOSE_DECRYPT)
            .setBlockModes(KeyProperties.BLOCK_MODE_CBC)
            .setEncryptionPaddings(KeyProperties.ENCRYPTION_PADDING_PKCS7)
            .build());
    keyGenerator.generateKey();

    Cipher cipher = Cipher.getInstance(
            KeyProperties.KEY_ALGORITHM_AES + "/" +
            KeyProperties.BLOCK_MODE_CBC + "/" +
            KeyProperties.ENCRYPTION_PADDING_PKCS7);
    SecretKey key = (SecretKey) keyStore.getKey(KEY_NAME, null);
    cipher.init(Cipher.ENCRYPT_MODE, key);

    mFpHandler = new FingerprintHandler(cipher);

    if (DEBUG) log("Fingeprint manager initialized");
}
 
開發者ID:WrBug,項目名稱:GravityBox,代碼行數:28,代碼來源:FingerprintLauncher.java

示例10: getRawKey

import javax.crypto.KeyGenerator; //導入依賴的package包/類
/**
 * 獲取256位的加密密鑰
 *
 * @param seed
 * @return
 * @throws Exception
 */
private static byte[] getRawKey(byte[] seed) throws Exception {
    KeyGenerator kgen = KeyGenerator.getInstance("AES");
    SecureRandom sr = null;
    // 在4.2以上版本中,SecureRandom獲取方式發生了改變
    if (android.os.Build.VERSION.SDK_INT >= JELLY_BEAN_4_2) {
        sr = SecureRandom.getInstance("SHA1PRNG", "Crypto");
    } else {
        sr = SecureRandom.getInstance("SHA1PRNG");
    }
    sr.setSeed(seed);
    // 256 bits or 128 bits,192bits
    kgen.init(256, sr);
    SecretKey skey = kgen.generateKey();
    byte[] raw = skey.getEncoded();
    return raw;
}
 
開發者ID:codeccc,項目名稱:baselibrary-master,代碼行數:24,代碼來源:AESEncryptor.java

示例11: WrongAAD

import javax.crypto.KeyGenerator; //導入依賴的package包/類
public WrongAAD() throws Exception {
    // init a secret key
    KeyGenerator kg = KeyGenerator.getInstance("AES", PROVIDER);
    kg.init(KEY_SIZE);
    key = kg.generateKey();

    // generate a plain text
    plainText = Helper.generateBytes(TEXT_SIZE);

    // init AADs
    byte[] AAD = Helper.generateBytes(AAD_SIZE);

    // init a cipher
    encryptCipher = createCipher(Cipher.ENCRYPT_MODE, null);
    encryptCipher.updateAAD(AAD);
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:17,代碼來源:WrongAAD.java

示例12: initKey

import javax.crypto.KeyGenerator; //導入依賴的package包/類
/**
 * 生成密鑰 <br>
 * Java 6 隻支持56bit密鑰 <br>
 * Bouncy Castle 支持64bit密鑰 <br>
 * 
 * @return byte[] 二進製密鑰
 * @throws NoSuchAlgorithmException
 */
public static byte[] initKey() throws NoSuchAlgorithmException {
	/*
	 * 實例化密鑰生成器
	 * 
	 * 若要使用64bit密鑰注意替換 將下述代碼中的KeyGenerator.getInstance(CIPHER_ALGORITHM);
	 * 替換為KeyGenerator.getInstance(CIPHER_ALGORITHM, "BC");
	 */
	KeyGenerator kg = KeyGenerator.getInstance(KEY_ALGORITHM);
	/*
	 * 初始化密鑰生成器 若要使用64bit密鑰注意替換 將下述代碼kg.init(56); 替換為kg.init(64);
	 */
	kg.init(56, new SecureRandom());
	// 生成秘密密鑰
	SecretKey secretKey = kg.generateKey();
	// 獲得密鑰的二進製編碼形式
	return secretKey.getEncoded();
}
 
開發者ID:iBase4J,項目名稱:iBase4J-Common,代碼行數:26,代碼來源:DESCoder.java

示例13: getOrCreateSecretKey

import javax.crypto.KeyGenerator; //導入依賴的package包/類
private SecretKey getOrCreateSecretKey(String alias) throws GeneralSecurityException, IOException {
  try {
    return getSymmetricKey(alias);
  } catch (FileNotFoundException fnfe) {
    Log.i(Constants.TAG, "no existing symmetric key for alias");

    KeyGenerator keyGenerator = KeyGenerator.getInstance("AES");
    //32bytes / 256bits AES key
    keyGenerator.init(256);
    SecretKey secretKey = keyGenerator.generateKey();
    PublicKey publicKey = getOrCreatePublicKey(alias);
    Storage.writeValues(getContext(), Constants.SKS_KEY_FILENAME + alias,
        encryptRsaPlainText(publicKey, secretKey.getEncoded()));

    Log.i(Constants.TAG, "created new symmetric keys for alias");
    return secretKey;
  }
}
 
開發者ID:pradeep1991singh,項目名稱:react-native-secure-key-store,代碼行數:19,代碼來源:RNSecureKeyStoreModule.java

示例14: createCipherKeyGenerator

import javax.crypto.KeyGenerator; //導入依賴的package包/類
private void createCipherKeyGenerator(){
    if(cipherKeyGenCreated){
        return;
    }
    try {
        cipherKeyGenerator = KeyGenerator.getInstance(KeyProperties.KEY_ALGORITHM_AES, provider);
        cipherKeyGenerator.init(new KeyGenParameterSpec.Builder(keyName,KeyProperties.PURPOSE_ENCRYPT | KeyProperties.PURPOSE_DECRYPT)
                .setBlockModes(KeyProperties.BLOCK_MODE_CBC)
                .setUserAuthenticationRequired(true)
                .setEncryptionPaddings(KeyProperties.ENCRYPTION_PADDING_PKCS7)
                .build());

        cipherKeyGenCreated = true;
    } catch (NoSuchAlgorithmException | NoSuchProviderException | InvalidAlgorithmParameterException e) {
        throw new RuntimeException("Failed to create key generator", e);
    }
}
 
開發者ID:OmarAflak,項目名稱:Fingerprint,代碼行數:18,代碼來源:CipherHelper.java

示例15: initKey

import javax.crypto.KeyGenerator; //導入依賴的package包/類
/**
 * 生成密鑰 <br>
 * Java 6 隻支持56bit密鑰 <br>
 * Bouncy Castle 支持64bit密鑰 <br>
 * 
 * @return byte[] 二進製密鑰
 * @throws NoSuchAlgorithmException
 * @throws Exception
 */
public static byte[] initKey() throws NoSuchAlgorithmException {
	/*
	 * 實例化密鑰生成器
	 * 
	 * 若要使用64bit密鑰注意替換 將下述代碼中的KeyGenerator.getInstance(CIPHER_ALGORITHM);
	 * 替換為KeyGenerator.getInstance(CIPHER_ALGORITHM, "BC");
	 */
	KeyGenerator kg = KeyGenerator.getInstance(KEY_ALGORITHM);
	/*
	 * 初始化密鑰生成器 若要使用64bit密鑰注意替換 將下述代碼kg.init(56); 替換為kg.init(64);
	 */
	kg.init(56, new SecureRandom());
	// 生成秘密密鑰
	SecretKey secretKey = kg.generateKey();
	// 獲得密鑰的二進製編碼形式
	return secretKey.getEncoded();
}
 
開發者ID:guokezheng,項目名稱:automat,代碼行數:27,代碼來源:DESCoder.java


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