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);
}
发布评论