Last active
August 17, 2021 14:03
-
-
Save SimoneStefani/99052e8ce0550eb7725ca8681e4225c5 to your computer and use it in GitHub Desktop.
Example of AES encryption and decryption in Java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/** | |
* Code written by P. Gajland | |
* https://github.com/GaPhil | |
* | |
* IMPORTANT: | |
* This code is for educational and demonstrative purpose only. | |
* If you need to do serious encryption for "production" it is | |
* recommended to investigate more traditional libraries and | |
* gain some specific knowledge on cryptography and security. | |
*/ | |
import java.security.Key; | |
import javax.crypto.Cipher; | |
import sun.misc.BASE64Encoder; | |
import sun.misc.BASE64Decoder; | |
import javax.crypto.spec.SecretKeySpec; | |
public class AESenc { | |
private static final String ALGO = "AES"; | |
private static final byte[] keyValue = | |
new byte[]{'T', 'h', 'e', 'B', 'e', 's', 't', 'S', 'e', 'c', 'r', 'e', 't', 'K', 'e', 'y'}; | |
/** | |
* Encrypt a string with AES algorithm. | |
* | |
* @param data is a string | |
* @return the encrypted string | |
*/ | |
public static String encrypt(String data) throws Exception { | |
Key key = generateKey(); | |
Cipher c = Cipher.getInstance(ALGO); | |
c.init(Cipher.ENCRYPT_MODE, key); | |
byte[] encVal = c.doFinal(data.getBytes()); | |
return new BASE64Encoder().encode(encVal); | |
} | |
/** | |
* Decrypt a string with AES algorithm. | |
* | |
* @param encryptedData is a string | |
* @return the decrypted string | |
*/ | |
public static String decrypt(String encryptedData) throws Exception { | |
Key key = generateKey(); | |
Cipher c = Cipher.getInstance(ALGO); | |
c.init(Cipher.DECRYPT_MODE, key); | |
byte[] decordedValue = new BASE64Decoder().decodeBuffer(encryptedData); | |
byte[] decValue = c.doFinal(decordedValue); | |
return new String(decValue); | |
} | |
/** | |
* Generate a new encryption key. | |
*/ | |
private static Key generateKey() throws Exception { | |
return new SecretKeySpec(keyValue, ALGO); | |
} | |
} |
I am getting this exception when I run the same code in decryption process... please help!
Exception in thread "main" javax.crypto.IllegalBlockSizeException: Input length must be multiple of 16 when decrypting with padded cipher
at com.sun.crypto.provider.CipherCore.doFinal(CipherCore.java:934)
at com.sun.crypto.provider.CipherCore.doFinal(CipherCore.java:845)
at com.sun.crypto.provider.AESCipher.engineDoFinal(AESCipher.java:446)
at javax.crypto.Cipher.doFinal(Cipher.java:2165)
at ae1.Ae1.decrypt(Ae1.java:40)
at ae1.Ae1.main(Ae1.java:60)
C:\Users\apoor\AppData\Local\NetBeans\Cache\8.2\executor-snippets\run.xml:53: Java returned: 1
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
please how can i convert this code to php. i want to encrypte with php and decrypt with java