
spring.turbo.util.crypto.DSAKeyPairFactories Maven / Gradle / Ivy
package spring.turbo.util.crypto;
import spring.turbo.util.Asserts;
import spring.turbo.util.HexUtils;
import spring.turbo.util.StringUtils;
import java.security.*;
import java.security.interfaces.DSAPrivateKey;
import java.security.interfaces.DSAPublicKey;
import java.security.spec.PKCS8EncodedKeySpec;
import java.security.spec.X509EncodedKeySpec;
import java.util.Base64;
/**
* {@link DSAKeyPair} 创建工具
*
* @author 应卓
* @since 3.3.1
*/
public final class DSAKeyPairFactories {
public static final String ALG_DSA = "DSA";
/**
* 私有构造方法
*/
private DSAKeyPairFactories() {
super();
}
/**
* 创建实例
*
* @return 密钥对
*/
public static DSAKeyPair create() {
return create(1024);
}
/**
* 创建实例
*
* @param keySize keySize
* @return 密钥对
*/
public static DSAKeyPair create(int keySize) {
try {
var generator = KeyPairGenerator.getInstance(ALG_DSA);
generator.initialize(keySize);
var keyPair = generator.generateKeyPair();
return new Pair((DSAPublicKey) keyPair.getPublic(), (DSAPrivateKey) keyPair.getPrivate());
} catch (NoSuchAlgorithmException e) {
throw new IllegalArgumentException(e.getMessage(), e);
}
}
/**
* 从文本中读取密钥对
*
* @param publicKeyString 公钥。Base64HexEncoded
* @param privateKeyString 私钥。Base64HexEncoded
* @return 密钥对
*/
public static DSAKeyPair createFromBased64EncodedString(String publicKeyString, String privateKeyString) {
var decoder = Base64.getDecoder();
publicKeyString = StringUtils.removeAllWhitespaces(publicKeyString);
privateKeyString = StringUtils.removeAllWhitespaces(privateKeyString);
var publicKeyBytes = decoder.decode(publicKeyString);
var privateKeyBytes = decoder.decode(privateKeyString);
return createFromBytes(publicKeyBytes, privateKeyBytes);
}
/**
* 从文本中读取密钥对
*
* @param publicKeyString 公钥。HexEncoded
* @param privateKeyString 私钥。HexEncoded
* @return 密钥对
*/
public static DSAKeyPair createFromHexEncodedString(String publicKeyString, String privateKeyString) {
publicKeyString = StringUtils.removeAllWhitespaces(publicKeyString);
privateKeyString = StringUtils.removeAllWhitespaces(privateKeyString);
var publicKeyBytes = HexUtils.decode(publicKeyString);
var privateKeyBytes = HexUtils.decode(privateKeyString);
return createFromBytes(publicKeyBytes, privateKeyBytes);
}
/**
* 从字节数组中读取密钥对
*
* @param publicKeyBytes 公钥。HexEncoded
* @param privateKeyBytes 私钥。HexEncoded
* @return 密钥对
*/
public static DSAKeyPair createFromBytes(byte[] publicKeyBytes, byte[] privateKeyBytes) {
try {
var keyFactory = KeyFactory.getInstance(ALG_DSA);
var publicKeySpec = new X509EncodedKeySpec(publicKeyBytes);
var pub = keyFactory.generatePublic(publicKeySpec);
var privateKeySpec = new PKCS8EncodedKeySpec(privateKeyBytes);
var pri = keyFactory.generatePrivate(privateKeySpec);
return new Pair((DSAPublicKey) pub, (DSAPrivateKey) pri);
} catch (Exception e) {
throw new IllegalArgumentException(e.getMessage(), e);
}
}
/**
* 从JDK密钥对生成
*
* @param keyPair JDK密钥对
* @return 密钥对
*/
public static DSAKeyPair createFromJdkKeyPair(KeyPair keyPair) {
return new Pair(
(DSAPublicKey) keyPair.getPublic(),
(DSAPrivateKey) keyPair.getPrivate()
);
}
/**
* 从JDK密钥中生成
*
* @param publicKey 公钥
* @param privateKey 私钥
* @return 密钥对
*/
public static DSAKeyPair createFromJdkKeys(PublicKey publicKey, PrivateKey privateKey) {
return new Pair(
(DSAPublicKey) publicKey,
(DSAPrivateKey) privateKey
);
}
// -----------------------------------------------------------------------------------------------------------------
private record Pair(DSAPublicKey publicKey, DSAPrivateKey privateKey) implements DSAKeyPair {
Pair {
Asserts.notNull(publicKey, "publicKey is required");
Asserts.notNull(privateKey, "privateKey is required");
}
@Override
public DSAPublicKey getJdkPublicKey() {
return this.publicKey;
}
@Override
public DSAPrivateKey getJdkPrivateKey() {
return this.privateKey;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy