java 密码MD5加密

简介:
  1. package com.sunnylocus.util;  
  2.   
  3. import java.security.MessageDigest;  
  4.   
  5. /**  
  6.  * 对密码进行加密和验证的类 
  7.  */  
  8. public class CipherUtil{  
  9.       
  10.     //十六进制下数字到字符的映射数组  
  11.     private final static String[] hexDigits = {"0""1""2""3""4",  
  12.         "5""6""7""8""9""a""b""c""d""e""f"};  
  13.       
  14.     /** * 把inputString加密     */  
  15.     public static String generatePassword(String inputString){  
  16.         return encodeByMD5(inputString);  
  17.     }  
  18.       
  19.       /** 
  20.        * 验证输入的密码是否正确 
  21.      * @param password    加密后的密码 
  22.      * @param inputString    输入的字符串 
  23.      * @return    验证结果,TRUE:正确 FALSE:错误 
  24.      */  
  25.     public static boolean validatePassword(String password, String inputString){  
  26.         if(password.equals(encodeByMD5(inputString))){  
  27.             return true;  
  28.         } else{  
  29.             return false;  
  30.         }  
  31.     }  
  32.     /**  对字符串进行MD5加密     */  
  33.     private static String encodeByMD5(String originString){  
  34.         if (originString != null){  
  35.             try{  
  36.                 //创建具有指定算法名称的信息摘要  
  37.                 MessageDigest md = MessageDigest.getInstance("MD5");  
  38.                 //使用指定的字节数组对摘要进行最后更新,然后完成摘要计算  
  39.                 byte[] results = md.digest(originString.getBytes());  
  40.                 //将得到的字节数组变成字符串返回  
  41.                 String resultString = byteArrayToHexString(results);  
  42.                 return resultString.toUpperCase();  
  43.             } catch(Exception ex){  
  44.                 ex.printStackTrace();  
  45.             }  
  46.         }  
  47.         return null;  
  48.     }  
  49.       
  50.     /**  
  51.      * 转换字节数组为十六进制字符串 
  52.      * @param     字节数组 
  53.      * @return    十六进制字符串 
  54.      */  
  55.     private static String byteArrayToHexString(byte[] b){  
  56.         StringBuffer resultSb = new StringBuffer();  
  57.         for (int i = 0; i < b.length; i++){  
  58.             resultSb.append(byteToHexString(b[i]));  
  59.         }  
  60.         return resultSb.toString();  
  61.     }  
  62.       
  63.     /** 将一个字节转化成十六进制形式的字符串     */  
  64.     private static String byteToHexString(byte b){  
  65.         int n = b;  
  66.         if (n < 0)  
  67.             n = 256 + n;  
  68.         int d1 = n / 16;  
  69.         int d2 = n % 16;  
  70.         return hexDigits[d1] + hexDigits[d2];  
  71.     }  
  72. }  

 

Java代码   收藏代码
  1. package com.sunnylocus.util;  
  2.   
  3. public class Main {  
  4.     public static void main(String[] args) {  
  5.         String pwd1="123";  
  6.         String pwd2="";  
  7.         CipherUtil cipher = new CipherUtil();  
  8.         System.out.println("未加密的密码:"+pwd1);  
  9.         //将123加密  
  10.         pwd2 = cipher.generatePassword(pwd1);  
  11.         System.out.println("加密后的密码:"+pwd2);  
  12.           
  13.         System.out.print("验证密码是否下确:");  
  14.         if(cipher.validatePassword(pwd2, pwd1)) {  
  15.             System.out.println("正确");  
  16.         }  
  17.         else {  
  18.             System.out.println("错误");  
  19.         }  
  20.     }  
  21. }  

 

结果输出:

Java代码   收藏代码
  1. 未加密的密码:123  
  2. 加密后的密码:202CB962AC59075B964B07152D234B70  
  3. 验证密码是否下确:正确  
相关文章
|
4月前
|
存储 Java 数据安全/隐私保护
Java技术栈揭秘:Base64加密和解密文件的实战案例
以上就是我们今天关于Java实现Base64编码和解码的实战案例介绍。希望能对你有所帮助。还有更多知识等待你去探索和学习,让我们一同努力,继续前行!
327 5
|
8月前
|
存储 缓存 Java
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
807 3
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
|
8月前
|
存储 算法 Java
解锁“分享文件”高效密码:探秘 Java 二叉搜索树算法
在信息爆炸的时代,文件分享至关重要。二叉搜索树(BST)以其高效的查找性能,为文件分享优化提供了新路径。本文聚焦Java环境下BST的应用,介绍其基础结构、实现示例及进阶优化。BST通过有序节点快速定位文件,结合自平衡树、多线程和权限管理,大幅提升文件分享效率与安全性。代码示例展示了文件插入与查找的基本操作,适用于大规模并发场景,确保分享过程流畅高效。掌握BST算法,助力文件分享创新发展。
|
9月前
|
存储 人工智能 算法
解锁分布式文件分享的 Java 一致性哈希算法密码
在数字化时代,文件分享成为信息传播与协同办公的关键环节。本文深入探讨基于Java的一致性哈希算法,该算法通过引入虚拟节点和环形哈希空间,解决了传统哈希算法在分布式存储中的“哈希雪崩”问题,确保文件分配稳定高效。文章还展示了Java实现代码,并展望了其在未来文件分享技术中的应用前景,如结合AI优化节点布局和区块链增强数据安全。
|
12月前
|
Java Maven 数据安全/隐私保护
如何实现Java打包程序的加密代码混淆,避免被反编译?
【10月更文挑战第15天】如何实现Java打包程序的加密代码混淆,避免被反编译?
1951 2
|
算法 Java 数据安全/隐私保护
java MD5 32位加密
java MD5 32位加密
188 0
|
编解码 算法 安全
怎么Java进行MD5摘要加密?
MD5(Message-Digest Algorithm 5)是一种常用的摘要算法,用于将任意长度的数据转换为固定长度的摘要值(通常为128位)。MD5算法的原理是将原始数据分成若干个固定长度的块,对每个块进行一系列的数据处理,最终得到一个128位的摘要值。这个摘要值可以作为数据的唯一标识,用于验证数据的完整性和真实性。
141 1
|
算法 Java 数据处理
Java中MD5加密算法的实现
Java中MD5加密算法的实现
|
存储 算法 Java
在Java中使用MD5对用户输入密码进行加密存储、同时登录验证。
这篇文章详细介绍了在Java项目中如何使用MD5算法对用户密码进行加密存储和登录验证,包括加入依赖、编写MD5工具类、注册时的密码加密和登录时的密码验证等步骤,并通过示例代码和数据库存储信息展示了测试效果。
在Java中使用MD5对用户输入密码进行加密存储、同时登录验证。
|
算法 安全 Java
Java中MD5加密算法的原理与实现详解
Java中MD5加密算法的原理与实现详解