嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300
本次赞助数额为: 4 元微信扫码支付:4 元
请留下您的邮箱,我们将在2小时内将文件发到您的邮箱
1、JAVA MD5加密,AES加密解决;
2、项目需求,根据用户ID,软件名称,时间,硬件ID生成随机6位码,用户ID是可逆的。 基本思路是,两位存储用户ID,其他四位随机加密码,然后再讲两位 和四位二次混淆加密。
/ 自定义加密六位码 母本
private static String CUSTKEY = "56789Q0TYW2prxaER1U3Oz4IPASDuiowcvnFGHtyJsdfKLZXghjkeCVbBNMqm";
/**
* 根据 输入 字符串 输出四位随机数
*
* @param input
* @return
* @throws NoSuchAlgorithmException
* @throws UnsupportedEncodingException
*/
public static String Rarefy_Encrypt(String input) {
try {
String encrypt = MD5_Encrypt(input);
String result = "";
byte[] bytes = encrypt.getBytes("utf-8");
for (int i = 0; i < 4; i )// 每八位 字节相加对61取余数 ,取custkey中的内容
{
int t = (bytes[i 0] bytes[i 1] bytes[i 2]
bytes[i 3] bytes[i 4] bytes[i 5]
bytes[i 6] bytes[i 7]);
int t1 = t % 61;
result = CUSTKEY.charAt(t1);
}
return result;
} catch (Exception ex) {
ex.printStackTrace();
return "";
}
}
/**
* 将两位用户ID插入4位加密密码中 可逆的 返回6位
*
* @param source
* 四位密码
* @param insert
* 两位用户ID
* @return
*/
public static String Insert_Encrypt(String source, String insert) {
try {
// XYXXX YY
// [][][][][][]
String t1 = source.substring(0, 2);
String t2 = source.substring(2,4);
byte[] temp1 = t1.getBytes("utf-8");
byte[] temp2 = t2.getBytes("utf-8");
int index1 = (temp1[0] temp1[1]) % 2;// 奇数:1 偶数:2
int index2 = (temp2[0] temp2[1]) % 2;// 奇数:4,偶数:5
char[] result = new char[6];
if (index1 > 0) {
result[0] = source.charAt(0);
result[1] = insert.charAt(0);
result[2] = source.charAt(1);
} else {
result[0] = source.charAt(0);
result[1] = source.charAt(1);
result[2] = insert.charAt(0);
}
if (index2 > 0) {
result[3] = source.charAt(2);
result[4] = insert.charAt(1);
result[5] = source.charAt(3);
} else {
result[3] = source.charAt(2);
result[4] = source.charAt(3);
result[5] = insert.charAt(1);
}
return new String(result);
} catch (Exception ex) {
ex.printStackTrace();
return "";
}
}
/**
* 将 两位 用户ID从 六位加密中取出, 返回 string【】 0:4位密码 ;1:两位用户名ID
*
* @param decryptStr
* 6位加密字符
* @param source
* 4位原始加密码
* @return
*/
public static String[] Insert_Decrypt(String decryptStr, String source) {
try {
String t1 = source.substring(0, 2);
String t2 = source.substring(2, 4);
byte[] temp1 = t1.getBytes("utf-8");
byte[] temp2 = t2.getBytes("utf-8");
int index1 = (temp1[0] temp1[1]) % 2;// 基数:1 偶数:2
int index2 = (temp2[0] temp2[1]) % 2;// 基数:4,偶数:5
char[] encrypt = new char[4];
char[] userid = new char[2];
if (index1 > 0) {
// result[0] = source[0];
// result[1] = insert[0];
// result[2] = source[1];
userid[0] = decryptStr.charAt(1);
encrypt[0] = decryptStr.charAt(0);
encrypt[1] = decryptStr.charAt(2);
} else {
// result[0] = source[0];
// result[1] = source[1];
// result[2] = insert[0];
userid[0] = decryptStr.charAt(2);
encrypt[0] = decryptStr.charAt(0);
encrypt[1] = decryptStr.charAt(1);
}
if (index2 > 0) {
// result[3] = source[2];
// result[4] = insert[1];
// result[5] = source[3];
encrypt[2] = decryptStr.charAt(3);
encrypt[3] = decryptStr.charAt(5);
userid[1] = decryptStr.charAt(4);
} else {
// result[3] = source[2];
// result[4] = source[3];
// result[5] = insert[1];
encrypt[2] = decryptStr.charAt(3);
encrypt[3] = decryptStr.charAt(4);
userid[1] = decryptStr.charAt(5);
}
String[] result = new String[2];
result[0] = new String(encrypt);
result[1] = new String(userid);
return result;
} catch (Exception ex) {
ex.printStackTrace();
return null;
}
}