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. 验证密码是否下确:正确  
时间: 2024-11-27 11:39:20

java 密码MD5加密的相关文章

Java生成MD5加密字符串代码实例_java

      (1)一般使用的数据库中都会保存用户名和密码,其中密码不使用明码保存.     有时候用MD5密码,很多语言都提供了将字符串生成为MD5密码的方法或函数.MD5的加密算法是公开的.     有时候也可以用自己的字符串加密算法,这种加密算法是只有自己知道的. (2)破解MD5的过程就是先算好大量或者所有可能的字符串的MD5数值,之后进行查询就可以破解.虽然有些网站规定了密码的位数在6~20位之间,但是要事先计算这么多是字符串并有效的组织存储.查询还是相当麻烦,相当慢的. 因为MD5的位

java的md5加密类(zt)

加密 java的md5加密类 MD5算法是将数据进行不可逆加密的算法有较好的安全性,在国内如寿信的安全支付平台就采用此算法. 源代码如下/************************************************MD5 算法的Java BeanLast Modified:10,Mar,2001*************************************************/ import java.lang.reflect.*; /************

Java实现MD5加密的方法_java

本文实例讲述了Java实现MD5加密的方法.分享给大家供大家参考.具体实现方法如下: import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; public class MD5HashUtil { private MessageDigest md = null; private static MD5HashUtil md5 = null; private static final char

解密-java的MD5加密怎么改成C++的代码

问题描述 java的MD5加密怎么改成C++的代码 import java.security.MessageDigest; public class MD5andKL { // MD5加码.32位 public static String MD5(String inStr) { MessageDigest md5 = null; try { md5 = MessageDigest.getInstance("MD5"); } catch (Exception e) { System.ou

Java实现MD5加密解密类

首先说明一下系统自带的MD5加密:           public final static String MD5(String s) {       char hexDigits[]={'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};              try {           byte[] btInput = s.getBytes();           // 获得MD5摘要算法的 Messa

java用md5加密同一个签名后结果不一样??

问题描述 java用md5加密同一个签名后结果不一样?? 需要验证签名是否一样,用md5加密后得到的签名跟对方报文中传过来的加密后的签名不一样?? 解决方案 用winmd5之类的软件算下,看下你的程序和标准的是否一致,特别注意你的文件流的读取,还是按照文本文件读取的. 解决方案二: 你确定对方加密的时候也是JAVA加密的吗?C#,JAVA等不同的语言加密有时候是不一样的 解决方案三: 可能是编码类型的问题 解决方案四: 确定双方使用的版本,与加密过程是一样的.否则,产生不一样的结果很正常. 解决

java加密算法--MD5加密和哈希散列带秘钥加密算法源码_java

java加密算法--MD5加密和哈希散列带秘钥加密算法源码              最近学习加密算法的知识,利用MD5 加密,百度一下网上资料很多,不是很详细,这里就整理下如何实现用MD5加密和 哈希散列带秘钥加密算法,大家可以看下. 实现代码: package com.ompa.common.utils; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import java

密码-MD5加密后的值可能相同

问题描述 MD5加密后的值可能相同 不同字符串的MD5加密后的值可能相同.假如'123'和'456'的MD5加密后的值相同.如果我的密码是123,那么我输入456在实际中是不通过的?那么是不是还有其他机制决定? 解决方案 1.md5不是加密算法,只是hash算法 2.md5碰撞(就是你说的值相同)几率非常非常非常低 3.一般的后台都不会直接密码一次md5,而是加盐后md5,甚至多次md5,防止脱库(意思就是就算有人把整个数据库拿走,用户的密码明文都不会泄露) 解决方案二: 如果我不知道你的密码,

java实现md5加密示例_java

复制代码 代码如下: /**  * 实现MD5加密  *  */ public class MD5 {    /**   * 获取加密后的字符串   * @param input   * @return   */  public static String stringMD5(String pw) {   try {               // 拿到一个MD5转换器(如果想要SHA1参数换成"SHA1")          MessageDigest messageDigest