本文实例讲述了java实现的AES加密算法。分享给大家供大家参考,具体如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
|
import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
import android.util.Base64;
/**
* @author vipin.cb , vipin.cb@experionglobal.com <br>
* Sep 27, 2013, 5:18:34 PM <br>
* Package:- <b>com.veebow.util</b> <br>
* Project:- <b>Veebow</b>
* <p>
*/
public class AESCrypt {
private final Cipher cipher;
private final SecretKeySpec key;
private AlgorithmParameterSpec spec;
public static final String SEED_16_CHARACTER = "U1MjU1M0FDOUZ.Qz" ;
public AESCrypt() throws Exception {
// hash password with SHA-256 and crop the output to 128-bit for key
MessageDigest digest = MessageDigest.getInstance( "SHA-256" );
digest.update(SEED_16_CHARACTER.getBytes( "UTF-8" ));
byte [] keyBytes = new byte [ 32 ];
System.arraycopy(digest.digest(), 0 , keyBytes, 0 , keyBytes.length);
cipher = Cipher.getInstance( "AES/CBC/PKCS7Padding" );
key = new SecretKeySpec(keyBytes, "AES" );
spec = getIV();
}
public AlgorithmParameterSpec getIV() {
byte [] iv = { 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , };
IvParameterSpec ivParameterSpec;
ivParameterSpec = new IvParameterSpec(iv);
return ivParameterSpec;
}
public String encrypt(String plainText) throws Exception {
cipher.init(Cipher.ENCRYPT_MODE, key, spec);
byte [] encrypted = cipher.doFinal(plainText.getBytes( "UTF-8" ));
String encryptedText = new String(Base64.encode(encrypted,
Base64.DEFAULT), "UTF-8" );
return encryptedText;
}
public String decrypt(String cryptedText) throws Exception {
cipher.init(Cipher.DECRYPT_MODE, key, spec);
byte [] bytes = Base64.decode(cryptedText, Base64.DEFAULT);
byte [] decrypted = cipher.doFinal(bytes);
String decryptedText = new String(decrypted, "UTF-8" );
return decryptedText;
}
}
|
希望本文所述对大家java程序设计有所帮助。