java中使用MD5加密算法进行加密
在各种应用系统的开发中,经常需要存储用户信息,很多地方都要存储用户密码,而将用户密码直接存储在服务器上显然是不安全的,本文简要介绍工作中常用的 MD5加密算法,希望能抛砖引玉。
??? (一)消息摘要简介
??? 一个消息摘要就是一个数据块的数字指纹。即对一个任意长度的一个数据块进行计算,产生一个唯一指印(对于SHA1是产生一个20字节的二进制数组)。消息摘要是一种与消息认证码结合使用以确保消息完整性的技术。主要使用单向散列函数算法,可用于检验消息的完整性,和通过散列密码直接以文本形式保存等,目前广泛使用的算法有MD4、MD5、SHA-1.
??? 消息摘要有两个基本属性:
??? 两个不同的报文难以生成相同的摘要难以对指定的摘要生成一个报文,而可以由该报文反推算出该指定的摘要代表:美国国家标准技术研究所的SHA1和麻省理工学院Ronald Rivest提出的MD5
??? (二)对字符串进行加密
????/**?*//**利用MD5进行加密
?????*?@param?str??待加密的字符串
?????*?@return??加密后的字符串
?????*?@throws?NoSuchAlgorithmException??没有这种产生消息摘要的算法
?????*?@throws?UnsupportedEncodingException??
?????*/
????public?String?EncoderByMd5(String?str)?throws?NoSuchAlgorithmException,?UnsupportedEncodingException...{
????????//确定计算方法
????????????return?true;
????????else
????????????return?false;
????} 1 楼 diandidemeng 2007-07-28 貌似md5算法加密,现在都被破解了N次了,为何不用sha128或以上呢?因为这个到目前为止还没有被那些牛人破解掉,请教下的? 2 楼 lllyq 2007-07-28 所谓的破解md5只不过可以算出特定解,没什么意义,所以md5还是很安全的,java security方面 可以看看Jasypt