MD5工具类 -- 文件MD5值 -- MD5加密
今在网上看到一MD5工具类,挺实用的,保存下来以备后用,感谢作者package com.zz.cert.test;import java.io.File;import java.io.FileInputStream;import java.io.IOException;import java.io.InputStream;import java.nio.ByteBuffer;import java.nio.channels.FileChannel;import java.security.MessageDigest;import java.security.NoSuchAlgorithmException;public class MD5Util { ** * 16进制字符集 */private static final char HEX_DIGITS[] = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F'}; ** * 指定算法为MD5的MessageDigest */private static MessageDigest messageDigest = null; ** * 初始化messageDigest的加密算法为MD5 */static {try { messageDigest = MessageDigest.getInstance("MD5"); }catch(NoSuchAlgorithmException e) { e.printStackTrace(); }} ** * 获取文件的MD5值* @param file 目标文件* @return MD5字符串 */public static String getFileMD5String(File file) {String ret = "";FileInputStream in = null;FileChannel ch = null;try { in = new FileInputStream(file); ch = in.getChannel(); ByteBuffer byteBuffer = ch.map(FileChannel.MapMode.READ_ONLY, 0, file.length()); messageDigest.update(byteBuffer); ret = bytesToHex(messageDigest.digest());}catch(IOException e) { e.printStackTrace(); } finally { if(in != null) { try { in.close(); } catch(IOException e) { e.printStackTrace(); } } if(ch != null) { try { ch.close(); } catch(IOException e) { e.printStackTrace(); } } } return ret; }** * 获取文件的MD5值* @param fileName 目标文件的完整名称* @return MD5字符串 */public static String getFileMD5String(String fileName) {return getFileMD5String(new File(fileName)); } ** * MD5加密字符串* @param str 目标字符串* @return MD5加密后的字符串 */ public static String getMD5String(String str) { return getMD5String(str.getBytes()); }** * MD5加密以byte数组表示的字符串* @param bytes 目标byte数组* @return MD5加密后的字符串 */ public static String getMD5String(byte[] bytes) {messageDigest.update(bytes);return bytesToHex(messageDigest.digest()); } ** * 校验密码与其MD5是否一致* @param pwd 密码字符串* @param md5 基准MD5值* @return 检验结果 */public static boolean checkPassword(String pwd, String md5) {return getMD5String(pwd).equalsIgnoreCase(md5); } ** * 校验密码与其MD5是否一致* @param pwd 以字符数组表示的密码* @param md5 基准MD5值* @return 检验结果 */public static boolean checkPassword(char[] pwd, String md5) {return checkPassword(new String(pwd), md5);}** * 检验文件的MD5值* @param file 目标文件* @param md5 基准MD5值* @return 检验结果 */public static boolean checkFileMD5(File file, String md5) {return getFileMD5String(file).equalsIgnoreCase(md5);} ** * 检验文件的MD5值* @param fileName 目标文件的完整名称* @param md5 基准MD5值* @return 检验结果 */public static boolean checkFileMD5(String fileName, String md5) {return checkFileMD5(new File(fileName), md5);} ** * 将字节数组转换成16进制字符串* @param bytes 目标字节数组* @return 转换结果 */ public static String bytesToHex(byte bytes[]) {return bytesToHex(bytes, 0, bytes.length);} ** * 将字节数组中指定区间的子数组转换成16进制字符串* @param bytes 目标字节数组* @param start 起始位置(包括该位置)* @param end 结束位置(不包括该位置)* @return 转换结果 */ public static String bytesToHex(byte bytes[], int start, int end) {StringBuilder sb = new StringBuilder();for(int i = start; i < start + end; i++) { sb.append(byteToHex(bytes)); } return sb.toString(); } ** * 将单个字节码转换成16进制字符串* @param bt 目标字节* @return 转换结果 */public static String byteToHex(byte bt) {return HEX_DIGITS[(bt & 0xf0) >> 4] + "" + HEX_DIGITS;} //// public static void main(String[] args) throws IOException {long begin = System.currentTimeMillis();String md5 = getFileMD5String(new File("c://aa.cer"));long end = System.currentTimeMillis();System.out.println("MD5:\t" + md5 + "\nTime:\t" + (end - begin) + "ms"); } }
页:
[1]