在各种应用系统的开发中,经常需要存储用户信息,很多地方都要存储用户密码,而将用户密码直接存储在服务器上显然是不安全的,本文简要介绍工作中常用的 MD5加密算法,希望能抛砖引玉。
(一)消息摘要简介
一个消息摘要就是一个数据块的数字指纹。即对一个任意长度的一个数据块进行计算,产生一个唯一指印(对于SHA1是产生一个20字节的二进制数组)。消息摘要是一种与消息认证码结合使用以确保消息完整性的技术。主要使用单向散列函数算法,可用于检验消息的完整性,和通过散列密码直接以文本形式保存等,目前广泛使用的算法有MD4、MD5、SHA-1.
消息摘要有两个基本属性:
两个不同的报文难以生成相同的摘要难以对指定的摘要生成一个报文,而可以由该报文反推算出该指定的摘要代表:美国国家标准技术研究所的SHA1和麻省理工学院Ronald Rivest提出的MD5
(二)对字符串进行加密
/***//**利用MD5进行加密
*@paramstr待加密的字符串
*@return加密后的字符串
*@throwsNoSuchAlgorithmException没有这种产生消息摘要的算法
*@throwsUnsupportedEncodingException
*/
publicStringEncoderByMd5(Stringstr)throwsNoSuchAlgorithmException,
UnsupportedEncodingException...{
//确定计算方法
MessageDigestmd5=MessageDigest.getInstance("MD5");
BASE64Encoderbase64en=newBASE64Encoder();
//加密后的字符串
Stringnewstr=base64en.encode(md5.digest(str.getBytes("utf-8")));
returnnewstr;
}
调用函数:String str="0123456789"
System.out.println(EncoderByMd5(str));
输出:eB5eJF1ptWaXm4bijSPyxw==
(三)验证密码是否正确
因为MD5是基于消息摘要原理的,消息摘要的基本特征就是很难根据摘要推算出消息报文,因此要验证密码是否正确,就必须对输入密码(消息报文)重新计算其摘要,和数据库中存储的摘要进行对比(即数据库中存储的其实为用户密码的摘要),若两个摘要相同,则说明密码正确,不同,则说明密码错误。
/***//**判断用户密码是否正确
*@paramnewpasswd用户输入的密码
*@paramoldpasswd数据库中存储的密码--用户密码的摘要
*@return
*@throwsNoSuchAlgorithmException
*@throwsUnsupportedEncodingException
*/
publicbooleancheckpassword(Stringnewpasswd,Stringoldpasswd)throwsNoSuchAlgorithmException,
UnsupportedEncodingException...{
if(EncoderByMd5(newpasswd).equals(oldpasswd))
returntrue;
else
returnfalse;
}
注明:QQ技术交流群:108614806 感兴趣的加一下。
分享到:
相关推荐
java中使用MD5加密算法进行加密.pdf
实现了不可逆的MD5加密算法
java实现MD5加密解密算法,java源代码~
JAVA高手MD5加密算法底层源码完美实现 JAVA高手MD5加密算法底层源码完美实现 JAVA高手MD5加密算法底层源码完美实现
java 采用MD5 加密密码 的方法
java实现md5 加密解密(在网络中MD5是著名的不可逆算法,但是如果知道MD5的加密的字符串 则可以通过自己的加密算法对明文进行加密,对加密后的密文与字符串匹配; 匹配成功,表示找到明文;但是此程序的时间耗费较高!仅...
java与c#MD5加密方法得到不一致解决办法,MD5加密后得到不一致结果
MD5加密算法的设计与实现\JAVA技术
对接接口时用到的一种常用加密算法,常用于验证签名,使用shiro-all-1.4.1.jar,可自行下载
md5 的算法 import java.security.*; import java.security.spec.*; class MD5_Test{ public final static String MD5(String s){ char hexDigits[] = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', '...
\基于JAVA技术的MD5加密算法的设计与实现
MD5加密算法的java实现,用于用户登录验证等
这是可以运用在Javaweb项目开发中密码的加密,代码沉余少。
MD5加密 加密算法,jar包学习交流,java研发学习交流MD5加密算法需要jar包,满足基础研发需要
通过java代码实现MD5加密算法实现。希望对您有所帮助。
MD5加密算法,适用于jsp项目,供大家学习参考
JAVA MD5 加密算法
常用MD5加密算法和3-DES加密算法java实现,在实际项目中我们会经常用到加密字符串,用md5算法是很多人的选择,其中包含源码,可直接使用。
JAVA的MD5加密算法