最近在百度做系统的研发,遇到一个文件md5校验的问题,刚开始以为挺复杂,后来才发现其实前人已经为我们铺好了道路,而且还是康庄大道啊,谢谢前辈们。需求是这样的,系统需要通过ftp下载一个服务器上的两份文件(一份文件是源文件,另一份用于校对的md5),通过对文件md5的校验后,比对一起下载下来的这个md5文件,如果相同则文件是安全的,我们在进行下一步操作,这是为了防止文件被别有用心的人篡改。其实我们要做的其实主要就是对该源文件进行md5码的生成。代码如下所示:
/**
* MD5验证工具
*
* @author yangchao
* @version $Id: MD5Util.java, v 0.1 2012-2-20 下午4:06:11 yangchao Exp $
*/
public class MD5Util {
/**
* 默认的密码字符串组合,用来将字节转换成 16 进制表示的字符,apache校验下载的文件的正确性用的就是默认的这个组合
*/
protected static char hexDigits[] = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c',
'd', 'e', 'f' };
protected static MessageDigest messagedigest = null;
static {
try {
messagedigest = MessageDigest.getInstance("MD5");
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
}
public static String getFileMD5String(File file) throws IOException {
InputStream fis;
fis = new FileInputStream(file);
byte[] buffer = new byte[1024];
int numRead = 0;
while ((numRead = fis.read(buffer)) > 0) {
messagedigest.update(buffer, 0, numRead);
}
fis.close();
return bufferToHex(messagedigest.digest());
}
private static String bufferToHex(byte bytes[]) {
return bufferToHex(bytes, 0, bytes.length);
}
private static String bufferToHex(byte bytes[], int m, int n) {
StringBuffer stringbuffer = new StringBuffer(2 * n);
int k = m + n;
for (int l = m; l < k; l++) {
appendHexPair(bytes[l], stringbuffer);
}
return stringbuffer.toString();
}
private static void appendHexPair(byte bt, StringBuffer stringbuffer) {
char c0 = hexDigits[(bt & 0xf0) >> 4];// 取字节中高 4 位的数字转换
// 为逻辑右移,将符号位一起右移,此处未发现两种符号有何不同
char c1 = hexDigits[bt & 0xf];// 取字节中低 4 位的数字转换
stringbuffer.append(c0);
stringbuffer.append(c1);
}
public static void main(String[] args) throws IOException {
File file = new File("E:/test/crm_account_YYYY_MM_DD.txt");
String md5 = getFileMD5String(file);
System.out.println("md5:" + md5);
}
}
运行一下就会生成一串md5码,在于md5文件比对,就可以了,简单吧