提出问题:MD5,SHA算法是常用的两种加密算法。以前看过很多人写的md5算法,要么过于难懂,要么过于冗长,而且不能切换为其他加密算法,非常不给力。
分析和解决问题:于是,决定自己写一个简单好用的加密算法。翻看JDK1.5的API文档,惊喜的发现,在java.security这个包下面有一个MessageDigest类:此 MessageDigest 类为应用程序提供信息摘要算法的功能,如 MD5 或 SHA 算法。bingo!参考了部分网友的代码,本人的代码如下,不足之处,请大家批评指正。JDK/JRE版本:1.5+
- package common.util.security;
-
-
import java.io.UnsupportedEncodingException;
-
import java.security.MessageDigest;
-
import java.security.NoSuchAlgorithmException;
-
-
public class EncryptUtil {
-
-
public static void main(String[] args) {
-
-
String md5_1 = md5("123");
-
String md5_2 = md5("abc");
-
System.out.println(md5_1 + "\n" + md5_2);
-
System.out.println("md5 length: " + md5_1.length());
-
-
String sha_1 = sha("123");
-
String sha_2 = sha("abc");
-
System.out.println(sha_1 + "\n" + sha_2);
-
System.out.println("sha length: " + sha_1.length());
- }
-
-
-
public static String md5(String inputText) {
-
return encrypt(inputText, "md5");
- }
-
-
-
public static String sha(String inputText) {
-
return encrypt(inputText, "sha-1");
- }
-
-
-
-
-
-
-
-
-
-
-
private static String encrypt(String inputText, String algorithmName) {
-
if (inputText == null || "".equals(inputText.trim())) {
-
throw new IllegalArgumentException("请输入要加密的内容");
- }
-
if (algorithmName == null || "".equals(algorithmName.trim())) {
-
algorithmName = "md5";
- }
-
String encryptText = null;
-
try {
- MessageDigest m = MessageDigest.getInstance(algorithmName);
-
m.update(inputText.getBytes("UTF8"));
-
byte s[] = m.digest();
-
-
return hex(s);
-
} catch (NoSuchAlgorithmException e) {
- e.printStackTrace();
-
} catch (UnsupportedEncodingException e) {
- e.printStackTrace();
- }
-
return encryptText;
- }
-
-
-
private static String hex(byte[] arr) {
-
StringBuffer sb = new StringBuffer();
-
for (int i = 0; i < arr.length; ++i) {
-
sb.append(Integer.toHexString((arr[i] & 0xFF) | 0x100).substring(1,
-
3));
- }
-
return sb.toString();
- }
package common.util.security;
import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
public class EncryptUtil {
public static void main(String[] args) {
//md5加密测试
String md5_1 = md5("123");
String md5_2 = md5("abc");
System.out.println(md5_1 + "\n" + md5_2);
System.out.println("md5 length: " + md5_1.length());
//sha加密测试
String sha_1 = sha("123");
String sha_2 = sha("abc");
System.out.println(sha_1 + "\n" + sha_2);
System.out.println("sha length: " + sha_1.length());
}
// md5加密
public static String md5(String inputText) {
return encrypt(inputText, "md5");
}
// sha加密
public static String sha(String inputText) {
return encrypt(inputText, "sha-1");
}
/**
* md5或者sha-1加密
*
* @param inputText
* 要加密的内容
* @param algorithmName
* 加密算法名称:md5或者sha-1,不区分大小写
* @return
*/
private static String encrypt(String inputText, String algorithmName) {
if (inputText == null || "".equals(inputText.trim())) {
throw new IllegalArgumentException("请输入要加密的内容");
}
if (algorithmName == null || "".equals(algorithmName.trim())) {
algorithmName = "md5";
}
String encryptText = null;
try {
MessageDigest m = MessageDigest.getInstance(algorithmName);
m.update(inputText.getBytes("UTF8"));
byte s[] = m.digest();
// m.digest(inputText.getBytes("UTF8"));
return hex(s);
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
return encryptText;
}
// 返回十六进制字符串
private static String hex(byte[] arr) {
StringBuffer sb = new StringBuffer();
for (int i = 0; i < arr.length; ++i) {
sb.append(Integer.toHexString((arr[i] & 0xFF) | 0x100).substring(1,
3));
}
return sb.toString();
}
- 上述代码的运行结果:
- 202cb962ac59075b964b07152d234b70
- 900150983cd24fb0d6963f7d28e17f72
-
md5 length: 32
- 40bd001563085fc35165329ea1ff5c5ecbdbbeef
- a9993e364706816aba3e25717850c26c9cd0d89d
-
sha length: 40
上述代码的运行结果:
202cb962ac59075b964b07152d234b70
900150983cd24fb0d6963f7d28e17f72
md5 length: 32
40bd001563085fc35165329ea1ff5c5ecbdbbeef
a9993e364706816aba3e25717850c26c9cd0d89d
sha length: 40
由此可见,MD5和SHA-1加密后生成的字符串长度分别为32和40。
分享到:
相关推荐
以下是一个简单的Java MD5加密工具类示例: ```java import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; public class MD5Util { private static final String MD5 = "MD5"; ...
以上代码中,`encryptMD5`和`encryptSHA256`方法分别实现了MD5和SHA-256的加密过程。它们首先创建一个`MessageDigest`实例,然后使用`digest()`方法对输入的密码字符串进行散列处理,最后将结果转换为16进制字符串。...
本文将详细介绍一个Java实现的MD5加密工具类,包括其核心功能、实现原理以及如何使用。 #### 二、工具类核心功能 该Java_MD5加密工具类提供了以下主要功能: 1. **转换字节数组为16进制字符串**:将字节数组转换...
java加密工具类。提供各种加密方法,加密方法有:aes,des,md5,sha等加密方式
MD5Utils 是一个工具类,提供了 MD5Encode 方法来实现 MD5 加密。该方法将输入的字符串转换为 byte 数组,然后使用 MessageDigest 类的 getInstance 方法获取 MD5 加密对象,最后将加密后的哈希值转换为字符串。 二...
这些文件名表明了几个关键的加密算法实现,包括AES(高级加密标准)、DES(数据加密标准)、MD5(消息摘要算法5)、SHA(安全散列算法)以及3DES(三重DES)。下面我们将详细探讨这些加密工具类在Java中的应用及其...
Java作为一种广泛应用的编程语言,提供了丰富的库和工具来实现各种加密算法,如MD5和SHA-1。这两种散列函数是信息安全领域的基石,用于确保数据的完整性并验证其来源。 MD5(Message-Digest Algorithm 5)是一种...
2. **Java实现**:在Java中,`java.security.MessageDigest`类提供了对包括MD5在内的多种哈希算法的支持。首先需要实例化`MessageDigest`对象,然后调用`digest()`方法对数据进行哈希计算,最后将得到的字节数组转换...
js javascript 加密 MD5 SHA
### MD5加密工具类知识点详解 #### 一、MD5简介 MD5(Message-Digest Algorithm 5)是一种广泛使用的密码散列函数,可以产生一个128位(16字节)的散列值(又称哈希值)。它通过一个可变长度的数据块输入,产生一个...
为了更好地理解和使用这个工具类,你需要了解基本的MD5和签名算法原理,并熟悉如何在代码中调用这些工具类的方法。同时,注意MD5虽然快速但已不再被视为安全的哈希算法,因为它容易产生碰撞,不适合用于存储敏感信息...
MD5和SHA可用于文件校验;AES适合大量数据的高效加密;而RSA则用于保障公钥通信的安全。这些JavaScript文件的集成,使得开发者能够在浏览器环境中轻松实现这些加密功能,增强了Web应用的安全性。 综上所述,这个...
这个jar包包含了一系列用于MD5加密的Java类和方法。开发者可以将其导入项目中,通过调用相关API实现对字符串、文件等进行MD5加密。通常,它会包含以下几个关键组件: - `MessageDigest` 类:这是Java标准库中的类,...
在IT领域,加密算法是确保数据安全的重要工具。在Java编程语言中,开发人员经常使用各种加密技术来保护敏感信息,...然而,需要注意的是,随着技术的发展,MD5和SHA1的安全性已逐渐下降,应当考虑使用更新的加密标准。
本文将详细介绍在Kotlin中实现的几种主要加密算法,包括AES、DES、CBC/ECB模式、MD5、SHA1以及SHA256。这些算法在数据保护、网络安全以及密码学中扮演着关键角色。 1. **AES(Advanced Encryption Standard)**:...
例如,可以使用`java.security.MessageDigest`类实现MD5和SHA哈希计算,`javax.crypto.Cipher`类处理DES和AES的加密解密,而`java.util.Base64`类则用于BASE64编码解码。 总的来说,这个"加密算法工具类"提供了一站...
这个"Java-MD5加密工具.rar"提供了一个简单的MD5加密工具类,方便开发者快速实现数据的哈希加密。 MD5的工作原理是将输入的数据分割成512位的块,并对每个块进行一系列复杂的计算,最终生成一个128位(16字节)的...
在Java编程领域,加密工具类是开发过程中必不可少的...开发者可以根据项目需求选择合适的工具类,也可以作为理解这些基本概念和实现方式的参考。在实际使用时,务必遵循相关的安全规范,确保应用程序的安全性和合规性。