java绕过加密密码_Java项目密码做MD5加密处理

packagecn.ljs.util;importjava.security.MessageDigest;importjava.security.NoSuchAlgorithmException;importjava.util.Random;importorg.apache.commons.codec.binary.Hex;/*** MD5加盐加密

*@authorAdministrator

**/

public classMD5 {public staticString makeMD5(String plainText) {

plainText=plainText+"A";//A是自定义盐值,随便填什么都可以try{

MessageDigest md= MessageDigest.getInstance("MD5");

md.update(plainText.getBytes());byte b[] =md.digest();inti;

StringBuffer buf= new StringBuffer("");for (int offset = 0; offset < b.length; offset++) {

i=b[offset];if (i < 0)

i+= 256;if (i < 16)

buf.append("0C");

buf.append(Integer.toHexString(i));

}//32位加密

returnbuf.toString();//16位的加密//return buf.toString().substring(8, 24);

} catch(NoSuchAlgorithmException e) {

e.printStackTrace();return null;

}

}/*** 生成含有随机盐的密码*/

/*public static String generate(String password) {

Random r = new Random();

StringBuilder sb = new StringBuilder(16);

sb.append(r.nextInt(99999999)).append(r.nextInt(99999999));

int len = sb.length();

if (len < 16) {

for (int i = 0; i < 16 - len; i++) {

sb.append("0");

}

}

String salt = sb.toString();

password = md5Hex(password + salt);

char[] cs = new char[48];

for (int i = 0; i < 48; i += 3) {

cs[i] = password.charAt(i / 3 * 2);

char c = salt.charAt(i / 3);

cs[i + 1] = c;

cs[i + 2] = password.charAt(i / 3 * 2 + 1);

}

return new String(cs);

}*/

/*** 校验密码是否正确*/

/*public static boolean verify(String password, String md5) {

char[] cs1 = new char[32];

char[] cs2 = new char[16];

for (int i = 0; i < 48; i += 3) {

cs1[i / 3 * 2] = md5.charAt(i);

cs1[i / 3 * 2 + 1] = md5.charAt(i + 2);

cs2[i / 3] = md5.charAt(i + 1);

}

String salt = new String(cs2);

return md5Hex(password + salt).equals(new String(cs1));

}*/

/*** 获取十六进制字符串形式的MD5摘要*/

/*public static String md5Hex(String src) {

try {

MessageDigest md5 = MessageDigest.getInstance("MD5");

byte[] bs = md5.digest(src.getBytes());

return new String(new Hex().encode(bs));

} catch (Exception e) {

return null;

}

}*/}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值