六狼论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博账号登陆

只需一步,快速开始

搜索
查看: 24|回复: 0

MD5工具类 -- 文件MD5值 -- MD5加密

[复制链接]

升级  27.33%

23

主题

23

主题

23

主题

秀才

Rank: 2

积分
91
 楼主| 发表于 2013-2-4 19:17:41 | 显示全部楼层 |阅读模式
今在网上看到一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[i]));   } return sb.toString();   }   ** * 将单个字节码转换成16进制字符串* @param bt 目标字节* @return 转换结果 */  public static String byteToHex(byte bt) {  return HEX_DIGITS[(bt & 0xf0) >> 4] + "" + HEX_DIGITS[bt & 0xf];  } //// 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");    } }
您需要登录后才可以回帖 登录 | 立即注册 新浪微博账号登陆

本版积分规则

快速回复 返回顶部 返回列表