一个简单的加密工具,性能貌似不行,待优化
2019-10-18 08:41:32来源:博客园 阅读 ()
一个简单的加密工具,性能貌似不行,待优化
package com.kxvz.common.crypt;
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import java.io.ByteArrayOutputStream;
import java.security.SecureRandom;
import java.util.ArrayList;
import java.util.List;
import java.util.Random;
import java.util.zip.Deflater;
import java.util.zip.Inflater;
public class Xe {
private static final String HEX_NORMAL = "0123456789abcdef";
private static final String HEX_TMP = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
private static final int hexLen = 100;
private static final List<String> hexs = new ArrayList<>(hexLen);
static {
gen();
}
/**
* 加密 bin->en->hex->zip
*
* @param bytes
* @return
*/
public static byte[] en(byte[] bytes, byte[] pass) throws Exception {
long t1 = System.currentTimeMillis();
byte[] en = encrypt(bytes, pass);
long t2 = System.currentTimeMillis();
String hex = toHex(en);
long t3 = System.currentTimeMillis();
byte[] res = compress(hex.getBytes());
long t4 = System.currentTimeMillis();
System.out.println("En Time : encrypt: " + (t2 - t1) + " : toHex : " + (t3 - t2) + " : compress: " + (t4 - t3));
return res;
}
/**
* 解密 zip->hex->de->bin
*
* @param bytes
* @return
*/
public static byte[] de(byte[] bytes, byte[] pass) throws Exception {
byte[] unzip = uncompress(bytes);
byte[] hex = hexTo(new String(unzip));
return decrypt(hex, pass);
}
public static String enAndHex(byte[] bytes, byte[] pass) throws Exception {
byte[] res = en(bytes, pass);
return toHex(res);
}
public static byte[] deWithHex(String content, byte[] pass) throws Exception {
byte[] hex = hexTo(content);
return de(hex, pass);
}
private static String getHexSource(int index) {
return hexs.get(index);
}
private static int toInt(byte[] bytes) {
if (bytes == null || bytes.length != 2) {
throw new RuntimeException("Length bytes length error");
}
int c1 = (int) bytes[0];
int c2 = (int) bytes[1];
return Integer.valueOf(c1 + "" + (c2 < 10 ? "0" + c2 : c2));
}
private static byte[] toBytes(int num) {
if (num > 10000 || num < 0) {
throw new RuntimeException("Number mast in 0~9999");
}
if (num < 100) {
return new byte[]{0x00, (byte) num};
} else {
String tmp = String.valueOf(num);
int a1 = Integer.valueOf(tmp.substring(0, tmp.length() - 2));
int a2 = Integer.valueOf(tmp.substring(tmp.length() - 2));
return new byte[]{(byte) a1, (byte) a2};
}
}
private static String toHex(byte[] bytes) {
int index = new Random().nextInt(hexLen);
String hexTmp = getHexSource(index);
String result = "";
byte[] lenBytes = toBytes(index);
String hex = String.valueOf(HEX_NORMAL.charAt((lenBytes[0] & 0xF0) >> 4));
hex += String.valueOf(HEX_NORMAL.charAt(lenBytes[0] & 0x0F));
result += hex;
hex = String.valueOf(HEX_NORMAL.charAt((lenBytes[1] & 0xF0) >> 4));
hex += String.valueOf(HEX_NORMAL.charAt(lenBytes[1] & 0x0F));
result += hex;
for (int i = 0; i < bytes.length; i++) {
hex = String.valueOf(hexTmp.charAt((bytes[i] & 0xF0) >> 4));
hex += String.valueOf(hexTmp.charAt(bytes[i] & 0x0F));
result += hex;
}
return result;
}
private static byte[] hexTo(String hex) {
byte indexFirstHigh = (byte) ((HEX_NORMAL.indexOf(hex.charAt(0))) << 4);
byte indexFirstLow = (byte) HEX_NORMAL.indexOf(hex.charAt(1));
byte indexFirst = (byte) (indexFirstHigh | indexFirstLow);
byte indexLastHigh = (byte) ((HEX_NORMAL.indexOf(hex.charAt(2))) << 4);
byte indexLastLow = (byte) HEX_NORMAL.indexOf(hex.charAt(3));
byte indexLast = (byte) (indexLastHigh | indexLastLow);
byte[] lenBytes = new byte[]{indexFirst, indexLast};
int index = toInt(lenBytes);
String hexTmp = getHexSource(index);
String content = hex.substring(4);
int len = content.length() >> 1;
byte[] result = new byte[len];
byte high = 0;
byte low = 0;
for (int i = 0; i < len; i++) {
high = (byte) ((hexTmp.indexOf(content.charAt(2 * i))) << 4);
low = (byte) hexTmp.indexOf(content.charAt(2 * i + 1));
result[i] = (byte) (high | low);
}
return result;
}
private static byte[] encrypt(byte[] bytes, byte[] pass) throws Exception {
SecureRandom secureRandom = SecureRandom.getInstance("SHA1PRNG");
secureRandom.setSeed(pass);
KeyGenerator generator = KeyGenerator.getInstance("AES");
generator.init(secureRandom);
SecretKey secretKey = generator.generateKey();
Cipher cipher = Cipher.getInstance("AES");
cipher.init(Cipher.ENCRYPT_MODE, secretKey);
return cipher.doFinal(bytes);
}
private static byte[] decrypt(byte[] bytes, byte[] pass) throws Exception {
SecureRandom secureRandom = SecureRandom.getInstance("SHA1PRNG");
secureRandom.setSeed(pass);
KeyGenerator generator = KeyGenerator.getInstance("AES");
generator.init(secureRandom);
SecretKey secretKey = generator.generateKey();
Cipher cipher = Cipher.getInstance("AES");
cipher.init(Cipher.DECRYPT_MODE, secretKey);
return cipher.doFinal(bytes);
}
private static byte[] compress(byte[] inputByte) throws Exception {
int len = 0;
Deflater defl = new Deflater();
defl.setInput(inputByte);
defl.finish();
ByteArrayOutputStream bos = new ByteArrayOutputStream();
byte[] outputByte = new byte[1024];
try {
while (!defl.finished()) {
len = defl.deflate(outputByte);
bos.write(outputByte, 0, len);
}
defl.end();
} catch (Exception e) {
throw e;
} finally {
bos.close();
}
return bos.toByteArray();
}
private static byte[] uncompress(byte[] inputByte) throws Exception {
int len = 0;
Inflater infl = new Inflater();
infl.setInput(inputByte);
ByteArrayOutputStream bos = new ByteArrayOutputStream();
byte[] outByte = new byte[1024];
try {
while (!infl.finished()) {
len = infl.inflate(outByte);
if (len == 0) {
break;
}
bos.write(outByte, 0, len);
}
infl.end();
} catch (Exception e) {
throw e;
} finally {
bos.close();
}
return bos.toByteArray();
}
private static void gen() {
while (hexs.size() < hexLen) {
String hex = genHexTmp();
if (!hexs.contains(hex)) {
hexs.add(hex);
}
}
}
private static String genHexTmp() {
Random rnd = new Random();
int len = HEX_TMP.length();
List<Character> tmp = new ArrayList<>(17);
String hex = "";
while (tmp.size() < 16) {
int index = rnd.nextInt(len);
char c = HEX_TMP.charAt(index);
if (!tmp.contains(c)) {
tmp.add(c);
hex += String.valueOf(c);
}
}
tmp.clear();
return hex;
}
}
==LOG-Footer Start==================================
作者公众号:Loyomer
简洁:Kxvz的生活记账本。技术,生活,随笔,文摘...
欢迎大家关注...
==LOG-Footer End==================================
原文链接:https://www.cnblogs.com/kxvz/p/11698004.html
如有疑问请与原作者联系
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- DES/3DES/AES 三种对称加密算法实现 2020-06-11
- Linux简单命令的学习 2020-06-10
- 因为命名被diss无数次。简单聊聊编程最头疼的事情之一:命名 2020-06-10
- 作为一个面试官,我想问问你Redis分布式锁怎么搞? 2020-06-10
- 「starter推荐」简单高效Excel 导出工具 2020-06-08
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash