Java生成摘要
java安全类库提供了一个java.security.MessageDigest类,此 MessageDigest 类为应用程序提供信息摘要算法的功能,如 MD5 或 SHA-1 算法。信息摘要是安全的单向哈希函数,它接收任意大小的数据,并输出固定长度的哈希值。
MD5的非常有实际应用性。描述参照:http://blog.csdn.net/Daping_Zhang/archive/2005/05/28/382688.aspx
该类的getInstance(String algorithm) 方法返回一个MessageDigest的实体,加密的一系统的digest()方法和update(byte input)方法。加密后返回一个byte[],16位,我们经常见到很多开源网站的下载地址会有一个[md5]的链接,打开其实就是一小段文本内容。例如:
MD5 (commons-logging-1.1.1-bin.zip) = f88520ed791673aed6cc4591bc058b55
这是Jakarta的logging组件下载时提供的MD5摘要信息,是对这个zip包进行全文加密生成的摘要,摘要码就是后面的f88520ed791673aed6cc4591bc058b55,如果你下载以后,按照MD5的算法生成自己的摘要,如果这二个摘要一样,就证明这个文件是没有被人篡改过的。Java的MessageDigest类执行后返回的byte[16]得转换成十六进制的字符串,如果直接用new String(byte[]),得到的结果将是不正确的。先整理如下:
public class MD5Builder {static Logger logger = Logger.getLogger(MD5Builder.class);// 用来将字节转换成 16 进制表示的字符static char hexDigits[] = { '0', '1', '2', '3', '4', '5', '6', '7', '8','9', 'a', 'b', 'c', 'd', 'e', 'f' }; /*** 对文件全文生成MD5摘要* @param file 要加密的文件* @return MD5摘要码*/public static String getMD5(File file) {FileInputStream fis = null;try {MessageDigest md = MessageDigest.getInstance("MD5");logger.info("MD5摘要长度:" + md.getDigestLength());fis = new FileInputStream(file);byte[] buffer = new byte[2048];int length = -1;logger.info("开始生成摘要");long s = System.currentTimeMillis();while ((length = fis.read(buffer)) != -1) {md.update(buffer, 0, length);}logger.info("摘要生成成功,总用时: "+ (System.currentTimeMillis() - s) + "ms");byte[] b = md.digest();return byteToHexString(b);// 16位加密// return buf.toString().substring(8, 24);} catch (Exception ex) {logger.error(ex);ex.printStackTrace();return null;}finally {try {fis.close();} catch (IOException ex) {ex.printStackTrace();}}}/*** 对一段String生成MD5加密信息* @param message 要加密的String* @return 生成的MD5信息*/public static String getMD5(String message){try {MessageDigest md = MessageDigest.getInstance("MD5");logger.info("MD5摘要长度:" + md.getDigestLength());byte[] b = md.digest(message.getBytes());return byteToHexString(b);} catch (NoSuchAlgorithmException e) {logger.error(e);e.printStackTrace();return null;}}/*** 把byte[]数组转换成十六进制字符串表示形式* @param tmp 要转换的byte[]* @return 十六进制字符串表示形式*/private static String byteToHexString(byte[] tmp) {String s;// 用字节表示就是 16 个字节char str[] = new char[16 * 2]; // 每个字节用 16 进制表示的话,使用两个字符,// 所以表示成 16 进制需要 32 个字符int k = 0; // 表示转换结果中对应的字符位置for (int i = 0; i < 16; i++) { // 从第一个字节开始,对 MD5 的每一个字节// 转换成 16 进制字符的转换byte byte0 = tmp[i]; // 取第 i 个字节str[k++] = hexDigits[byte0 >>> 4 & 0xf]; // 取字节中高 4 位的数字转换, // >>> 为逻辑右移,将符号位一起右移str[k++] = hexDigits[byte0 & 0xf]; // 取字节中低 4 位的数字转换}s = new String(str); // 换后的结果转换为字符串return s;}
}
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!
