package zk.learn.encrypt; import java.io.UnsupportedEncodingException; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; /** * @program: demo * @description: 加密工具类 * * md5加密出来的长度是32位 * * sha加密出来的长度是40位 * @author: zhangkun * @create: 2019-07-25 11:01 **/ public class Encrypt { /** * 二次加密,应该破解不了了吧? * * @param inputText * @return */ public static String md5AndSha(String inputText) { return sha(md5(inputText)); } /** * md5加密 * * @param inputText * @return */ public static String md5(String inputText) { return encrypt(inputText, "md5"); } /** * sha加密 * * @param inputText * @return */ public static String sha(String inputText) { return encrypt(inputText, "sha-1"); } /** * md5或者sha-1加密 * * @param inputText * 要加密的内容 * @param algorithmName * 加密算法名称:md5或者sha-1,不区分大小写 * @return */ private static String encrypt(String inputText, String algorithmName) { if (inputText == null || "".equals(inputText.trim())) { throw new IllegalArgumentException("请输入要加密的内容"); } if (algorithmName == null || "".equals(algorithmName.trim())) { algorithmName = "md5"; } String encryptText = null; try { MessageDigest m = MessageDigest.getInstance(algorithmName); m.update(inputText.getBytes("UTF8")); byte s[] = m.digest(); // m.digest(inputText.getBytes("UTF8")); return hex(s); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } return encryptText; } /** * 返回十六进制字符串 * * @param arr * @return */ private static String hex(byte[] arr) { StringBuffer sb = new StringBuffer(); for (int i = 0; i < arr.length; ++i) { sb.append(Integer.toHexString((arr[i] & 0xFF) | 0x100).substring(1, 3)); } return sb.toString(); } public static void main(String sdf[]){ String str = "123456"; System.out.println("明文:"+str); System.out.println("md5密文:"+md5(str)); System.out.println("sha-1密文:"+sha(str)); System.out.println("二次加密:"+md5AndSha(str)); } }
分享一波MD5和SHA-1加密工具类
猜你喜欢
转载自www.cnblogs.com/chewing-gum/p/11242990.html
今日推荐
周排行