原文地址:http://www.cnblogs.com/weiwangnuanyang/articles/4326336.html

java中使用MD5进行加密

    在各种应用系统的开发中,经常需要存储用户信息,很多地方都要存储用户密码,而将用户密码直接存储在服务器上显然是不安全的,本文简要介绍工作中常用的 MD5加密算法,希望能抛砖引玉。
(一)消息摘要简介
    一个消息摘要就是一个数据块的数字指纹。即对一个任意长度的一个数据块进行计算,产生一个唯一指印(对于SHA1是产生一个20字节的二进制数组)。消息摘要是一种与消息认证码结合使用以确保消息完整性的技术。主要使用单向散列函数算法,可用于检验消息的完整性,和通过散列密码直接以文本形式保存等,目前广泛使用的算法有MD4、MD5、SHA-1。

消息摘要有两个基本属性: 

  1. 两个不同的报文难以生成相同的摘要
  2. 难以对指定的摘要生成一个报文,而可以由该报文反推算出该指定的摘要

代表:美国国家标准技术研究所的SHA1和麻省理工学院Ronald Rivest提出的MD5

(二)对字符串进行加密

    /**利用MD5进行加密
     * @param str  待加密的字符串
     * @return  加密后的字符串
     * @throws NoSuchAlgorithmException  没有这种产生消息摘要的算法
     * @throws UnsupportedEncodingException  
     */
    public String EncoderByMd5(String str) throws NoSuchAlgorithmException, UnsupportedEncodingException{
        //确定计算方法
        MessageDigest md5=MessageDigest.getInstance("MD5");
        BASE64Encoder base64en = new BASE64Encoder();
        //加密后的字符串
        String newstr=base64en.encode(md5.digest(str.getBytes("utf-8")));
        return newstr;
    }

调用函数:
String str="0123456789"
System.out.println(EncoderByMd5(str));
输出:eB5eJF1ptWaXm4bijSPyxw==
(三)验证密码是否正确
    因为MD5是基于消息摘要原理的,消息摘要的基本特征就是很难根据摘要推算出消息报文,因此要验证密码是否正确,就必须对输入密码(消息报文)重新计算其摘要,和数据库中存储的摘要进行对比(即数据库中存储的其实为用户密码的摘要),若两个摘要相同,则说明密码正确,不同,则说明密码错误。

    /**判断用户密码是否正确
     * @param newpasswd  用户输入的密码
     * @param oldpasswd  数据库中存储的密码--用户密码的摘要
     * @return
     * @throws NoSuchAlgorithmException
     * @throws UnsupportedEncodingException
     */
    public boolean checkpassword(String newpasswd,String oldpasswd) throws NoSuchAlgorithmException, UnsupportedEncodingException{
        if(EncoderByMd5(newpasswd).equals(oldpasswd))
            return true;
        else
            return false;
    }

最新文章

  1. css清除浮动深度解析
  2. iOS之自动调节输入文本框的高度
  3. [游戏学习22] MFC 井字棋 双人对战
  4. JAX-RS 2.0 REST客户端编程实例
  5. Android 滑动效果入门篇(二)—— Gallery
  6. 介绍两个Eclipse插件: Implementors & Call Hierarchy
  7. Mysql 应该选择什么引擎
  8. 五子棋Web版的开发(一)---搭建IDEA SSH环境
  9. windows短路径转换成长路径
  10. tomcat简介与配置
  11. 又是一个Notepad++的问题
  12. Web GIS系统相关
  13. Codeforces Round #508 (Div. 2)
  14. C# 之抽象类和抽象方法
  15. C#与Visual Basic的异与同
  16. 28UDP
  17. 【】Python】异常处理try...except、raise
  18. python中的configparse学习笔记
  19. C# 动态加载WebService
  20. Win7下:编译器错误信息: CS0016

热门文章

  1. kotlin下载地址收藏
  2. 解决 Could not resolve com.android.tools.build:gradle:3.1.3
  3. 007.KVM虚机时间-快照管理
  4. jquery 点击页面流畅弹出预定文字
  5. Java对epub电子书类型切割
  6. 9、Redis处理过期keys的机制
  7. MikroTik RouterOS安装到SATA硬盘
  8. 使用GSON和泛型解析约定格式的JSON串(转)
  9. OPENSSL FIPS
  10. 最简单的例子理解Javascript闭包