`

Java实现的加密工具类(支持MD5和SHA)

    博客分类:
  • java
阅读更多

提出问题:MD5,SHA算法是常用的两种加密算法。以前看过很多人写的md5算法,要么过于难懂,要么过于冗长,而且不能切换为其他加密算法,非常不给力。
     分析和解决问题:于是,决定自己写一个简单好用的加密算法。翻看JDK1.5的API文档,惊喜的发现,在java.security这个包下面有一个MessageDigest类:此 MessageDigest 类为应用程序提供信息摘要算法的功能,如 MD5 或 SHA 算法。bingo!参考了部分网友的代码,本人的代码如下,不足之处,请大家批评指正。JDK/JRE版本:1.5+

Java代码 复制代码
  1. package common.util.security;   
  2.   
  3. import java.io.UnsupportedEncodingException;   
  4. import java.security.MessageDigest;   
  5. import java.security.NoSuchAlgorithmException;   
  6.   
  7. public class EncryptUtil {   
  8.   
  9.     public static void main(String[] args) {   
  10.         //md5加密测试   
  11.         String md5_1 = md5("123");   
  12.         String md5_2 = md5("abc");   
  13.         System.out.println(md5_1 + "\n" + md5_2);   
  14.         System.out.println("md5 length: " + md5_1.length());   
  15.         //sha加密测试   
  16.         String sha_1 = sha("123");   
  17.         String sha_2 = sha("abc");   
  18.         System.out.println(sha_1 + "\n" + sha_2);   
  19.         System.out.println("sha length: " + sha_1.length());   
  20.     }   
  21.   
  22.     // md5加密   
  23.     public static String md5(String inputText) {   
  24.         return encrypt(inputText, "md5");   
  25.     }   
  26.   
  27.     // sha加密   
  28.     public static String sha(String inputText) {   
  29.         return encrypt(inputText, "sha-1");   
  30.     }   
  31.   
  32.     /**  
  33.      * md5或者sha-1加密  
  34.      *   
  35.      * @param inputText  
  36.      *            要加密的内容  
  37.      * @param algorithmName  
  38.      *            加密算法名称:md5或者sha-1,不区分大小写  
  39.      * @return  
  40.      */  
  41.     private static String encrypt(String inputText, String algorithmName) {   
  42.         if (inputText == null || "".equals(inputText.trim())) {   
  43.             throw new IllegalArgumentException("请输入要加密的内容");   
  44.         }   
  45.         if (algorithmName == null || "".equals(algorithmName.trim())) {   
  46.             algorithmName = "md5";   
  47.         }   
  48.         String encryptText = null;   
  49.         try {   
  50.             MessageDigest m = MessageDigest.getInstance(algorithmName);   
  51.             m.update(inputText.getBytes("UTF8"));   
  52.             byte s[] = m.digest();   
  53.             // m.digest(inputText.getBytes("UTF8"));   
  54.             return hex(s);   
  55.         } catch (NoSuchAlgorithmException e) {   
  56.             e.printStackTrace();   
  57.         } catch (UnsupportedEncodingException e) {   
  58.             e.printStackTrace();   
  59.         }   
  60.         return encryptText;   
  61.     }   
  62.   
  63.     // 返回十六进制字符串   
  64.     private static String hex(byte[] arr) {   
  65.         StringBuffer sb = new StringBuffer();   
  66.         for (int i = 0; i < arr.length; ++i) {   
  67.             sb.append(Integer.toHexString((arr[i] & 0xFF) | 0x100).substring(1,   
  68.                     3));   
  69.         }   
  70.         return sb.toString();   
  71.     }  
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();
	}

 

运行结果代码 复制代码
  1. 上述代码的运行结果:   
  2. 202cb962ac59075b964b07152d234b70   
  3. 900150983cd24fb0d6963f7d28e17f72   
  4. md5 length: 32  
  5. 40bd001563085fc35165329ea1ff5c5ecbdbbeef   
  6. a9993e364706816aba3e25717850c26c9cd0d89d   
  7. sha length: 40  
上述代码的运行结果:
202cb962ac59075b964b07152d234b70
900150983cd24fb0d6963f7d28e17f72
md5 length: 32
40bd001563085fc35165329ea1ff5c5ecbdbbeef
a9993e364706816aba3e25717850c26c9cd0d89d
sha length: 40


    由此可见,MD5和SHA-1加密后生成的字符串长度分别为32和40。

分享到:
评论
1 楼 hellohank 2011-12-01  
这个……叫摘要算法,不叫加密算法~

相关推荐

    java加密工具类.zip

    java加密工具类。提供各种加密方法,加密方法有:aes,des,md5,sha等加密方式

    一个JS加密工具类MD5 SHA

    js javascript 加密 MD5 SHA

    java加密工具包AES SHA SHA1 SHA256 BASEENCODE64

    java加密工具包 包括 AES SHA SHA1 SHA256 BASEENCODE64 md5

    java版MD5/SHA验证工具

    MD5/SHA验证工具 无聊时写着玩儿的, 本程序具有一定的实用价值, 本人经常用其检查下载的文件是否有损坏等, 附带源码,可作为JAVA爱好者参考 算法直接调用Java的API,代码量:318行 jar文件双击直接运...

    Java常用的对密码加密的方法(MD5,SHA)

    博文链接:https://llying.iteye.com/blog/171256

    Java加密工具类,AES/DES/MD5/SHA/3DES

    商业项目使用报文和加解密和对数据进行加解密

    java加密与解密工具类

    java加密与解密工具类MD5方式加密SHA方式加密以MD5方式加密、加私钥

    加密算法工具类

    一个包含MD5.DES3,DES,AES,BASE64,SHA等常见的7种加密算法,可以直接下载集成到项目里面

    暴力破解AES DES SHA MD5

    用java写的暴力破解,专门破解AES,DES,SHA,MD5. 你们可以自己再次的去完善一下,这里纯属简单版本。 用java写的暴力破解,专门破解AES,DES,SHA,MD5. 你们可以自己再次的去完善一下,这里纯属简单版本。 用java写的...

    CryptUtil.java

    CryptUtil java工具加密类(支持 MD5、SHA、DES加密,解密)

    通用工具类

    3.常用加密算法工具类,包括MD5、SHA、DES、HMAC、Base64等 4.RSA加解密,RSA签名、签名验证类 5.文件处理工具类,实现文件的复制、移动、查找、追加内容等。支持自动识别文件编码,解决中文乱码问题 6.扩展Properties...

    加密代码,先是SHA然后盐值,最后MD5

    个人在开发中使用到的一个工具类,对字符串简单的加密,使用的是java提供的类

    JCT - java加密解密工具包

    JCT 为java开发者提供实用、方便、简洁的加密和...1.0版提供Blowfish,SHA与MD5数字摘要,PBE基于口令的加密,RSA算法工具类,使这些算法更容易在编成中使用.文件包中含源码、文档、class包WDSsoft:http://www.wdssoft.com

    java开源包4

    用来计算 MD5、SHA 哈希算法的 Java 类库,支持 "MD5", "SHA", "SHA-1", "SHA-256", "SHA-384", "SHA-512". 高性能RPC框架 nfs-rpc nfs-rpc是一个集成了各种知名通信框架的高性能RPC框架,目前其最好的性能为在采用...

    java开源包5

    用来计算 MD5、SHA 哈希算法的 Java 类库,支持 "MD5", "SHA", "SHA-1", "SHA-256", "SHA-384", "SHA-512". 高性能RPC框架 nfs-rpc nfs-rpc是一个集成了各种知名通信框架的高性能RPC框架,目前其最好的性能为在采用...

    java 工具类

    java 常用工具类,暂时包括MD5、SHA1、HMAC、3DES加密,进制转换

    java开源包7

    用来计算 MD5、SHA 哈希算法的 Java 类库,支持 "MD5", "SHA", "SHA-1", "SHA-256", "SHA-384", "SHA-512". 高性能RPC框架 nfs-rpc nfs-rpc是一个集成了各种知名通信框架的高性能RPC框架,目前其最好的性能为在采用...

    ToolsFx密码学工具箱-Java语言编写,是爬虫工程师的好用工具

    RSA-SHA384、RSA-SHA512、BLAKE2B512、MD4、MD5、MD5-SHA1、 MDC2、MDC2WITHRSA、SHA1、SHA224 、SHA256、SHA384、SHA 对称加密算法:AES、DES、IDEA、XXTEA等 非对称加密算法:RSA、SM(国产椭圆曲线密码)

Global site tag (gtag.js) - Google Analytics