字符串,byte[],文件等对象的加密和解密工具集合,包含了多种加密方案。
加密类型 | 摘要 | 相关方法 |
---|---|---|
简单加密 | 换一种编码格式 | Base64Util |
单向加密 | 只能加密,不能解密 | MD5Util、SHAUtil |
对称加密 | 使用相同的秘钥加密和解密 | AESUtil、DESUtil |
非对称加密 | 分公钥和私钥,一个加密,另一个解密 | RSAUtil |
方法 | 摘要 |
---|---|
String base64EncodeStr(String str) | 编码 |
String base64DecodedStr(String str) | 解码 |
单元测试:
System.out.println("base64");
// base64 字符串加密解密测试
assertEquals("R2NzU2xvb3DkuK3mloc=\n", Base64Util.base64EncodeStr("GcsSloop中文"));
assertEquals("GcsSloop中文", Base64Util.base64DecodedStr("R2NzU2xvb3DkuK3mloc=\n"));
方法 | 摘要 |
---|---|
String md5(String string) | 加密字符串 |
String md5(String string, String slat) | 加密字符串同时加盐 |
String md5(String string, int times) | 多次加密 |
String md5(File file) | 计算文件的md5数值 |
单元测试:
System.out.println("md5");
// MD5 字符串加密测试
assertEquals("", MD5Util.md5(""));
assertEquals("386d3ff3fa6def1ec307428e885e03a1", MD5Util.md5("GcsSloop中文"));
assertEquals("fd01aa74bb73bbdb094bae28a558c6d1", MD5Util.md5("GcsSloop中文", "salt"));
// MD5 多次加密测试
assertEquals("GcsSloop中文", MD5Util.md5("GcsSloop中文", 0));
assertEquals("386d3ff3fa6def1ec307428e885e03a1", MD5Util.md5("GcsSloop中文", 1));
assertEquals("2d9fdd834c5c852fa2f946b670f3731f", MD5Util.md5("GcsSloop中文", 2));
assertEquals("211dd7a16d5a01df756278cea9a38d53", MD5Util.md5("GcsSloop中文", 3));
// MD5 文件md5测试
File file = new File("./Encrypt/Test/demo" +
".flv");
assertEquals("a4e592e6160e0102e7ecc4ab6117b700", MD5Util.md5(file));
方法 | 摘要 |
---|---|
String sha(String string, String type) | 加密 |
单元测试:
System.out.println("sha");
// des 字符串加密解密测试
String source = "GcsSloop中文";
assertEquals("b9dd1d754ee3ac16dc584b8fd4655ca581a0637eab8ff25128b0a522372e7233",
SHAUtil.sha(source, null));
assertEquals("34d44835ce4cc4d7ecf66428e49273bf02f748d7213be24c767c5f4f",
SHAUtil.sha(source, SHAUtil.SHA224));
assertEquals("b9dd1d754ee3ac16dc584b8fd4655ca581a0637eab8ff25128b0a522372e7233",
SHAUtil.sha(source, SHAUtil.SHA256));
assertEquals("2e3c27201c21b06b01289ebef09c9c36e752ca6a5b6425ca7b2501b4baaed29876954ca710b7e75c80b7b542df28fde6",
SHAUtil.sha(source, SHAUtil.SHA384));
assertEquals("bc3f55fcb03272ee166d7804ccba348ffba05ddce08bf3fab719fa2c97c8dc71993fc9524e21b8fee9491aafc0b309ebca797163bca45ece7c3dd73dae3698ee",
SHAUtil.sha(source, SHAUtil.SHA512));
方法 | 摘要 |
---|---|
String aes(String content, String password, int type) | 加密/解密 |
单元测试:
System.out.println("aes");
// aes 字符串加密解密测试
String source = "GcsSloop中文";
String key = "1234567890123456";
System.out.println("原数据 = " + source);
String aesStr = AESUtil.aes(source, key, Cipher.ENCRYPT_MODE);
System.out.println("加密后 = " + aesStr);
String result = AESUtil.aes(aesStr, key, Cipher.DECRYPT_MODE);
System.out.println("解密后 = " + result);
assertEquals(source, result);
方法 | 摘要 |
---|---|
String des(String content, String password, int type) | 加密/解密 |
单元测试:
System.out.println("des");
// des 字符串加密解密测试
String source = "GcsSloop中文";
String key = "1234567890123456";
System.out.println("原数据 = " + source);
String aesStr = DESUtil.des(source, key, Cipher.ENCRYPT_MODE);
System.out.println("加密后 = " + aesStr);
String result = DESUtil.des(aesStr, key, Cipher.DECRYPT_MODE);
System.out.println("解密后 = " + result);
assertEquals(source, result);
方法 | 摘要 |
---|---|
Map<String, Object> getKeyPair() | 随机获取密钥(公钥和私钥), 客户端公钥加密,服务器私钥解密 |
String getKey(Map<String, Object> keyMap, boolean isPublicKey) | 获取公钥/私钥(true:获取公钥,false:获取私钥) |
String sign(byte[] data, String privateKey) | 获取数字签名 |
boolean verify(byte[] data, String publicKey, String sign) | 数字签名校验 |
byte[] rsa(byte[] data, String string, int type) | Rsa加密/解密(一般情况下,公钥加密私钥解密) |
单元测试:
System.out.println("rsa");
// des 字符串加密解密测试
byte[] data = "GcsSloop中文".getBytes();
// 密钥与数字签名获取
Map<String, Object> keyMap = RSAUtil.getKeyPair();
String publicKey = RSAUtil.getKey(keyMap, true);
System.out.println("rsa获取公钥: " + publicKey);
String privateKey = RSAUtil.getKey(keyMap, false);
System.out.println("rsa获取私钥: " + privateKey);
// 公钥加密私钥解密
byte[] rsaPublic =
RSAUtil.rsa(data, publicKey, RSAUtil.RSA_PUBLIC_ENCRYPT);
System.out.println("rsa公钥加密: " + new String(rsaPublic));
System.out.println("rsa私钥解密: " + new String(
RSAUtil.rsa(rsaPublic, privateKey, RSAUtil.RSA_PRIVATE_DECRYPT)));
// 私钥加密公钥解密
byte[] rsaPrivate =
RSAUtil.rsa(data, privateKey, RSAUtil.RSA_PRIVATE_ENCRYPT);
System.out.println("rsa私钥加密: " + new String(rsaPrivate));
System.out.println("rsa公钥解密: " + new String(
RSAUtil.rsa(rsaPrivate, publicKey, RSAUtil.RSA_PUBLIC_DECRYPT)));
// 私钥签名及公钥签名校验
String signStr = RSAUtil.sign(rsaPrivate, privateKey);
System.out.println("rsa数字签名生成: " + signStr);
System.out.println("rsa数字签名校验: " + RSAUtil.verify(rsaPrivate, publicKey, signStr));
build.gradle
中添加上远程仓库:
allprojects {
repositories {
jcenter()
// 就是下面这一行
maven { url "http://lib.gcssloop.com/repository/gcssloop-central/" }
}
}
compile 'com.gcssloop.util:encrypt:1.0.0@aar'
热门源码