Merge branch 'master' of https://e.coding.net/boss-01/ydool/rd
This commit is contained in:
commit
28ef580019
|
@ -0,0 +1,87 @@
|
|||
package com.ydool.boot.api.util;
|
||||
|
||||
import org.apache.commons.codec.DecoderException;
|
||||
import org.apache.commons.codec.binary.Hex;
|
||||
import org.springframework.util.ObjectUtils;
|
||||
|
||||
import javax.crypto.BadPaddingException;
|
||||
import javax.crypto.Cipher;
|
||||
import javax.crypto.IllegalBlockSizeException;
|
||||
import javax.crypto.spec.SecretKeySpec;
|
||||
import java.io.UnsupportedEncodingException;
|
||||
|
||||
/**
|
||||
* Created with IntelliJ IDEA.
|
||||
* User: liuj
|
||||
* Date: 2020/11/18
|
||||
* Time: 13:27
|
||||
* Description: No Description
|
||||
*/
|
||||
public class CodecUtils {
|
||||
|
||||
private static Cipher encryptCipher; // 加密cipher
|
||||
private static Cipher decryptChipher; // 解密chipher
|
||||
private static final String ENCODING = "UTF-8";
|
||||
|
||||
static {
|
||||
try {
|
||||
encryptCipher = Cipher.getInstance("AES");
|
||||
decryptChipher = Cipher.getInstance("AES");
|
||||
encryptCipher.init(Cipher.ENCRYPT_MODE, generateAESKey("ydool", ENCODING));
|
||||
decryptChipher.init(Cipher.DECRYPT_MODE, generateAESKey("ydool", ENCODING));
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
|
||||
public static SecretKeySpec generateAESKey(final String key, final String encoding) {
|
||||
try {
|
||||
final byte[] finalKey = new byte[16];
|
||||
int i = 0;
|
||||
for (byte b : key.getBytes(encoding))
|
||||
finalKey[i++ % 16] ^= b;
|
||||
return new SecretKeySpec(finalKey, "AES");
|
||||
} catch (UnsupportedEncodingException e) {
|
||||
throw new RuntimeException(e);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 加密算法
|
||||
*
|
||||
* @param encryptString
|
||||
* @return
|
||||
*/
|
||||
public static String encrypt(String encryptString) {
|
||||
try {
|
||||
if(encryptString == null) return null;
|
||||
return new String(Hex.encodeHex(encryptCipher.doFinal(encryptString.getBytes(ENCODING)))).toUpperCase();
|
||||
} catch (BadPaddingException e) {
|
||||
throw new RuntimeException(e);
|
||||
} catch (UnsupportedEncodingException e) {
|
||||
throw new RuntimeException(e);
|
||||
} catch (IllegalBlockSizeException e) {
|
||||
throw new RuntimeException(e);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 解密算法
|
||||
*
|
||||
* @param decryptString
|
||||
* @return
|
||||
*/
|
||||
public static String decrypt(String decryptString) {
|
||||
|
||||
if(ObjectUtils.isEmpty(decryptString)) return null;
|
||||
try {
|
||||
return new String(decryptChipher.doFinal(Hex.decodeHex(decryptString.toCharArray())));
|
||||
} catch (DecoderException nspe) {
|
||||
throw new RuntimeException(nspe);
|
||||
} catch (BadPaddingException nsae) {
|
||||
throw new RuntimeException(nsae);
|
||||
} catch (IllegalBlockSizeException ike) {
|
||||
throw new RuntimeException(ike);
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue