Spring Framework encryption extension. SimpleEncryptor supports property encryption via TextEncryptor, with optional use of spring-security-rsa RSA (PUBLIC and PRIVATE keys). RSA (PUBLIC and PRIVATE keys) can be deleted or cleared after TextEncryptor instantiation using the SimpleEncryptorFactoryBean.
SimpleEncryptor provides encryption support for property sources in Spring Boot Applications and plain old Spring.
-
Add the simple-encryptor dependency to your project (Maven Central):
compile("com.transempiric:simple-encryptor:1.0.0")
<dependency> <groupId>com.transempiric</groupId> <artifactId>simple-encryptor</artifactId> <version>1.0.0</version> <scope>compile</scope> </dependency>
-
Spring Boot property example:
@SpringBootApplication public class WebTemplateApplication { public static void main(String[] args) throws Exception { TextEncryptor rsaDecryptor = new SimpleEncryptorFactoryBean() .rsaDecryptor("classPath:local_enc_private_key.pem") .createInstance(); //TODO: Clean up and make use of the SimpleEncryptorFactoryBean. SimpleEncryptorPropertyResolver resolver = new SimpleEncryptorPropertyResolver(rsaDecryptor); SimpleEncryptorEnvironment env = new SimpleEncryptorEnvironment(SimpleEncryptorInterceptionMode.WRAPPER, resolver); new SpringApplicationBuilder() .environment(env) .sources(WebTemplateApplication.class) .run(args); } }
Encryptable properties will be enabled across the entire Spring Environment (This means any system property, environment property, command line argument, application.properties, yaml properties, and any other custom property sources can contain encrypted properties)
-
Spring Bean example for encryptors:
import com.transempiric.simpleEncryptor.SimpleEncryptorFactoryBean; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.security.crypto.encrypt.TextEncryptor; import static com.transempiric.simpleEncryptor.SimpleEncryptorFactoryBean.SIMPLE_ENCRYPTOR_SALT_PROPERTY_NAME; import static com.transempiric.simpleEncryptor.SimpleEncryptorFactoryBean.SIMPLE_ENCRYPTOR_SECRET_PROPERTY_NAME; @Configuration public class SimpleEncryptorConfigExample { @Bean public TextEncryptor rsaSimpleEncryptor() throws Exception { return new SimpleEncryptorFactoryBean() .rsaEncryptor("classPath:local_enc_public_key.pem") // .clearKeyFileContents(false) // .deleteKeyFiles(false) .createInstance(); } @Bean public TextEncryptor rsaSimpleDecryptor() throws Exception { return new SimpleEncryptorFactoryBean() .rsaDecryptor("classPath:local_enc_private_key.pem") // .clearKeyFileContents(true) // .deleteKeyFiles(true) .createInstance(); } // Required (Hex-encoded string): Inject System property -Dsimple.encryptor.secret=497349744150726F626C656D466F72596F75546F41736B // Optional (Hex-encoded string): Inject System property -Dsimple.encryptor.salt=456E63727970746F7273 @Bean public TextEncryptor hexEncodingSimpleEncryptor() throws Exception { return new SimpleEncryptorFactoryBean() .hexEncodingTextEncryptor( System.getProperty(SIMPLE_ENCRYPTOR_SECRET_PROPERTY_NAME), System.getProperty(SIMPLE_ENCRYPTOR_SALT_PROPERTY_NAME) ) .createInstance(); } @Bean public String spaceMonkey( TextEncryptor hexEncodingSimpleEncryptor, TextEncryptor rsaSimpleEncryptor, TextEncryptor rsaSimpleDecryptor ) { /* System.out.println("**************** SimpleEncryptorConfigExample Test *************************"); System.out.println(rsaSimpleEncryptor.encrypt("rupertDurden")); System.out.println(rsaSimpleEncryptor.encrypt("rupertDurden")); System.out.println(rsaSimpleDecryptor.decrypt(rsaSimpleEncryptor.encrypt("rupert"))); System.out.println(rsaSimpleDecryptor.decrypt(rsaSimpleEncryptor.encrypt("durden"))); System.out.println(hexEncodingSimpleEncryptor.encrypt("rupert")); System.out.println(hexEncodingSimpleEncryptor.encrypt("durden")); System.out.println(hexEncodingSimpleEncryptor.decrypt(hexEncodingSimpleEncryptor.encrypt("rupert"))); System.out.println(hexEncodingSimpleEncryptor.decrypt(hexEncodingSimpleEncryptor.encrypt("durden"))); System.out.println("**************** SimpleEncryptorConfigExample Test *************************"); */ return "SpaceMonkey"; } }
Dave Syer for spring-security-rsa and spring-cloud-config.
Ulises Bocchio for jasypt-spring-boot.