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


Java SecureRandom.getInstance方法代碼示例

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


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

示例1: main

import java.security.SecureRandom; //導入方法依賴的package包/類
public static void main(String[] args) throws Exception {
    SecureRandom sr;
    boolean pass = true;
    for (String mech : new String[]{"Hash_DRBG", "HMAC_DRBG", "CTR_DRBG"}) {
        try {
            System.out.println("Testing " + mech + "...");
            Security.setProperty("securerandom.drbg.config", mech);

            // Check auto reseed works
            sr = SecureRandom.getInstance("DRBG");
            sr.nextInt();
            sr = SecureRandom.getInstance("DRBG");
            sr.reseed();
            sr = SecureRandom.getInstance("DRBG");
            sr.generateSeed(10);
        } catch (Exception e) {
            pass = false;
            e.printStackTrace(System.out);
        }
    }
    if (!pass) {
        throw new RuntimeException("At least one test case failed");
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:25,代碼來源:AutoReseed.java

示例2: buildArtifact

import java.security.SecureRandom; //導入方法依賴的package包/類
/** {@inheritDoc} */
public SAML1ArtifactType0001 buildArtifact(
        SAMLMessageContext<RequestAbstractType, Response, NameIdentifier> requestContext, Assertion assertion) {
    try {
        MessageDigest sha1Digester = MessageDigest.getInstance("SHA-1");
        byte[] source = sha1Digester.digest(requestContext.getLocalEntityId().getBytes());

        SecureRandom handleGenerator = SecureRandom.getInstance("SHA1PRNG");
        byte[] assertionHandle = new byte[20];
        handleGenerator.nextBytes(assertionHandle);

        return new SAML1ArtifactType0001(source, assertionHandle);
    } catch (NoSuchAlgorithmException e) {
        log.error("JVM does not support required cryptography algorithms.", e);
        throw new InternalError("JVM does not support required cryptography algorithms: SHA-1 and/or SHA1PRNG.");
    }
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:18,代碼來源:SAML1ArtifactType0001Builder.java

示例3: getCipher

import java.security.SecureRandom; //導入方法依賴的package包/類
public static Cipher getCipher(int mode, byte[] secret) throws NoSuchAlgorithmException,
        NoSuchPaddingException, InvalidKeyException, UnsupportedEncodingException {
    // generate an encryption/decryption key from random data seeded with
    // our secret (i.e. password)
    SecureRandom secureRandom = SecureRandom.getInstance(RANDOM_ALGORITHM);
    secureRandom.setSeed(secret);
    KeyGenerator keyGenerator = KeyGenerator.getInstance(ENCRYPTION_ALGORITHM);
    keyGenerator.init(KEY_SIZE, secureRandom);
    Key key = new SecretKeySpec(keyGenerator.generateKey().getEncoded(), ENCRYPTION_ALGORITHM);
    // get a cipher based on the specified encryption algorithm
    Cipher cipher = Cipher.getInstance(ENCRYPTION_ALGORITHM);
    // tell the cipher if it will be used for encryption or decryption
    // (i.e. cipher mode) and give it our key
    cipher.init(mode, key);
    return cipher;
}
 
開發者ID:sdrausty,項目名稱:buildAPKsSamples,代碼行數:17,代碼來源:CryptUtil.java

示例4: getSecretKey

import java.security.SecureRandom; //導入方法依賴的package包/類
public static SecretKeySpec getSecretKey(String secretKey) throws Exception
{
	KeyGenerator kgen = KeyGenerator.getInstance(ENCRYPT_TYPE);
	SecureRandom random = SecureRandom.getInstance("SHA1PRNG");
	random.setSeed(secretKey.getBytes());

	kgen.init(AES_DEFAULT_KEY_SIZE, random);
	SecretKey sk = kgen.generateKey();

	byte[] enCodeFormat = sk.getEncoded();
	return new SecretKeySpec(enCodeFormat, ENCRYPT_TYPE);
}
 
開發者ID:marlonwang,項目名稱:raven,代碼行數:13,代碼來源:AESUtils.java

示例5: generateKey

import java.security.SecureRandom; //導入方法依賴的package包/類
public static byte[] generateKey( byte[] seed ) throws Exception
{
	KeyGenerator keyGenerator = KeyGenerator.getInstance( CIPHER_ALGORITHM );
	SecureRandom secureRandom = SecureRandom.getInstance( RANDOM_GENERATOR_ALGORITHM );
	secureRandom.setSeed( seed );
    keyGenerator.init( RANDOM_KEY_SIZE, secureRandom );
    SecretKey secretKey = keyGenerator.generateKey();
    return secretKey.getEncoded();
}
 
開發者ID:sdrausty,項目名稱:buildAPKsSamples,代碼行數:10,代碼來源:StringCryptor.java

示例6: createRngInternal

import java.security.SecureRandom; //導入方法依賴的package包/類
private static RandomWrapper createRngInternal() {
  try {
    return new RandomWrapper(SecureRandom.getInstance("SHA1PRNG"));
  } catch (final NoSuchAlgorithmException e) {
    throw new RuntimeException(e);
  }
}
 
開發者ID:Pr0methean,項目名稱:BetterRandom,代碼行數:8,代碼來源:RandomWrapperSecureRandomTest.java

示例7: main

import java.security.SecureRandom; //導入方法依賴的package包/類
public static void main(String[] args) {
    System.setProperty("java.security.egd", "file:/dev/urandom");

    boolean success = true;
    for (String mech : new String[]{
        "SHA1PRNG", "Hash_DRBG", "HMAC_DRBG", "CTR_DRBG"}) {
        System.out.printf("%nTest for SecureRandom algorithm: '%s'", mech);
        try {
            SecureRandom sr = null;
            if (!mech.contains("_DRBG")) {
                sr = SecureRandom.getInstance(mech);
            } else {
                Security.setProperty(DRBG_CONFIG, mech);
                sr = SecureRandom.getInstance("DRBG");
            }

            success &= forEachSeedBytes(sr);
            System.out.printf("%nCompleted test for SecureRandom "
                    + "mechanism: '%s'", mech);
        } catch (Exception e) {
            success &= false;
            e.printStackTrace(System.out);
        } finally {
            Security.setProperty(DRBG_CONFIG, DRBG_CONFIG_VALUE);
        }
    }
    if (!success) {
        throw new RuntimeException("At least one test failed.");
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:31,代碼來源:EnoughSeedTest.java

示例8: testWolfSignInteropVerify

import java.security.SecureRandom; //導入方法依賴的package包/類
@Test
public void testWolfSignInteropVerify()
    throws NoSuchProviderException, NoSuchAlgorithmException,
           SignatureException, InvalidKeyException,
           InvalidAlgorithmParameterException {

    String toSign = "Hello World";
    byte[] toSignBuf = toSign.getBytes();
    byte[] signature;

    for (int i = 0; i < wolfJCEAlgos.length; i++) {

        Signature signer =
            Signature.getInstance(wolfJCEAlgos[i], "wolfJCE");
        Signature verifier =
            Signature.getInstance(wolfJCEAlgos[i]);

        assertNotNull(signer);
        assertNotNull(verifier);

        Provider prov = verifier.getProvider();
        if (prov.equals("wolfJCE")) {
            /* bail out, there isn't another implementation to interop
             * against by default */
            return;
        }

        SecureRandom rand =
            SecureRandom.getInstance("HashDRBG", "wolfJCE");
        assertNotNull(rand);

        /* generate key pair */
        KeyPair pair = generateKeyPair(wolfJCEAlgos[i], rand);
        assertNotNull(pair);

        PrivateKey priv = pair.getPrivate();
        PublicKey  pub  = pair.getPublic();

        /* generate signature */
        signer.initSign(priv);
        signer.update(toSignBuf, 0, toSignBuf.length);
        signature = signer.sign();

        /* verify signature */
        verifier.initVerify(pub);
        verifier.update(toSignBuf, 0, toSignBuf.length);
        boolean verified = verifier.verify(signature);

        if (verified != true) {
            fail("Signature verification failed when generating with " +
                    "wolfJCE and verifying with system default JCE " +
                    "provider");
        }
    }
}
 
開發者ID:wolfSSL,項目名稱:wolfcrypt-jni,代碼行數:56,代碼來源:WolfCryptSignatureTest.java

示例9: generateRandomBytes

import java.security.SecureRandom; //導入方法依賴的package包/類
/** {@inheritDoc} */
@Override
public byte[] generateRandomBytes(final int numBytes) throws IOException {
    final SecureRandom sr;
    try {
        sr = SecureRandom.getInstance("SHA1PRNG"); //$NON-NLS-1$
    }
    catch (final NoSuchAlgorithmException e) {
        throw new IOException("Algoritmo de generacion de aleatorios no valido: " + e, e); //$NON-NLS-1$
    }
    final byte[] randomBytes = new byte[numBytes];
    sr.nextBytes(randomBytes);
    return randomBytes;
}
 
開發者ID:MiFirma,項目名稱:mi-firma-android,代碼行數:15,代碼來源:JseCryptoHelper.java

示例10: getSecureRandom

import java.security.SecureRandom; //導入方法依賴的package包/類
private static SecureRandom getSecureRandom() {
    try {
        return SecureRandom.getInstance("SHA1PRNG");
    } catch (NoSuchAlgorithmException e) {
        throw new AssertionError(e);
    }
}
 
開發者ID:toshiapp,項目名稱:toshi-headless-client,代碼行數:8,代碼來源:Util.java

示例11: generateSalt

import java.security.SecureRandom; //導入方法依賴的package包/類
public String generateSalt() throws NoSuchAlgorithmException {
	// VERY important to use SecureRandom instead of just Random
	SecureRandom random = SecureRandom.getInstance("SHA1PRNG");
	// Generate a 8 byte (64 bit) salt as recommended by RSA PKCS5
	byte[] salt = new byte[8];
	random.nextBytes(salt);
	return Base64.getEncoder().encodeToString(salt);
}
 
開發者ID:Angular2Guy,項目名稱:AngularAndSpring,代碼行數:9,代碼來源:PasswordEncryption.java

示例12: encrypt

import java.security.SecureRandom; //導入方法依賴的package包/類
/**
 * 加密
 *
 * @param content �?要加密的內容
 * @return
 */
public static String encrypt(String content) throws Exception {
        KeyGenerator kgen = KeyGenerator.getInstance(AES);
        SecureRandom random = SecureRandom.getInstance("SHA1PRNG");
        random.setSeed(KEY.getBytes());
        kgen.init(AES_LENGTH, random);
        SecretKey secretKey = kgen.generateKey();
        byte[] enCodeFormat = secretKey.getEncoded();
        SecretKeySpec key = new SecretKeySpec(enCodeFormat, AES);
        Cipher cipher = Cipher.getInstance(AES);// 創建密碼�?
        byte[] byteContent = content.getBytes(ENCODING_UTF8);
        cipher.init(Cipher.ENCRYPT_MODE, key);// 初始�?
        byte[] result = cipher.doFinal(byteContent);
        return new BASE64Encoder().encode(result); // 加密
}
 
開發者ID:Awesky,項目名稱:awe-awesomesky,代碼行數:21,代碼來源:AESUtil.java

示例13: installLinuxPRNGSecureRandom

import java.security.SecureRandom; //導入方法依賴的package包/類
/**
 * Installs a Linux PRNG-backed {@code SecureRandom} implementation as the
 * default. Does nothing if the implementation is already the default or if
 * there is not need to install the implementation.
 *
 * @throws SecurityException if the fix is needed but could not be applied.
 */
private static void installLinuxPRNGSecureRandom()
        throws SecurityException {
    if (Build.VERSION.SDK_INT > VERSION_CODE_JELLY_BEAN_MR2) {
        // No need to apply the fix
        return;
    }

    // Install a Linux PRNG-based SecureRandom implementation as the
    // default, if not yet installed.
    Provider[] secureRandomProviders =
            Security.getProviders("SecureRandom.SHA1PRNG");
    if ((secureRandomProviders == null)
            || (secureRandomProviders.length < 1)
            || (!LinuxPRNGSecureRandomProvider.class.equals(
            secureRandomProviders[0].getClass()))) {
        Security.insertProviderAt(new LinuxPRNGSecureRandomProvider(), 1);
    }

    // Assert that new SecureRandom() and
    // SecureRandom.getInstance("SHA1PRNG") return a SecureRandom backed
    // by the Linux PRNG-based SecureRandom implementation.
    SecureRandom rng1 = new SecureRandom();
    if (!LinuxPRNGSecureRandomProvider.class.equals(
            rng1.getProvider().getClass())) {
        throw new SecurityException(
                "new SecureRandom() backed by wrong Provider: "
                        + rng1.getProvider().getClass());
    }

    SecureRandom rng2;
    try {
        rng2 = SecureRandom.getInstance("SHA1PRNG");
    } catch (NoSuchAlgorithmException e) {
        throw new SecurityException("SHA1PRNG not available", e);
    }
    if (!LinuxPRNGSecureRandomProvider.class.equals(
            rng2.getProvider().getClass())) {
        throw new SecurityException(
                "SecureRandom.getInstance(\"SHA1PRNG\") backed by wrong"
                        + " Provider: " + rng2.getProvider().getClass());
    }
}
 
開發者ID:privacyidea,項目名稱:privacyidea-authenticator,代碼行數:50,代碼來源:PRNGFixes.java

示例14: generateNonce

import java.security.SecureRandom; //導入方法依賴的package包/類
static String generateNonce() throws NoSuchAlgorithmException, UnsupportedEncodingException {
    SecureRandom random = SecureRandom.getInstance("SHA1PRNG");
    random.setSeed(System.currentTimeMillis());
    byte[] nonceBytes = new byte[16];
    random.nextBytes(nonceBytes);
    String nonce = new String(Base64.getEncoder().encode(nonceBytes), "UTF-8");
    return nonce;
}
 
開發者ID:CCob,項目名稱:bittrex4j,代碼行數:9,代碼來源:EncryptionUtility.java

示例15: installLinuxPRNGSecureRandom

import java.security.SecureRandom; //導入方法依賴的package包/類
/**
 * Installs a Linux PRNG-backed {@code SecureRandom} implementation as
 * the default. Does nothing if the implementation is already the
 * default or if there is not need to install the implementation.
 *
 * @throws SecurityException if the fix is needed but could not be
 *             applied.
 */
private static void installLinuxPRNGSecureRandom() throws SecurityException {
    if (Build.VERSION.SDK_INT > VERSION_CODE_JELLY_BEAN_MR2) {
        // No need to apply the fix
        return;
    }

    // Install a Linux PRNG-based SecureRandom implementation as the
    // default, if not yet installed.
    Provider[] secureRandomProviders = Security.getProviders("SecureRandom.SHA1PRNG");

    // Insert and check the provider atomically.
    // The official Android Java libraries use synchronized methods for
    // insertProviderAt, etc., so synchronizing on the class should
    // make things more stable, and prevent race conditions with other
    // versions of this code.
    synchronized (java.security.Security.class) {
        if ((secureRandomProviders == null)
                || (secureRandomProviders.length < 1)
                || (!secureRandomProviders[0].getClass().getSimpleName().equals("LinuxPRNGSecureRandomProvider"))) {
            Security.insertProviderAt(new LinuxPRNGSecureRandomProvider(), 1);
        }

        // Assert that new SecureRandom() and
        // SecureRandom.getInstance("SHA1PRNG") return a SecureRandom backed
        // by the Linux PRNG-based SecureRandom implementation.
        SecureRandom rng1 = new SecureRandom();
        if (!rng1.getProvider().getClass().getSimpleName().equals("LinuxPRNGSecureRandomProvider")) {
            if (ALLOW_BROKEN_PRNG) {
                Log.w(PrngFixes.class.getSimpleName(),
                        "new SecureRandom() backed by wrong Provider: " + rng1.getProvider().getClass());
                return;
            } else {
                throw new SecurityException("new SecureRandom() backed by wrong Provider: "
                        + rng1.getProvider().getClass());
            }
        }

        SecureRandom rng2 = null;
        try {
            rng2 = SecureRandom.getInstance("SHA1PRNG");
        } catch (NoSuchAlgorithmException e) {
            if (ALLOW_BROKEN_PRNG) {
                Log.w(PrngFixes.class.getSimpleName(), "SHA1PRNG not available", e);
                return;
            } else {
                new SecurityException("SHA1PRNG not available", e);
            }
        }
        if (!rng2.getProvider().getClass().getSimpleName().equals("LinuxPRNGSecureRandomProvider")) {
            if (ALLOW_BROKEN_PRNG) {
                Log.w(PrngFixes.class.getSimpleName(),
                        "SecureRandom.getInstance(\"SHA1PRNG\") backed by wrong" + " Provider: "
                                + rng2.getProvider().getClass());
                return;
            } else {
                throw new SecurityException(
                        "SecureRandom.getInstance(\"SHA1PRNG\") backed by wrong" + " Provider: "
                                + rng2.getProvider().getClass());
            }
        }
    }
}
 
開發者ID:YoeriNijs,項目名稱:NoteBuddy,代碼行數:71,代碼來源:AesCbcWithIntegrity.java


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