
com.kloudtek.kryptotek.jce.JCERSAPublicKey Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of kryptotek-core Show documentation
Show all versions of kryptotek-core Show documentation
Kryptotek provides an easy to use abstraction layer for cryptographic functions
The newest version!
/*
* Copyright (c) 2015 Kloudtek Ltd
*/
package com.kloudtek.kryptotek.jce;
import com.kloudtek.kryptotek.EncodedKey;
import com.kloudtek.kryptotek.InvalidKeyEncodingException;
import com.kloudtek.kryptotek.key.KeyType;
import com.kloudtek.kryptotek.key.RSAPublicKey;
import com.kloudtek.util.UnexpectedException;
import java.security.InvalidKeyException;
import java.security.KeyFactory;
import java.security.NoSuchAlgorithmException;
import java.security.PublicKey;
import java.security.spec.InvalidKeySpecException;
import java.security.spec.X509EncodedKeySpec;
/**
* Created by yannick on 18/12/2014.
*/
public class JCERSAPublicKey extends JCEPublicKey implements JCERSAKey, RSAPublicKey {
public JCERSAPublicKey() {
}
public JCERSAPublicKey(JCECryptoEngine cryptoEngine, PublicKey publicKey) {
super(cryptoEngine, publicKey);
}
public JCERSAPublicKey(JCECryptoEngine cryptoEngine, EncodedKey encodedKey) throws InvalidKeyException, InvalidKeyEncodingException {
super(cryptoEngine, encodedKey);
}
@Override
public KeyType getType() {
return KeyType.RSA_PUBLIC;
}
@Override
public EncodedKey getEncoded() {
return new EncodedKey(key.getEncoded(), EncodedKey.Format.X509);
}
@Override
public EncodedKey.Format getDefaultEncoding() {
return EncodedKey.Format.X509;
}
@Override
public void setDefaultEncoded(byte[] encodedKey) throws InvalidKeyException {
try {
KeyFactory kf = KeyFactory.getInstance("RSA");
key = kf.generatePublic(new X509EncodedKeySpec(encodedKey));
} catch (NoSuchAlgorithmException e) {
throw new UnexpectedException(e);
} catch (InvalidKeySpecException e) {
throw new InvalidKeyException(e);
}
}
@Override
public byte[] getDefaultEncoded() {
return key.getEncoded();
}
@Override
public String getJceCryptAlgorithm(boolean compatibilityMode) {
return JCECryptoEngine.getRSAEncryptionAlgorithm(compatibilityMode);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy