`

java——MD5加密算法(含验证)

阅读更多
package date;

import java.security.MessageDigest;

public class Password {
/** 十六进制下数字到字符的映射数组 */
private final static String[] hexDigits = { "0", "1", "2", "3", "4", "5",
"6", "7", "8", "9", "a", "b", "c", "d", "e", "f" };

/**
*
* 对input加密生成新密码
*
* @param inputString
*            待加密的字符串
* @return
*/
public static String createPassword(String inputString) {
return encodeByMD5(inputString);
}

/**
*
* 验证输入密码是否正确
*
* @param password
*            加密后的密码
* @param inputString
*            输入的明文密码
* @return
*/
public static boolean authenticatePassword(String password,
String inputString) {
if (password.equals(encodeByMD5(inputString))) {
return true;
} else {
return false;
}
}

/**
*
* 对字符串进行md5编码
*
* @param originString
* @return
*/
private static String encodeByMD5(String originString) {
if (originString != null) {
try {
MessageDigest md = MessageDigest.getInstance("MD5");
byte[] results = md.digest(originString.getBytes());
String resultString = byteArrayToHexString(results);
return resultString.toUpperCase();
} catch (Exception ex) {
ex.printStackTrace();
}
}
return null;
}

/**
*
* 转换字节数组为十六进制字符串
*
* @param b
*            字节数组
* @return 十六进制字符串
*/
private static String byteArrayToHexString(byte[] b) {
StringBuffer resultSb = new StringBuffer();
for (int i = 0; i < b.length; i++) {
resultSb.append(byteToHexString(b[i]));
}
return resultSb.toString();
}

/**
* 转换一个字节为十六进制
*
* @param b
*            单个字节
* @return
*/
private static String byteToHexString(byte b) {
int n = b;
if (n < 0) {
n = 256 + n;
}
int d1 = n / 16;
int d2 = n % 16;
return hexDigits[d1] + hexDigits[d2];
}

public static void main(String args[]){


String password=Password.createPassword("945896808");

System.out.println(password);

System.out.println("对945896808加密后是否匹配"+Password.authenticatePassword(password, "945896808"));

System.out.println("加密后是否匹配"+Password.authenticatePassword(password, "888888888"));
}

}
分享到:
评论

相关推荐

    JAVA上百实例源码以及开源项目源代码

     Java非对称加密源程序代码实例,本例中使用RSA加密技术,定义加密算法可用 DES,DESede,Blowfish等。  设定字符串为“张三,你好,我是李四”  产生张三的密钥对(keyPairZhang)  张三生成公钥(publicKeyZhang...

    JAVA上百实例源码以及开源项目

     Java非对称加密源程序代码实例,本例中使用RSA加密技术,定义加密算法可用 DES,DESede,Blowfish等。  设定字符串为“张三,你好,我是李四”  产生张三的密钥对(keyPairZhang)  张三生成公钥(publicKeyZhang...

    程序员简历模板java开发工程师

    2.用户注册,采用RBAC权限控制,实现用户选择注册不同类型的帐号,所实现的功能不一样,用户密码采用md5加盐加密算法存储。 3.发起众筹项目,这是项目创业者所拥有的功能,将数据存入mysql数据库,通过mycat实现。 4...

    毕业设计 :ASP基于RSA的数字签名的设计与实现(源代码)

    (2)利用MD5算法计算出消息摘要MD; (3)数字签名的实现:用私钥d对消息摘要进行加密计算(RSA算法中的加密方法); (4)验证数字签名:用公钥e对数字签名进行解密计算(RSA算法中的解密方法),得到的解密结果与...

    JAVA程序开发大全---上半部分

    第5章 Java开发项目的软件测试工具——JUnit 68 5.1 软件测试简介 68 5.2 JUnit简介 68 5.2.1 JUnit的特点 69 5.2.2 JUnit的常用类和接口 69 5.3 在MyEclipse中设置JUnit 71 5.4 JUnit测试 72 5.4.1 JUnit测试用例 ...

    jive.chm

    4 关于Jive1中的验证和相关类的调用 &lt;br&gt; 5 MD5的加密算法(JavaScript) &lt;br&gt; 产品介绍 1 Jive简介 &lt;br&gt; Jive Forums 1 Jive Forums特性 2 Jive Forums Changelog &lt;br&gt; ...

    Jive资料集

    安全认证 1 Jive2.1.1 License保护原理分析 2 用Java的加密机制来保护你的数据 3 在java中编程实现数字签名系统 4 关于Jive1中的验证和相关类的调用 &lt;br&gt; 5 MD5的加密算法...

    asp.net知识库

    常用编码工具类,支持base64,md5,des,crc32 也谈谈技术面试 在C#里把ArrayList转换为Array 或 把Array转换为ArrayList C# 2.0 在.NET 2.0中,让你的组件也可以绑定 .NET20 一种简单的窗口控件UI状态控制方法 翻译MSDN...

Global site tag (gtag.js) - Google Analytics