`

加密相关类

 
阅读更多
import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;

/**
 * ASC加密解密辅助类.
 * 
 * @author admin
 * @version 1.0.0
 * 
 */
public class AesUtil {
	private static final String AES = "AES";
	private static final String CRYPT_KEY = "YUUAtestYUUAtest";

	/**
	 * 加密.
	 * 
	 * @param src
	 * @param key
	 * @return
	 * @throws Exception
	 */
	private static byte[] encrypt(byte[] src, String key) throws Exception {
		Cipher cipher = Cipher.getInstance(AES);
		SecretKeySpec securekey = new SecretKeySpec(key.getBytes(), AES);
		cipher.init(Cipher.ENCRYPT_MODE, securekey);
		
		return cipher.doFinal(src);
	}

	/**
	 * 解密.
	 * 
	 * @param decryptStr
	 * @return
	 * @throws Exception
	 */
	private static byte[] decrypt(byte[] src, String key) throws Exception {
		Cipher cipher = Cipher.getInstance(AES);
		SecretKeySpec securekey = new SecretKeySpec(key.getBytes(), AES);
		cipher.init(Cipher.DECRYPT_MODE, securekey);
		
		return cipher.doFinal(src);
	}

	/**
	 * 二行制转十六进制字符串.
	 * 
	 * @param b
	 * @return
	 */
	private static String byte2hex(byte[] b) {
		String hs = "";
		String stmp = "";
		
		for (int n = 0; n < b.length; n++) {
			stmp = (java.lang.Integer.toHexString(b[n] & 0XFF));
			
			if (stmp.length() == 1) {
				hs = hs + "0" + stmp;
			} 
			else{
				hs = hs + stmp;
			}
		}
		
		return hs.toUpperCase();
	}

	private static byte[] hex2byte(byte[] b) {
		if ((b.length % 2) != 0) {
			throw new IllegalArgumentException("长度不是偶数");
		}
		
		byte[] b2 = new byte[b.length / 2];
		
		for (int n = 0; n < b.length; n += 2) {
			String item = new String(b, n, 2);
			b2[n / 2] = (byte) Integer.parseInt(item, 16);
		}
		
		return b2;
	}

	/**
	* 解密(供外部调用).
	* 
	* @param data
	* @return
	* @throws Exception
	*/
	public final static String decrypt(String data) {
		try {			
			return new String(decrypt(hex2byte(data.getBytes()), CRYPT_KEY));
		} 
		catch (Exception e) {
			e.printStackTrace();
		}
		
		return null;
	}

	/**
	* 加密(供外部调用).
	* 
	* @param data
	* @return
	* @throws Exception
	*/
	public final static String encrypt(String data) {
		try {
			return byte2hex(encrypt(data.getBytes(), CRYPT_KEY));
		} 
		catch (Exception e) {
			e.printStackTrace();
		}
		
		return null;
	}
}

 

分享到:
评论

相关推荐

    C#ASP.NET 加密帮助类

    6. 密码重置和身份验证:在Web应用程序中,加密帮助类还可能包含与用户密码重置、身份验证相关的函数,如盐值加盐哈希、验证用户输入的密码等。 总之,`MyJiaMi.cs`这个加密帮助类很可能封装了上述的加密和哈希功能...

    3DES 加密类 加密

    在C++中实现3DES加密,需要包含相关库,如`&lt;openssl/des.h&gt;`。首先,你需要创建一个3DES上下文环境,设置密钥,然后可以进行加密和解密操作。以下是一个简化的3DES加密过程: ```cpp #include void encrypt_3des...

    PHP 加密解密处理类

    本主题将深入探讨“PHP加密解密处理类”的相关知识点,旨在帮助开发者理解和应用这一技术。 PHP作为一种广泛使用的服务器端脚本语言,提供了多种加密和解密方法,以保护敏感数据,如用户密码、API密钥或交易信息。...

    QtChecks.zip

    Qt是Qt Company开发的一款跨平台的应用程序开发框架,广泛用于创建桌面、移动和嵌入式设备的用户界面。...因此,深入学习Qt的加密相关类和函数,以及遵循最佳安全实践,是每个Qt开发者必备的技能。

    JS(javascript)-md5加密工具类

    JavaScript中的MD5加密工具类是用于对数据进行安全哈希的一种方法,广泛应用于密码存储、数据完整性校验等场景。MD5(Message-Digest Algorithm 5)是一种广泛使用的哈希函数,它能将任意长度的输入转化为固定长度的...

    kotlin 加密算法工具类

    在IT行业中,加密算法是...总之,Kotlin中的加密算法工具类集成了多种加密方法,为开发人员提供了方便的数据保护手段。在选择合适的加密算法时,应考虑性能、安全性以及应用场景,确保数据在传输和存储过程中的安全性。

    java MD5加密工具类

    要创建一个MD5加密工具类,首先需要导入相关库: ```java import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import java.nio.charset.StandardCharsets; ``` 接下来,我们...

    MD5加密工具类

    通过上述内容,我们不仅了解了MD5的基本概念和MD5Util工具类的具体实现,还探讨了其在实际开发中的应用场景以及相关的安全性考虑。这对于从事软件开发工作的技术人员来说是非常有价值的知识点。

    c#加密解密类源码

    本文将详细解析C#中加密解密的相关知识点,包括基础概念、常用算法以及如何实现。 首先,我们需要理解加密和解密的基本原理。加密是将明文数据转化为密文的过程,目的是保护数据的隐私;而解密则是将密文还原为原始...

    C# 对称加密类算法

    根据提供的文件信息,我们可以总结出以下关于C#中对称加密类算法的相关知识点: ### 一、对称加密概述 对称加密是一种加密技术,在这种技术中,加密和解密都使用同一个密钥。常见的对称加密算法包括AES(高级加密...

    rsa+aes加密传输工具类及案例

    同时,我们也会探讨相关的工具类和案例。 首先,RSA(Rivest-Shamir-Adleman)是一种非对称加密算法,它基于大数因子分解的数学难题。RSA的核心在于一对公钥和私钥,其中公钥用于加密,私钥用于解密。这种机制使得...

    php支持中英文的加密解密类

    本文将详细讲解一个专为支持中英文加密解密而设计的PHP类,并探讨相关的核心知识点。 首先,PHP提供了一些内置的加密库,如mcrypt(已废弃)和openssl,但它们可能不直接支持中文字符的加密。因此,开发者通常需要...

    常用加密工具类(JAVA).zip

    在Java编程领域,加密工具类是开发过程中必不可少的一部分,它们用于保护数据安全,防止未经授权的访问。本资源包“常用加密工具类(JAVA).zip”提供了12个不同的加密和排序工具类,以及一个log4j配置文件,旨在...

    网络攻防技术-实现Tor 加密流量分类(源码).zip

    2、该资源适合计算机相关专业(如计科、人工智能、大数据、数学、电子信息等)正在做课程设计、期末大作业和毕设项目的学生、或者相关技术学习者作为学习资料参考使用。 3、该资源包括全部源码,需要具备一定基础才能...

    php实现的加密解密处理类.zip

    这个压缩包提供的“加密解密处理类”可能是为了简化这个过程,提供了一种封装好的解决方案。它可能包含以下功能: 1. 支持多种加密算法:类库可能会提供对多种加密算法的支持,允许开发者根据需求选择合适的算法。 ...

    qt5AES加密,ES加密/解密算法是一种可逆的对称加密算法,这类算法在加密和解密时使用相同的密钥,或是使用两个可以简单地相互推

    这个文件可能包含了实现AES加密解密功能的源代码、示例、文档或其他相关资源,帮助开发者在Qt5应用程序中集成AES加密。 **总结** AES加密算法是现代加密的标准之一,常用于保护数据的安全。在Qt5开发中,可以方便...

    JAVA实现AES加密解密工具类

    本篇文章将深入探讨如何在Java中实现AES加密解密,并介绍相关的关键知识点。 首先,我们需要理解AES加密的基本原理。AES是一种块密码,它以固定大小的数据块(128位)为单位进行操作。加密和解密过程都基于一系列...

    C++ 代码实现DES加密解密源代码类

    在C++中实现DES加密解密,可以创建一个类来封装相关的操作,这样有利于代码的复用和维护。 描述中提到的"单倍双倍加密算法的实现",可能是指使用DES算法进行一次或两次加密的过程。单次DES加密使用同一个密钥对数据...

    Bcrypt加密相关jar包

    这里我们关注的是"Bcrypt加密相关jar包",它包含了用于Java环境的Bcrypt实现,以及相关的辅助库。 Bcrypt是由Niels Provos和David Mazières基于Blowfish加密算法设计的,它通过引入一个随机盐值,使得每次对相同的...

    RSA加密签名Demo(直接根据原理写,未使用javaRSA相关类)

    RSA加密签名Demo是一种基于RSA公钥密码体制的示例,它展示了如何不依赖Java的内置RSA类库(如java.security)来实现加密和签名过程。RSA是一种非对称加密算法,由Ron Rivest、Adi Shamir和Leonard Adleman在1977年...

Global site tag (gtag.js) - Google Analytics