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


Java SecureRandom.getInstanceStrong方法代碼示例

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


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

示例1: EncryptionPayload

import java.security.SecureRandom; //導入方法依賴的package包/類
@JsonCreator
public EncryptionPayload(@JsonProperty("value") SecretValue value,
                         @JsonProperty("userdata") Optional<UserData> userData,
                         @JsonProperty("created") ZonedDateTime created,
                         Optional<UserAlias> createdBy,
                         @JsonProperty("modified") ZonedDateTime modified,
                         Optional<UserAlias> modifiedBy,
                         @JsonProperty("comment") Optional<Comment> comment) {

    this.value = value;
    this.userData = userData;
    this.created = created;
    this.modified = modified;
    this.createdBy = createdBy;
    this.modifiedBy = modifiedBy;
    this.comment = comment;

    try {
        this.random = SecureRandom.getInstanceStrong();
    } catch (NoSuchAlgorithmException e) {
        throw new RuntimeException("Failed to instantiate random number generator", e);
    }
}
 
開發者ID:schibsted,項目名稱:strongbox,代碼行數:24,代碼來源:EncryptionPayload.java

示例2: testAddRemove_SingleInstance

import java.security.SecureRandom; //導入方法依賴的package包/類
@Test
public void testAddRemove_SingleInstance() throws InterruptedException, NoSuchAlgorithmException {
    final String name = "testAddNegative_SingleInstance";

    RedissonClient r = BaseTest.createInstance();
    RSortedSet<Integer> map = r.getSortedSet(name);
    map.clear();
    int length = 1000;
    for (int i = 0; i < length; i++) {
        map.add(i);
    }

    final AtomicInteger counter = new AtomicInteger(length);
    final Random rnd = SecureRandom.getInstanceStrong();
    testSingleInstanceConcurrency(length, rc -> {
        RSortedSet<Integer> set = rc.getSortedSet(name);
        int c = counter.incrementAndGet();
        Assert.assertTrue(set.add(c));
        set.remove(rnd.nextInt(length));
    });

    Assert.assertEquals(counter.get(), length*2);
    
    Integer prevVal = null;
    for (Integer val : map) {
        if (prevVal == null) {
            prevVal = val;
            continue;
        }
        if (val < prevVal) {
            Assert.fail();
        }
    }
    
    r.shutdown();
}
 
開發者ID:qq1588518,項目名稱:JRediClients,代碼行數:37,代碼來源:ConcurrentRedissonSortedSetTest.java

示例3: getSecureRandom

import java.security.SecureRandom; //導入方法依賴的package包/類
private static SecureRandom getSecureRandom(boolean strong) {
    if (!strong) {
        return new SecureRandom();
    }

    try {
        return SecureRandom.getInstanceStrong();
    } catch (NoSuchAlgorithmException ex) {
        throw new RuntimeCryptoException(
                "could not get strong SecureRandom: " + ex.getMessage());
    }
}
 
開發者ID:xipki,項目名稱:xitk,代碼行數:13,代碼來源:SecurityFactoryImpl.java

示例4: generateToken

import java.security.SecureRandom; //導入方法依賴的package包/類
/**
 * Generate a strong random 16 byte token using the system provided {@link SecureRandom}.
 *
 * @return a random 16 byte token
 */
static byte[] generateToken() {

  try {
    SecureRandom sr = SecureRandom.getInstanceStrong();
    byte[] token = new byte[16];
    sr.nextBytes(token);
    return token;
  } catch (NoSuchAlgorithmException nsa) {
    throw new InterledgerRuntimeException("Could not generate token", nsa);
  }
}
 
開發者ID:hyperledger,項目名稱:quilt,代碼行數:17,代碼來源:PskContext.java

示例5: seed

import java.security.SecureRandom; //導入方法依賴的package包/類
/**
 * Constructs an instance of the header with a randomly generated value.
 *
 * @return new nonce header
 */
public static PskNonceHeader seed() {
  try {
    SecureRandom sr = SecureRandom.getInstanceStrong();
    byte[] nonce = new byte[16];
    sr.nextBytes(nonce);
    return new PskNonceHeader(nonce);
  } catch (NoSuchAlgorithmException nsa) {
    throw new InterledgerRuntimeException("Could not generate secure nonce", nsa);
  }
}
 
開發者ID:hyperledger,項目名稱:quilt,代碼行數:16,代碼來源:PskNonceHeader.java

示例6: test256bitKey

import java.security.SecureRandom; //導入方法依賴的package包/類
@Test
public final void test256bitKey()
    throws NoSuchAlgorithmException, NoSuchPaddingException, InvalidKeyException,
    InvalidAlgorithmParameterException, IllegalBlockSizeException, BadPaddingException {

  SecureRandom sr = SecureRandom.getInstanceStrong();
  byte[] nonce = new byte[16];
  sr.nextBytes(nonce);

  KeyGenerator keygen = KeyGenerator.getInstance("AES");
  keygen.init(256);
  byte[] key = keygen.generateKey().getEncoded();

  byte[] data = new byte[256];
  sr.nextBytes(data);

  Cipher cipher = Cipher.getInstance("AES/GCM/PKCS5Padding");
  GCMParameterSpec paramSpec = new GCMParameterSpec(128, nonce);

  try {
    cipher.init(Cipher.ENCRYPT_MODE, new SecretKeySpec(key, "AES"), paramSpec);
    cipher.doFinal(data);
  } catch (InvalidKeyException e) {
    throw new InterledgerRuntimeException("Error loading 256bit key. "
        + "Likley cause is missing Unlimited Strength Jurisdiction Policy Files.", e);
  }

}
 
開發者ID:hyperledger,項目名稱:quilt,代碼行數:29,代碼來源:Aes256BitKeysizeTest.java

示例7: createSecureRandom

import java.security.SecureRandom; //導入方法依賴的package包/類
private static Random createSecureRandom() {
  try {
    return SecureRandom.getInstanceStrong();
  } catch (NoSuchAlgorithmException nae) {
    LOGGER.warn("Couldn't create strong secure random generator; reason: {}.", nae.getMessage());
    return new SecureRandom();
  }
}
 
開發者ID:springuni,項目名稱:springuni-particles,代碼行數:9,代碼來源:RandomUtil.java

示例8: SecureRandomEntropySource

import java.security.SecureRandom; //導入方法依賴的package包/類
public SecureRandomEntropySource() {
    try {
        this.secureRandom = SecureRandom.getInstanceStrong();
        /*
         * Right after the SecureRandom constructor, perform a single nextBytes with some small numBytes > 0
         * and disregard the result (even though 0 should do if a Vulcan implemented the spec), then setSeed()
         * with whatever unpredictable data at hand, then use nextBytes.
         *
         * https://crypto.stackexchange.com/a/51222/44838
         */
        secureRandom.nextBytes(new byte[4]);
    } catch (NoSuchAlgorithmException e) {
        throw new IllegalStateException("could not get strong secure random instace", e);
    }
}
 
開發者ID:patrickfav,項目名稱:dice,代碼行數:16,代碼來源:SecureRandomEntropySource.java

示例9: main

import java.security.SecureRandom; //導入方法依賴的package包/類
public static void main(final String[] argv) throws NoSuchAlgorithmException, IOException {
    final NetworkParameters params = new MainNetParams();
    final LocalTransactionSigner signer = new LocalTransactionSigner();
    final SecureRandom secureRandom = SecureRandom.getInstanceStrong();
    final ECKey key = new ECKey(secureRandom);
    final KeyBag bag = new KeyBag() {
        @Override
        public ECKey findKeyFromPubHash(byte[] pubkeyHash) {
            return key;
        }

        @Override
        public ECKey findKeyFromPubKey(byte[] pubkey) {
            return key;
        }

        @Override
        public RedeemData findRedeemDataFromScriptHash(byte[] scriptHash) {
            return null;
        }

    };

    // Generate a fictional output transaction we take values from, and
    // an input transaction for the test case

    final Transaction outputTransaction = new Transaction(params);
    final Transaction inputTransaction = new Transaction(params);
    final TransactionOutput output = new TransactionOutput(params, inputTransaction, Coin.ZERO, key.toAddress(params));

    inputTransaction.addOutput(output);
    outputTransaction.addInput(output);
    outputTransaction.addOutput(Coin.ZERO, new ECKey(secureRandom).toAddress(params));

    addOutputs(outputTransaction, bag);

    // Sign the transaction
    final ProposedTransaction proposedTransaction = new ProposedTransaction(outputTransaction);
    signer.signInputs(proposedTransaction, bag);
    final TransactionInput input = proposedTransaction.partialTx.getInput(0);

    input.verify(output);
    input.getScriptSig().correctlySpends(outputTransaction, 0, output.getScriptPubKey(),
        EnumSet.of(Script.VerifyFlag.DERSIG, Script.VerifyFlag.P2SH));

    final Script scriptSig = input.getScriptSig();
    final TransactionSignature signature = TransactionSignature.decodeFromBitcoin(scriptSig.getChunks().get(0).data, true, false);

    // First output a conventional low-S transaction with the LOW_S flag, for the tx_valid.json set
    System.out.println("[\"A transaction with a low-S signature.\"],");
    System.out.println("[[[\""
        + inputTransaction.getHashAsString() + "\", "
        + output.getIndex() + ", \""
        + scriptToString(output.getScriptPubKey()) + "\"]],\n"
        + "\"" + Utils.HEX.encode(proposedTransaction.partialTx.unsafeBitcoinSerialize()) + "\", \""
        + Script.VerifyFlag.P2SH.name() + "," + Script.VerifyFlag.LOW_S.name() + "\"],");

    final BigInteger highS = HIGH_S_DIFFERENCE.subtract(signature.s);
    final TransactionSignature highSig = new TransactionSignature(signature.r, highS);
    input.setScriptSig(new ScriptBuilder().data(highSig.encodeToBitcoin()).data(scriptSig.getChunks().get(1).data).build());
    input.getScriptSig().correctlySpends(outputTransaction, 0, output.getScriptPubKey(),
        EnumSet.of(Script.VerifyFlag.P2SH));

    // A high-S transaction without the LOW_S flag, for the tx_valid.json set
    System.out.println("[\"A transaction with a high-S signature.\"],");
    System.out.println("[[[\""
        + inputTransaction.getHashAsString() + "\", "
        + output.getIndex() + ", \""
        + scriptToString(output.getScriptPubKey()) + "\"]],\n"
        + "\"" + Utils.HEX.encode(proposedTransaction.partialTx.unsafeBitcoinSerialize()) + "\", \""
        + Script.VerifyFlag.P2SH.name() + "\"],");

    // Lastly a conventional high-S transaction with the LOW_S flag, for the tx_invalid.json set
    System.out.println("[\"A transaction with a high-S signature.\"],");
    System.out.println("[[[\""
        + inputTransaction.getHashAsString() + "\", "
        + output.getIndex() + ", \""
        + scriptToString(output.getScriptPubKey()) + "\"]],\n"
        + "\"" + Utils.HEX.encode(proposedTransaction.partialTx.unsafeBitcoinSerialize()) + "\", \""
        + Script.VerifyFlag.P2SH.name() + "," + Script.VerifyFlag.LOW_S.name() + "\"],");
}
 
開發者ID:creativechain,項目名稱:creacoinj,代碼行數:82,代碼來源:GenerateLowSTests.java

示例10: initializeRandom

import java.security.SecureRandom; //導入方法依賴的package包/類
/**
 * Initializes the random source.
 *
 * @throws NoSuchAlgorithmException
 *             this should not happen.
 */
@PostConstruct
public void initializeRandom() throws NoSuchAlgorithmException {

    random = SecureRandom.getInstanceStrong();
}
 
開發者ID:trajano,項目名稱:app-ms,代碼行數:12,代碼來源:TokenGenerator.java


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