中使用进行加密覆盖
在各种应用系统的开发中,经常需要存储用户信息,很多地方都要存储用户密码,而将用户密码直接存储在服务器上显然是不安全的,本文简要介绍工作中常用的 MD5加密算法,希望能抛砖引玉。
(一)消息摘要简介
一个消息摘要就是一个数据块的数字指纹。即对一个任意长度的一个数据块进行计算,产生一个唯一指印(对于SHA1是产生一个20字节的二进制数组)。消息摘要是一种与消息认证码结合使用以确保消息完整性的技术。主要使用单向散列函数算法,可用于检验消息的完整性,和通过散列密码直接以文本形式保存等,目前广泛使用的算法有MD4、MD5、SHA-1。
消息摘要有两个基本属性:
两个不同的报文难以生成相同的摘要 难以对指定的摘要生成一个报文,而可以由该报文反推算出该指定的摘要 代表:美国国家标准技术研究所的SHA1和麻省理工学院Ronald Rivest提出的MD5
(二)对字符串进行加密
/***//**利用MD5进行加密
*@paramstr待加密的字符串
*@return加密后的字符串
*@throwsNoSuchAlgorithmException没有这种产生消息摘要的算法
*@throwsUnsupportedEncodingException
*/
publicStringEncoderByMd5(Stringstr)throwsNoSuchAlgorithmException,UnsupportedEncodingException...{
//确定计算方法
MessageDigestmd5=tInstance(\"MD5\");
BASE64Encoderbase64en=newBASE64Encoder();
//加密后的字符串
Stringnewstr=code(gest(tBytes(\"utf-8\")));
returnnewstr;
}
调用函数:
String str=\"\"
intln(EncoderByMd5(str));
输出:eB5eJF1ptWaXm4bijSPyxw==
(三)验证密码是否正确
因为MD5是基于消息摘要原理的,消息摘要的基本特征就是很难根据摘要推算出消息报文,因此要验证密码是否正确,就必须对输入密码(消息报文)重新计算其摘要,和数据库中存储的摘要进行对比(即数据库中存储的其实为用户密码的摘要),若两个摘要相同,则说明密码正确,不同,则说明密码错误。
/***//**判断用户密码是否正确
*@paramnewpasswd用户输入的密码
*@paramoldpasswd数据库中存储的密码--用户密码的摘要
*@return
*@throwsNoSuchAlgorithmException
*@throwsUnsupportedEncodingException
*/
publicbooleancheckpassword(Stringnewpasswd,Stringoldpasswd)throwsNoSuchAlgorithmException,UnsupportedEncodingException...{
if(EncoderByMd5(newpasswd).equals(oldpasswd))
returntrue;
else
returnfalse;
}
参考资料
java上加密算法的实现用例
金星就在微博中澄清没有骂范冰冰 java加密和数字签名编程快速入门
榆林专业治白癜风医院西安妇科专治医院
宝宝积食怎么办
- 上一页:中使用计划
- 下一页:中使用接口实现多继承和多态的方法牛
-
【东方焦点】北京中医药大学东方医院与海外中医中心共同承办国际代表大会“中医儿科”线上分论坛取得圆满成
北京里药学药大学圣城疗养院与海外里药学区域内联合负责负责管理国际则会...
2024-03-20
-
60岁的年龄,20岁的身材,这6位越老越帅气的男明星,太专一了
近几年,网络上涌现了一个名词——中所年有种男。 一般所指中所年男人长...
2024-03-05
-
求学季,杭州家长都在咨询的热门国际化该学校来了!
2022年秋招季,很多对学生都希望并能把握住机会,找来助父母选择到暗恋的...
2024-02-12
-
玲花的打扮真不像中年人,T恤配五分裤简约轻松,素颜看着也不杨家
透过最经典的时尚界上衣撘,让你在四季都能美出新现职人心,女人从不欠缺...
2024-01-30
-
限时⇩5000页全脑思维训练,全面锻炼孩子逻辑思维,专注力和魄力!
如今小美妈透过一套 5000页左右的日本网红小章鱼逻辑观念受训练 。锻炼男孩...
2024-01-27
-
蒜苔炒肉丝,别直接炒,物理学会3个技巧,蒜苔翠绿肉丝嫩滑,都入味
蒜苔煎出水煮,别同样煎,研究会3个精准,蒜苔翠绿出水煮沙拉弯,都煮 大...
2024-01-17