package **.tool;
import java.math.BigInteger;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
public class EncryptTools {
private static final char FIRST = **;
private static final char SECOND = ***;
public static byte[] encryptFile(byte[] file) {
int len = file.length;
int count = len > 100 ? 50 : file.length / 2;
for (int i = 0; i < count; i++) {
byte temp = file[i];
file[i] = file[len - i - 1];
file[len - i - 1] = temp;
}
byte[] bytes = new byte[len + 2];
System.arraycopy(file, 0, bytes, 2, len);
bytes[0] = FIRST;
bytes[1] = SECOND;
return bytes;
}
public static byte[] decryptFile(byte[] file) {
if (file == null || file.length == 0) {
return file;
}
if (file[0] != FIRST || file[1] != SECOND) {
return file;
}
byte[] bytes = new byte[file.length - 2];
System.arraycopy(file, 2, bytes, 0, file.length - 2);
int len = bytes.length;
int count = len > 100 ? 50 : len / 2;
for (int i = 0; i < count; i++) {
byte temp = bytes[i];
bytes[i] = bytes[len - i - 1];
bytes[len - i - 1] = temp;
}
return bytes;
}
public static String MD5Encrypt(String plainText) {
byte[] secretBytes = null;
try {
secretBytes = MessageDigest.getInstance("md5").digest(plainText.getBytes());
} catch (NoSuchAlgorithmException e) {
throw new RuntimeException("没有这个md5算法!");
}
String md5code = new BigInteger(1, secretBytes).toString(16);
for (int i = 0; i < 32 - md5code.length(); i++) {
md5code = "0" + md5code;
}
return md5code;
}
}