基本信息
源码名称:java MD5,AES及 六位随机码生成
源码大小:2.06KB
文件格式:.rar
开发语言:Java
更新时间:2020-02-11
   友情提示:(无需注册或充值,赞助后即可获取资源下载链接)

     嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300

本次赞助数额为: 4 元 
   源码介绍

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;
}

}