您的位置:首页 > 编程语言 > Java开发

用java计算文件MD5(文件hash)

2014-01-19 09:40 309 查看
distributed system的第一个实验需要提供这个功能,即如果一个配置文件改变了,在收发信息的时候就要按照新的配置文件的规则进行收发

那么如何知道一个文件是否改变了呢?当然是用比较文件hash值的方法,文件hash又叫文件签名,文件中哪怕一个bit位被改变了,文件hash就会不同。

比较常用的文件hash算法有MD5和SHA-1。

在这个实验中,我用的是MD5算法,java中,计算MD5可以用MessageDigest这个类。

下面是代码:

public static void main(String args[]) {
try {
System.out.println(getMD5Checksum("config.yaml"));
}
catch (Exception e) {
e.printStackTrace();
}
}

public static byte[] createChecksum(String filename) throws Exception {
InputStream fis =  new FileInputStream(filename);          //将流类型字符串转换为String类型字符串

byte[] buffer = new byte[1024];
MessageDigest complete = MessageDigest.getInstance("MD5"); //如果想使用SHA-1或SHA-256,则传入SHA-1,SHA-256
int numRead;

do {
numRead = fis.read(buffer);    //从文件读到buffer,最多装满buffer
if (numRead > 0) {
complete.update(buffer, 0, numRead);  //用读到的字节进行MD5的计算,第二个参数是偏移量
}
} while (numRead != -1);

fis.close();
return complete.digest();
}

public static String getMD5Checksum(String filename) throws Exception {
byte[] b = createChecksum(filename);
String result = "";

for (int i=0; i < b.length; i++) {
result += Integer.toString( ( b[i] & 0xff ) + 0x100, 16).substring(1);//加0x100是因为有的b[i]的十六进制只有1位
}
return result;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: