刚好最近项目中需要用到一点加密的东西,java安全类库提供了一个
java.security.MessageDigest类,此 MessageDigest 类为应用程序提供信息摘要算法的功能,如 MD5 或 SHA 算法。信息摘要是安全的单向哈希函数,它接收任意大小的数据,并输出固定长度的哈希值。有现成的当然是最好的,省事省力。
MD5的非常有实际应用性。有网友给出这样的描述,可以参照一下: http://blog.csdn.net/Daping_Zhang/archive/2005/05/28/382688.aspx
该类的
这是Jakarta的logging组件下载时提供的MD5摘要信息,是对这个zip包进行全文加密生成的摘要,摘要码就是后面的f88520ed791673aed6cc4591bc058b55,如果你下载以后,按照MD5的算法生成自己的摘要,如果这二个摘要一样,就证明这个文件是没有被人篡改过的。
遇到的问题是Java的MessageDigest类执行后返回的byte[16]得转换成十六进制的字符串,如果直接用new String(byte[]),得到的结果将是不正确的。算法有很多网友提供了,照搬了。比较有趣的是,commons-logging提供的那个MD5居然和我自己生成的不一样(难道文件被修改过?),后来尝试了其它地方提供的MD5码,都没有问题。
有很多相关的现成代码,搜集了一下整理如下(经过验证):
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[]),得到的结果将是不正确的。算法有很多网友提供了,照搬了。比较有趣的是,commons-logging提供的那个MD5居然和我自己生成的不一样(难道文件被修改过?),后来尝试了其它地方提供的MD5码,都没有问题。
有很多相关的现成代码,搜集了一下整理如下(经过验证):
public
class
MD5Builder
{
static Logger logger = Logger.getLogger(MD5Builder.class);
// 用来将字节转换成 16 进制表示的字符
static char hexDigits[] = { '0', '1', '2', '3', '4', '5', '6', '7',
static Logger logger = Logger.getLogger(MD5Builder.class);
// 用来将字节转换成 16 进制表示的字符
static char hexDigits[] = { '0', '1', '2', '3', '4', '5', '6', '7',