use of java.security.spec.MGF1ParameterSpec in project j2objc by google.
the class MGF1ParameterSpecTest method testMGF1ParameterSpec01.
//
// Tests
//
/**
* Test #1 for <code>MGF1ParameterSpec</code> constructor<br>
* Assertion: constructs new <code>MGF1ParameterSpec</code>
* object using valid parameter
*/
public final void testMGF1ParameterSpec01() {
try {
MGF1ParameterSpec pgf = new MGF1ParameterSpec(testAlgName);
assertNotNull(pgf);
assertTrue(pgf instanceof MGF1ParameterSpec);
} catch (Exception e) {
fail("Unexpected exception: " + e);
}
}
use of java.security.spec.MGF1ParameterSpec in project jdk8u_jdk by JetBrains.
the class TestOAEPPadding method testEncryptDecrypt.
private static void testEncryptDecrypt(OAEPParameterSpec spec, int dataLength) throws Exception {
System.out.print("Testing OAEP with hash ");
if (spec != null) {
System.out.print(spec.getDigestAlgorithm() + " and MGF " + ((MGF1ParameterSpec) spec.getMGFParameters()).getDigestAlgorithm());
} else {
System.out.print("Default");
}
System.out.println(", " + dataLength + " bytes");
Cipher c = Cipher.getInstance("RSA/ECB/OAEPPadding", cp);
if (spec != null) {
c.init(Cipher.ENCRYPT_MODE, publicKey, spec);
} else {
c.init(Cipher.ENCRYPT_MODE, publicKey);
}
byte[] data = new byte[dataLength];
byte[] enc = c.doFinal(data);
if (spec != null) {
c.init(Cipher.DECRYPT_MODE, privateKey, spec);
} else {
c.init(Cipher.DECRYPT_MODE, privateKey);
}
byte[] dec = c.doFinal(enc);
if (Arrays.equals(data, dec) == false) {
throw new Exception("Data does not match");
}
}
use of java.security.spec.MGF1ParameterSpec in project robovm by robovm.
the class CipherSpi method initFromSpec.
private void initFromSpec(OAEPParameterSpec pSpec) throws NoSuchPaddingException {
MGF1ParameterSpec mgfParams = (MGF1ParameterSpec) pSpec.getMGFParameters();
Digest digest = DigestFactory.getDigest(mgfParams.getDigestAlgorithm());
if (digest == null) {
throw new NoSuchPaddingException("no match on OAEP constructor for digest algorithm: " + mgfParams.getDigestAlgorithm());
}
cipher = new OAEPEncoding(new RSABlindedEngine(), digest, ((PSource.PSpecified) pSpec.getPSource()).getValue());
paramSpec = pSpec;
}
use of java.security.spec.MGF1ParameterSpec in project XobotOS by xamarin.
the class JCERSACipher method initFromSpec.
private void initFromSpec(OAEPParameterSpec pSpec) throws NoSuchPaddingException {
MGF1ParameterSpec mgfParams = (MGF1ParameterSpec) pSpec.getMGFParameters();
Digest digest = JCEDigestUtil.getDigest(mgfParams.getDigestAlgorithm());
if (digest == null) {
throw new NoSuchPaddingException("no match on OAEP constructor for digest algorithm: " + mgfParams.getDigestAlgorithm());
}
cipher = new OAEPEncoding(new RSABlindedEngine(), digest, ((PSource.PSpecified) pSpec.getPSource()).getValue());
paramSpec = pSpec;
}
use of java.security.spec.MGF1ParameterSpec in project XobotOS by xamarin.
the class JCERSACipher method engineInit.
protected void engineInit(int opmode, Key key, AlgorithmParameterSpec params, SecureRandom random) throws InvalidKeyException, InvalidAlgorithmParameterException {
CipherParameters param;
if (params == null || params instanceof OAEPParameterSpec) {
if (key instanceof RSAPublicKey) {
if (privateKeyOnly) {
throw new InvalidKeyException("mode 1 requires RSAPrivateKey");
}
param = RSAUtil.generatePublicKeyParameter((RSAPublicKey) key);
} else if (key instanceof RSAPrivateKey) {
if (publicKeyOnly) {
throw new InvalidKeyException("mode 2 requires RSAPublicKey");
}
param = RSAUtil.generatePrivateKeyParameter((RSAPrivateKey) key);
} else {
throw new InvalidKeyException("unknown key type passed to RSA");
}
if (params != null) {
OAEPParameterSpec spec = (OAEPParameterSpec) params;
paramSpec = params;
if (!spec.getMGFAlgorithm().equalsIgnoreCase("MGF1") && !spec.getMGFAlgorithm().equals(PKCSObjectIdentifiers.id_mgf1.getId())) {
throw new InvalidAlgorithmParameterException("unknown mask generation function specified");
}
if (!(spec.getMGFParameters() instanceof MGF1ParameterSpec)) {
throw new InvalidAlgorithmParameterException("unkown MGF parameters");
}
Digest digest = JCEDigestUtil.getDigest(spec.getDigestAlgorithm());
if (digest == null) {
throw new InvalidAlgorithmParameterException("no match on digest algorithm: " + spec.getDigestAlgorithm());
}
MGF1ParameterSpec mgfParams = (MGF1ParameterSpec) spec.getMGFParameters();
Digest mgfDigest = JCEDigestUtil.getDigest(mgfParams.getDigestAlgorithm());
if (mgfDigest == null) {
throw new InvalidAlgorithmParameterException("no match on MGF digest algorithm: " + mgfParams.getDigestAlgorithm());
}
cipher = new OAEPEncoding(new RSABlindedEngine(), digest, mgfDigest, ((PSource.PSpecified) spec.getPSource()).getValue());
}
} else {
throw new IllegalArgumentException("unknown parameter type.");
}
if (!(cipher instanceof RSABlindedEngine)) {
if (random != null) {
param = new ParametersWithRandom(param, random);
} else {
param = new ParametersWithRandom(param, new SecureRandom());
}
}
switch(opmode) {
case Cipher.ENCRYPT_MODE:
case Cipher.WRAP_MODE:
cipher.init(true, param);
break;
case Cipher.DECRYPT_MODE:
case Cipher.UNWRAP_MODE:
cipher.init(false, param);
break;
default:
throw new InvalidParameterException("unknown opmode " + opmode + " passed to RSA");
}
}
Aggregations