@Test(expected = IllegalArgumentException.class) public void testWithNullForPrivateKey() throws CertificateException, NoSuchAlgorithmException, KeyStoreException, NoSuchProviderException, UnrecoverableEntryException, IOException { HybridCrypto hybridCrypto = new HybridCrypto(SecurityProviderConnectorFactory.getSecurityProviderConnector()); Certificates certificates = new Certificates(SecurityProviderConnectorFactory.getSecurityProviderConnector()); StringWriter stringWriter = new StringWriter(); ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); String id = "test"; char[] password = "******".toCharArray(); X509Certificate cert = certificates.create(id, password, stringWriter, byteArrayOutputStream); hybridCrypto.addRecipient("test", cert); String message = "I am hybrid encrypted!"; HybridEncrypted hybridEncrypted = hybridCrypto.build( message.getBytes(), new PrivateKeyExtractor() .extractPrivateKey( password, new ByteArrayInputStream(byteArrayOutputStream.toByteArray()))); HybridCrypto freshHybridCrypto = new HybridCrypto(SecurityProviderConnectorFactory.getSecurityProviderConnector()); byte[] decryptedMessage = freshHybridCrypto.decrypt(hybridEncrypted, id, null); Assert.assertArrayEquals(message.getBytes(), decryptedMessage); Signature signature = new Signature(SecurityProviderConnectorFactory.getSecurityProviderConnector()); Assert.assertTrue( signature.verify( hybridEncrypted.getEncryptedBody(), hybridEncrypted.getSignature(), cert.getPublicKey())); }
@Test public void test() { HybridCrypto hybridCrypto = new HybridCrypto(SecurityProviderConnectorFactory.getSecurityProviderConnector()); Certificates certificates = new Certificates(SecurityProviderConnectorFactory.getSecurityProviderConnector()); StringWriter stringWriter = new StringWriter(); ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); String id = "test"; char[] password = "******".toCharArray(); certificates.create(id, password, stringWriter, byteArrayOutputStream); String cert = stringWriter.toString(); StringReader stringReader = new StringReader(cert); hybridCrypto.addRecipient("test", stringReader); String message = "I am hybrid encrypted!"; HybridEncrypted hybridEncrypted = hybridCrypto.build( message.getBytes(), password, new ByteArrayInputStream(byteArrayOutputStream.toByteArray())); HybridCrypto freshHybridCrypto = new HybridCrypto(SecurityProviderConnectorFactory.getSecurityProviderConnector()); byte[] decryptedMessage = freshHybridCrypto.decrypt( hybridEncrypted, id, password, new ByteArrayInputStream(byteArrayOutputStream.toByteArray())); Assert.assertArrayEquals(message.getBytes(), decryptedMessage); Signature signature = new Signature(SecurityProviderConnectorFactory.getSecurityProviderConnector()); Assert.assertTrue( signature.verify( hybridEncrypted.getEncryptedBody(), hybridEncrypted.getSignature(), new StringReader(cert))); }