JAVA DES+Base64加密解密工具类
程序员文章站
2022-03-12 19:39:57
...
这里简单记录一下des加密工具类,可直接使用
加密原理:
DES 使用一个 56 位的**以及附加的 8 位奇偶校验位,产生最大 64 位的分组大小。这是一个迭代的分组密码,使用称为 Feistel 的技术,其中将加密的文本块分成两半。使用子**对其中一半应用循环功能,然后将输出与另一半进行"异或"运算;接着交换这两半,这一过程会继续下去,但最后一个循环不交换。DES 使用 16 个循环,使用异或,置换,代换,移位操作四种基本运算。
import java.security.Key;
import javax.crypto.Cipher;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;
import org.apache.commons.codec.binary.Base64;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class DesUtils {
private static Logger logger = LoggerFactory.getLogger(DesUtils.class);
private static Key key;
private static String KEY_STR = "12345678";//注意这里长度要8位
static {
try {
DESKeySpec keySpec = new DESKeySpec(KEY_STR.getBytes("utf-8"));
SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
key = keyFactory.generateSecret(keySpec);
//另一种生成key方式
//KeyGenerator gengrator = KeyGenerator.getInstance("DES");
//gengrator.init(new SecureRandom(KEY_STR.getBytes()));
//key = gengrator.generateKey();
} catch (Exception e) {
logger.error(e.getMessage(), e);
}
}
/* 2、对字符串进行DES加密,返回BASE64编码的加密字符串 */
public static String encrypt(String src/* 明文 */) {
try {
byte[] src_byte = src.getBytes("UTF-8");
Cipher cipher = Cipher.getInstance("DES");
cipher.init(Cipher.ENCRYPT_MODE, key);
byte[] final_byte = cipher.doFinal(src_byte);
return Base64.encodeBase64URLSafeString(final_byte);
} catch (Exception e) {
throw new RuntimeException(e.getMessage(), e);
}
}
/* 3、对BASE64编码的加密字符串进行解密,返回解密后的字符串 */
public static String decrypt(String src/* 密文 */) {
try {
byte[] src_byte = Base64.decodeBase64(src);
Cipher cipher = Cipher.getInstance("DES");
cipher.init(Cipher.DECRYPT_MODE, key);
byte[] decrypt_byte = cipher.doFinal(src_byte);
return new String(decrypt_byte, "UTF-8");
} catch (Exception e) {
throw new RuntimeException(e.getMessage(), e);
}
}
public static void main(String[] args) throws Exception {
String string = DesUtils.encrypt("123123");
System.out.println(string);
System.out.println(DesUtils.decrypt(string));
}
}
执行结果:
上一篇: PHP memcache在微信公众平台的应用方法示例
下一篇: PHP DES加密解密封装类