/*
 * Copyright 2011-2016 the original author or authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      https://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.springframework.security.crypto.keygen;

import java.security.SecureRandom;

A KeyGenerator that uses SecureRandom to generate byte array-based keys.

No specific provider is used for the SecureRandom, so the platform default will be used.

Author:Keith Donald
/** * A KeyGenerator that uses {@link SecureRandom} to generate byte array-based keys. * <p> * No specific provider is used for the {@code SecureRandom}, so the platform default will * be used. * * @author Keith Donald */
final class SecureRandomBytesKeyGenerator implements BytesKeyGenerator { private final SecureRandom random; private final int keyLength;
Creates a secure random key generator using the defaults.
/** * Creates a secure random key generator using the defaults. */
public SecureRandomBytesKeyGenerator() { this(DEFAULT_KEY_LENGTH); }
Creates a secure random key generator with a custom key length.
/** * Creates a secure random key generator with a custom key length. */
public SecureRandomBytesKeyGenerator(int keyLength) { this.random = new SecureRandom(); this.keyLength = keyLength; } public int getKeyLength() { return keyLength; } public byte[] generateKey() { byte[] bytes = new byte[keyLength]; random.nextBytes(bytes); return bytes; } private static final int DEFAULT_KEY_LENGTH = 8; }