`
keepwork
  • 浏览: 334020 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论
阅读更多
开发者博客:http://www.developsearch.com

/**
 * 加密、解密工具类 包装cipher对象的操作
 * 基于javax.crypto.*、java.security.*、org.apache.commons.codec.binary.Base64实现
 * 解密、加密包装。该工具类仅仅是对底层方法的包装,提供更友好的API使用,本身不包含任何加密、解密
 * 算法;所有加密、解密算法均依赖于JDK提供的包实现;
 * 
 * @author chenxin
 * @version [版本号, 2012-5-21]
 * @see [相关类/方法]
 * @since [产品/模块版本]
 */
public class CryptUtil {

	/**
	 * 单态实例对象
	 */
	private static final CryptUtil instance = new CryptUtil();

	/**
	 * Base64解码对象
	 */
	private static final BASE64Decoder base64De = new BASE64Decoder();
	
	/**
	 * Base64加码对象
	 */
	private static final BASE64Encoder base64En = new BASE64Encoder();
	
	/**
	 * 密码类型
	 * @author ahli
	 * @version IMPV100R001DA0, Nov 18, 2009 
	 * @since CMS IMPV100R001DA0
	 */
	public enum CipherType{
		AES,
		DES
	}
	
	/**
	 * 私有构造函数,避免被外部实例化
	 */
	private CryptUtil()
	{
	};

	/**
	 * 获取单态实例对象
	 * @return
	 */
	public static CryptUtil getInstance()
	{
		return instance;
	}

	/**
	 * 产生随机的密钥
	 * 例如:“xjPk2rOSU1n5v70a84M+vw==”
	 * @return    随机密钥
	 */
	public String genRandomKeyStr(CipherType type)
	{
		SecretKey key;
		try
		{
			key = KeyGenerator.getInstance(type.toString()).generateKey();
			return base64En.encode(key.getEncoded());
		}
		catch (NoSuchAlgorithmException e)
		{
			return null;
		}
	}

	/**
	 * 加密文本
	 * @param str      明文
	 * @param key      密钥
	 * @param type     密码类型
	 * @return         密文
	 */
	public String encrypt(String str, String key, CipherType type)
	{
		try
		{
			Cipher cipher = Cipher.getInstance(type.toString());
			cipher.init(Cipher.ENCRYPT_MODE, initKey(type.toString(), key));
			return new String(Base64.encodeBase64(cipher.doFinal(str.getBytes("UTF-8"))));
		}
		catch (IOException e)
		{
			e.printStackTrace();
		}
		catch (GeneralSecurityException e)
		{
			e.printStackTrace();
		}
		return null;
	}

	/**
	 * 解密
	 * @param str     密文
	 * @param key     密钥
	 * @param type    密码算法
	 * @return        明文
	 */
	public String decrypt(String str, String key, CipherType type)
	{
		try
		{
			Cipher cipher = Cipher.getInstance(type.toString());
			cipher.init(Cipher.DECRYPT_MODE, initKey(type.toString(), key));
			return new String(cipher.doFinal( base64De.decodeBuffer(str)), "UTF-8");
		}
		catch (IOException e)
		{
			e.printStackTrace();
		}
		catch (GeneralSecurityException e)
		{
			e.printStackTrace();
		}
		return null;
	}

	/**
	 * 初始化密钥
	 * @param cryptType    加密算法类型
	 * @param key          密钥
	 * @return
	 * @throws UnsupportedEncodingException
	 */
	private Key initKey(String cryptType, String key) throws UnsupportedEncodingException{
		SecretKey secretKey = new SecretKeySpec(Base64.decodeBase64(key.getBytes("UTF-8")), cryptType);
		return secretKey;
	}
	
	public static void main(String[] args)
	{
//		String randomKey = CryptUtil.getInstance().genRandomKeyStr(CipherType.AES);
		String randomKey = "C1ZZsBNd0JY/8Yx2nPEg2g==";
		System.out.println("randomKey:" + randomKey);
		String message = "cms4a";
		System.out.println("加密前明文:" + message);
		String s1 = CryptUtil.getInstance().encrypt(message, randomKey, CipherType.AES);
		System.out.println("加密后的信息:" + s1);
		String s2 = CryptUtil.getInstance().decrypt(s1, randomKey, CipherType.AES);
		System.out.println("解密后的信息:" + s2);
	}


}
分享到:
评论

相关推荐

    cryptutil:加密算法包装器,易于使用RSA,AES,DES等

    本文将详细介绍`cryptutil`,这是一个针对Go语言设计的加密算法包装器,它使得开发者能够轻松地使用包括RSA、AES和DES在内的多种加密算法。 首先,让我们了解一下`cryptutil`的基本概念。`cryptutil`是一个开源的Go...

    CryptUtil.java

    CryptUtil.java

    COCOVOICE协议逆向

    通过对`com.azus.android.tcplogin.CryptUtil`类的反编译,我们可以看到COCOVOICE使用了标准的RSA和AES加密算法实现数据加密。 #### 五、Xposed Hook测试 使用XPOSED框架Hook关键加密函数,如`rsaEncrypt()`、`aes...

    JAVA工具模块TBOX

    6. **加密解密工具类(CryptUtil)**:CryptUtil包含了一系列的加密算法,如MD5、SHA、AES等,用于数据的安全存储和传输。同时,它也支持Base64编码和解码,便于处理二进制数据。 7. **反射和注解工具类(ReflectUtil,...

    JAVA工具类项目(用于平时的开发)

    5. **加密解密**:`CryptUtil`提供了常见的加密算法,如MD5、SHA、AES、DES等,帮助保护数据安全。 6. **集合操作**:`BeanUtil`和`CollUtil`分别对Java Bean对象和集合类进行了增强,提供了更灵活的属性操作和集合...

    hutool-v5-master.zip

    7. **加密解密**:CryptUtil包含了常见的加密解密算法,如MD5、SHA、AES、DES等,为数据安全提供了便利。 8. **集合操作**:CollUtil提供了对Java集合框架的扩展,包括列表、映射、队列等操作,以及一些集合的实用...

    hutool-all-5.4.2_如何用hutool-all_hutoll_hutool-all_

    5. **加密解密**:Hutool的CryptUtil提供了多种加密算法,如MD5、SHA、AES等,方便进行数据安全处理。这对于处理敏感信息的场景,如密码存储、数据传输,起到了关键作用。 6. **数据库操作**:DbUtil是Hutool的...

    dromara-hutool-v5-master.zip

    CryptUtil模块包含MD5、SHA、AES、DES等多种加密算法,满足安全需求。 7. **线程与并发**: ThreadUtil模块提供了线程的控制和管理,如线程的启动、停止、等待、唤醒等。 8. **数据库操作**: DBUtil模块提供了...

    java加密工具包AES SHA SHA1 SHA256 BASEENCODE64

    在`CryptUtil.java`这个文件中,我们可以预期它可能包含了上述所有加密和编码方法的实现。这个工具类可能会提供静态方法,方便开发者对数据进行AES加密、SHA哈希计算以及Base64编码解码操作。通过这个工具类,开发者...

Global site tag (gtag.js) - Google Analytics