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


Java SecureRandom.setSeed方法代碼示例

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


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

示例1: secureRandomHashing

import java.security.SecureRandom; //導入方法依賴的package包/類
public byte[] secureRandomHashing(long blockNumber) {

        final SecureRandom secureRandom;
        try {
            secureRandom = SecureRandom.getInstance("SHA1PRNG");
            secureRandom.setSeed(seedForThisBlock(blockNumber));
        } catch (NoSuchAlgorithmException e) {
            throw new RuntimeException(e);
        }
        final byte[] ret = new byte[EncConstants.BLOCKSIZE];
        secureRandom.nextBytes(ret);
//
//        secureRandom.longs(EncConstants.BLOCKSIZE / 8).forEach(value -> {
//        });
        return ret;
    }
 
開發者ID:MineboxOS,項目名稱:tools,代碼行數:17,代碼來源:BitPatternGenerator.java

示例2: AesDecrypt

import java.security.SecureRandom; //導入方法依賴的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

示例3: createSecureRandom

import java.security.SecureRandom; //導入方法依賴的package包/類
private static SecureRandom createSecureRandom()
{
    /*
     * We use our threaded seed generator to generate a good random seed. If the user has a
     * better random seed, he should use the constructor with a SecureRandom.
     */
    ThreadedSeedGenerator tsg = new ThreadedSeedGenerator();
    SecureRandom random = new SecureRandom();

    /*
     * Hopefully, 20 bytes in fast mode are good enough.
     */
    random.setSeed(tsg.generateSeed(20, true));

    return random;
}
 
開發者ID:Appdome,項目名稱:ipack,代碼行數:17,代碼來源:TlsClientProtocol.java

示例4: main

import java.security.SecureRandom; //導入方法依賴的package包/類
public static void main(String[] args) throws Exception {
    SecureRandom sr = SecureRandom.getInstance("SHA1PRNG");
    sr.setSeed(0);
    sr.nextInt();

    ByteArrayOutputStream bout = new ByteArrayOutputStream();
    new ObjectOutputStream(bout).writeObject(sr);

    SecureRandom sr2 = (SecureRandom) new ObjectInputStream(
            new ByteArrayInputStream(bout.toByteArray())).readObject();

    int i1 = sr.nextInt();
    sr2.setSeed(1);
    int i2 = sr2.nextInt();

    if (i1 == i2) {
        throw new Exception("output should not be the same");
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:20,代碼來源:SHA1PRNGReseed.java

示例5: main

import java.security.SecureRandom; //導入方法依賴的package包/類
public void main(Provider p) throws Exception {
    // Skip this test for providers not found by java.security.Security
    if (Security.getProvider(p.getName()) != p) {
        System.out.println("Skip test for provider " + p.getName());
        return;
    }
    SecureRandom r;
    try {
        r = SecureRandom.getInstance("PKCS11", p);
        System.out.println("SecureRandom instance " + r);
    } catch (NoSuchAlgorithmException e) {
        System.out.println("Provider " + p +
                           " does not support SecureRandom, skipping");
        e.printStackTrace();
        return;
    }
    r.setSeed(System.currentTimeMillis());
    byte[] buf = new byte[16];
    byte[] ser = toByteArray(r);
    System.out.println("Serialized Len = " + ser.length);
    SecureRandom r2 = fromByteArray(ser);
    System.out.println("Deserialized into " + r2);
    r2.nextBytes(buf);
    System.out.println("Done");
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:26,代碼來源:TestDeserialization.java

示例6: main

import java.security.SecureRandom; //導入方法依賴的package包/類
@Override
public void main(Provider p) throws Exception {
    SecureRandom random;
    try {
        random = SecureRandom.getInstance("PKCS11");
    } catch (NoSuchAlgorithmException e) {
        System.out.println("Provider " + p + " does not support SecureRandom, skipping");
        e.printStackTrace();
        return;
    }
    byte[] b = new byte[32];
    random.nextBytes(b);
    System.out.println(toString(b));
    random.setSeed(b);
    random.nextBytes(b);
    System.out.println(toString(b));
    System.out.println("OK");
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:19,代碼來源:Basic.java

示例7: generateSalt

import java.security.SecureRandom; //導入方法依賴的package包/類
private String generateSalt() {
    byte[] salt = new byte[KEY_LENGTH];
    try {
        SecureRandom sr = SecureRandom.getInstance("SHA1PRNG");
        sr.setSeed(System.currentTimeMillis());
        sr.nextBytes(salt);
        return Arrays.toString(salt);
    } catch (Exception e) {
        salt = DEFAULT_PASSWORD_SALT.getBytes();
    }
    return Base64.encodeToString(salt, Base64.DEFAULT);
}
 
開發者ID:sfilmak,項目名稱:MakiLite,代碼行數:13,代碼來源:AppLockImpl.java

示例8: 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:Fetax,項目名稱:Fetax-AI,代碼行數:21,代碼來源:AESUtil.java

示例9: randomBytes

import java.security.SecureRandom; //導入方法依賴的package包/類
/**
 *
 * @param lgt length wanted
 * @return secure random bytes of length lgt
 */
public static byte[] randomBytes(int lgt) {
    SecureRandom rd = new SecureRandom();
    rd.setSeed(System.nanoTime());
    byte[] bt = new byte[lgt];
    rd.nextBytes(bt);
    return bt;
}
 
開發者ID:IIlllII,項目名稱:bitbreeds-webrtc,代碼行數:13,代碼來源:SignalUtil.java

示例10: generate

import java.security.SecureRandom; //導入方法依賴的package包/類
/**
 * Generates a cryptographically secure API key of the specified length.
 * @param chars the length of the API key to generate
 * @return a String representation of the API key
 */
public static String generate(int chars) {
    final SecureRandom secureRandom = new SecureRandom();
    final char[] buff = new char[chars];
    for (int i = 0; i < chars; ++i) {
        if ((i % 10) == 0) {
            secureRandom.setSeed(secureRandom.nextLong());
        }
        buff[i] = VALID_CHARACTERS[secureRandom.nextInt(VALID_CHARACTERS.length)];
    }
    return new String(buff);
}
 
開發者ID:stevespringett,項目名稱:Alpine,代碼行數:17,代碼來源:ApiKeyGenerator.java

示例11: getRawKey

import java.security.SecureRandom; //導入方法依賴的package包/類
private static byte[] getRawKey(byte[] seed) throws Exception {
    KeyGenerator kgen = KeyGenerator.getInstance("AES");
    // SHA1PRNG 強隨機種子算法, 要區別4.2以上版本的調用方法
    SecureRandom sr;
    if (android.os.Build.VERSION.SDK_INT >= 17) {
        sr = SecureRandom.getInstance("SHA1PRNG", "Crypto");
    } else {
        sr = SecureRandom.getInstance("SHA1PRNG");
    }
    sr.setSeed(seed);
    kgen.init(256, sr); //256 bits or 128 bits,192bits
    SecretKey s_key = kgen.generateKey();
    byte[] raw = s_key.getEncoded();
    return raw;
}
 
開發者ID:abook23,項目名稱:godlibrary,代碼行數:16,代碼來源:AESCipher.java

示例12: AesDecryptByBytes

import java.security.SecureRandom; //導入方法依賴的package包/類
/**
 * AES解密
 * @param encryptBytes 待解密的byte[]
 * @param decryptKey 解密密鑰
 * @return 解密後的
 * @throws Exception
 */
public static byte[] AesDecryptByBytes(byte[] encryptBytes,byte[] decryptKey) throws Exception {
	KeyGenerator kgen = KeyGenerator.getInstance("AES");
	SecureRandom secureRandom = SecureRandom.getInstance("SHA1PRNG");
	secureRandom.setSeed(decryptKey);
	kgen.init(128,secureRandom);
	Cipher cipher = Cipher.getInstance("AES");
	cipher.init(Cipher.DECRYPT_MODE, new SecretKeySpec(kgen.generateKey().getEncoded(), "AES"));
	byte[] decryptBytes = cipher.doFinal(encryptBytes);
	return decryptBytes;
}
 
開發者ID:juebanlin,項目名稱:util4j,代碼行數:18,代碼來源:AesUtil.java

示例13: AesEncryptToBytes

import java.security.SecureRandom; //導入方法依賴的package包/類
/**
 * AES加密
 * @param content 待加密的內容
 * @param encryptKey 加密密鑰
 * @return 加密後的byte[]
 * @throws Exception
 */
public static byte[] AesEncryptToBytes(byte[] content,byte[] encryptKey) throws Exception {
	KeyGenerator kgen = KeyGenerator.getInstance("AES");
	SecureRandom secureRandom = SecureRandom.getInstance("SHA1PRNG");
	secureRandom.setSeed(encryptKey);
	kgen.init(128,secureRandom);
	Cipher cipher = Cipher.getInstance("AES");
	cipher.init(Cipher.ENCRYPT_MODE, new SecretKeySpec(kgen.generateKey().getEncoded(), "AES"));
	return cipher.doFinal(content);
}
 
開發者ID:juebanlin,項目名稱:util4j,代碼行數:17,代碼來源:AesUtil.java

示例14: testEncrypt

import java.security.SecureRandom; //導入方法依賴的package包/類
/**
 * Tests encryption / decryption by attempting to encrypt and decrypt the bytes forming this class definition and
 * comparing it with the unencrypted bytes.
 * 
 * @throws Exception
 *             an exception
 */
public void testEncrypt() throws Exception
{
    final KeyPairGenerator keyGen = KeyPairGenerator.getInstance("RSA");
    final SecureRandom random = SecureRandom.getInstance("SHA1PRNG");
    final byte[] seed = getClass().getName().getBytes("UTF-8");
    random.setSeed(seed);
    keyGen.initialize(1024, random);
    final KeyPair pair = keyGen.generateKeyPair();

    final ByteArrayOutputStream buff = new ByteArrayOutputStream(2048);
    final OutputStream encrypting = new EncryptingOutputStream(buff, pair.getPublic(), random);
    final ByteArrayOutputStream plainText1 = new ByteArrayOutputStream(2048);

    final InputStream in = getClass().getResourceAsStream(getClass().getSimpleName() + ".class");
    final byte[] inbuff = new byte[17];
    int bytesRead;
    while ((bytesRead = in.read(inbuff)) != -1)
    {
        encrypting.write(inbuff, 0, bytesRead);
        plainText1.write(inbuff, 0, bytesRead);
    }
    in.close();
    encrypting.close();
    plainText1.close();
    final InputStream decrypting = new DecryptingInputStream(new ByteArrayInputStream(buff.toByteArray()), pair
            .getPrivate());
    final ByteArrayOutputStream plainText2 = new ByteArrayOutputStream(2048);
    while ((bytesRead = decrypting.read(inbuff)) != -1)
    {
        plainText2.write(inbuff, 0, bytesRead);
    }

    assertTrue(Arrays.equals(plainText1.toByteArray(), plainText2.toByteArray()));

}
 
開發者ID:Alfresco,項目名稱:alfresco-core,代碼行數:43,代碼來源:EncryptingOutputStreamTest.java

示例15: 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


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