2023年12月8日发(作者:)

md5加密校验java_java-md5加密字符串和文件(校验文件是

否被修改)

package 5;

import ;

import putStream;

import ption;

import tream;

import ByteBuffer;

import annel;

import eDigest;

import AlgorithmException;

/**

* MD5生成文件校验值

* @author liuyazhuang

*

*/

public class MD5Utils {

/**

* 默认的密码字符串组合,用来将字节转换成 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 = tance("MD5");

} catch (NoSuchAlgorithmException nsaex) {

n(e() + "初始化失败,MessageDigest不支持MD5Util。");

tackTrace();

}

}

/**

* 生成字符串的md5校验值

** @param s

* @return

*/

public static String getMD5String(String s) {

return getMD5String(es());

}

/**

* 判断字符串的md5校验码是否与一个已知的md5码相匹配

*

* @param password

* 要校验的字符串

* @param md5PwdStr

* 已知的md5校验码

* @return

*/

public static boolean checkPassword(String password, String md5PwdStr) {

String s = getMD5String(password);

return (md5PwdStr);

}

/**

* 此方法返回文件的MD5码,用于验证文件是否被恶意修改使用

* @param file

* @return

*/

public static String getMd5ByFile(File file) {

String value = null;

FileInputStream in = null;

FileChannel fc = null;

try {

in = new FileInputStream(file);

byte[] buffer = new byte[1024];

int numRead = 0;

MessageDigest md5 = tance("MD5");

while ((numRead = (buffer)) > 0) {(buffer, 0, numRead);

}

value = bufferToHex(());

} catch (Exception e) {

tackTrace();

} finally {

try {

if(in != null) {

();

}

} catch (IOException e) {

tackTrace();

}

}

return value;

}

/**

* JDK1.4中不支持以MappedByteBuffer类型为参数update方法,并且网上有讨论要慎用MappedByteBuffer,

* 原因是当使用 方法时,MappedByteBuffer 已经在系统内占用了一个句柄, 而使用

* 方法是无法释放这个句柄的,且FileChannel有没有提供类似 unmap 的方法,

* 因此会出现无法删除文件的情况。

*

* 不推荐使用

*

* @param file

* @return

* @throws IOException

*/

public static String getFileMD5String_old(File file) throws IOException {

FileInputStream in = new FileInputStream(file);

FileChannel ch = nnel();

MappedByteBuffer byteBuffer = (_ONLY, 0, ());

(byteBuffer);

();return bufferToHex(());

}

public static String getMD5String(byte[] bytes) {

(bytes);

return bufferToHex(());

}

private static String bufferToHex(byte bytes[]) {

return bufferToHex(bytes, 0, );

}

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 ng();

}

private static void appendHexPair(byte bt, StringBuffer stringbuffer) {

char c0 = hexDigits[(bt & 0xf0) >> 4];// 取字节中高 4 位的数字转换, >>>

// 为逻辑右移,将符号位一起右移,此处未发现两种符号有何不同

char c1 = hexDigits[bt & 0xf];// 取字节中低 4 位的数字转换

(c0);

(c1);

}