md5加密算法是可逆的

md5加密算法是可逆的

大家好,又见面了,我是你们的朋友全栈君。

md5加密代码语言:javascript代码运行次数:0运行复制package gov.mof.fasp2.gcfr.adjustoffset.adjust; import java.security.MessageDigest; public class MD5Test { /** * 测试主函数 * @param args */ public static void main(String[] args) { String s = "admin"; System.out.println("原始:" + s); System.out.println("MD5后:" + MD5(s)); System.out.println("(可逆)加密的:" + JM(s)); System.out.println("(可逆)解密的:" + JM(JM(s)));//两次解密 } /** * 生成32位码 * @param s - 需要加密的字符串 * @return */ public final static String MD5(String s) { try { byte[] btInput = s.getBytes(); MessageDigest mdInst = MessageDigest.getInstance("MD5"); mdInst.update(btInput); byte[] md = mdInst.digest(); StringBuffer sb = new StringBuffer(); for (int i = 0; i < md.length; i++) { int val = ((int) md[i]) & 0xff; if (val < 16) sb.append("0"); sb.append(Integer.toHexString(val)); } return sb.toString(); } catch (Exception e) { return null; } } /** * 加密解密算法 执行一次加密,两次解密 (可逆加解密算法) * @param s - 需要加密的字符串 * @return */ public static String JM(String inStr) { char[] a = inStr.toCharArray(); for (int i = 0; i < a.length; i++) { a[i] = (char) (a[i] ^ 't'); } String k = new String(a); return k; } }以上代码输出结果:

注:md5算法是不可逆的,所以经过md5加密过的字符串是无法还原(解密)的。一般用作登陆验证的时候,也是要先经过md5加密然后去数据库验证密码是否正确。

据说md5是被山东的一个女博士激活成功教程过,纯属传说。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/168181.html原文链接:https://javaforall.cn

相关文章

周语·内史过论晋惠公必无后
365bet平台网投

周语·内史过论晋惠公必无后

⌚ 07-05 👁️‍🗨️ 7357
村正(妙法千五村正):由來,傳說,真實村正,區別,
365bet平台网投

村正(妙法千五村正):由來,傳說,真實村正,區別,

⌚ 08-14 👁️‍🗨️ 3500