资源简介
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;
}
}
代码片段和文件信息
package encrypt;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.io.UnsupportedEncodingException;
import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;
import javax.crypto.spec.IvParameterSpec;
import sun.misc.base64Decoder;
import com.sun.org.apache.xerces.internal.impl.dv.util.base64;
/**
* 通用加密解密算法
*
* @author kwg 2017-8-22
*
*/
public class Crypto {
/**
* MD5不可逆加密算法
*
* @param encryptString
* @return
* @throws NoSuchAlgorithmException
* @throws UnsupportedEncodingException
*/
public static String MD5_Encrypt(String encryptString) {
try {
if (““.equals(encryptString))
return ““;
MessageDigest md = MessageDigest.getInstance(“MD5“);
byte[] result = md.
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
I.A.... 7062 2020-02-11 15:33 Crypto.java
----------- --------- ---------- ----- ----
7062 1
- 上一篇:java awt swing 飞机躲子弹
- 下一篇:java带菜单的窗口
相关资源
- java带菜单的窗口
- java awt swing 飞机躲子弹
-
java 模板(codetemplates.xm
l) - java基础(入门级个人学习笔记)
- java推箱子小游戏源码(带背景音乐)
- JAVA事件处理机制.ppt
- JAVA入门经典案例.pdf
- des3向量加密解密(java类文件)
- 单片机HEX升级文件JAVA转换(parseHEX)
- Java知识点和知识结构思维导图
- 耿祥义java实用教程第5版教材源代码
- java编程基础教程:Java SWT 图形用户界
- Java websocket入门级
- java实现记事本 程序源码
- java将多张图片合并转为PDF
- java人力资源管理系统(控制台入门级
- 就诊时排队叫号系统(java入门级)
- leadtools集成java将pdf转换成docx文档
- Java习题参考答案及解析.pdf(共85页)
- 88道 疯狂Java面试题(附答案)
- Java swing学生成绩系统(源码+数据库脚
- java 扫雷 小游戏源码
- java学生信息管理系统(源码+数据库脚
- Java编程基础(个人学习笔记.docx)
- java图书管理系统(源码+数据库脚本)
- java SSH2
- java 为图片添加水印
- java 计算器(入门级)
- java swing树形菜单结构,动态选择数据
- Java 多线程编程
评论
共有 条评论