aQute.libg.cryptography.RSA Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of bndlib Show documentation
Show all versions of bndlib Show documentation
A Swiss Army Knife for OSGi
package aQute.libg.cryptography;
import java.math.*;
import java.security.*;
import java.security.interfaces.*;
import java.security.spec.*;
import aQute.libg.tuple.*;
public class RSA {
final static String ALGORITHM = "RSA";
final static KeyFactory factory = getKeyFactory();
static private KeyFactory getKeyFactory() {
try {
return KeyFactory.getInstance(ALGORITHM);
} catch (Exception e) {
// built in
}
return null;
}
public static RSAPrivateKey create(RSAPrivateKeySpec keyspec) throws InvalidKeySpecException {
return (RSAPrivateKey) factory.generatePrivate(keyspec);
}
public static RSAPublicKey create(RSAPublicKeySpec keyspec) throws InvalidKeySpecException {
return (RSAPublicKey) factory.generatePrivate(keyspec);
}
public static RSAPublicKey createPublic(BigInteger m, BigInteger e) throws InvalidKeySpecException {
return create( new RSAPublicKeySpec(m,e));
}
public static RSAPrivateKey createPrivate(BigInteger m, BigInteger e) throws InvalidKeySpecException {
return create( new RSAPrivateKeySpec(m,e));
}
public static Pair generate() throws NoSuchAlgorithmException {
KeyPairGenerator kpg = KeyPairGenerator.getInstance(ALGORITHM);
KeyPair keypair = kpg.generateKeyPair();
return new Pair( (RSAPrivateKey) keypair.getPrivate(), (RSAPublicKey) keypair.getPublic());
}
}