AES 加密 解密(Hex编码解码)

Aes加密解密方法使用Hex进行了编码解码

package com.baidu.wallet.bdwallet.utils;
import java.io.UnsupportedEncodingException;  
import java.security.InvalidKeyException;  
import java.security.NoSuchAlgorithmException;  
import javax.crypto.BadPaddingException;  
import javax.crypto.Cipher;  
import javax.crypto.IllegalBlockSizeException;  
import javax.crypto.NoSuchPaddingException;  
import javax.crypto.spec.SecretKeySpec; 
import org.apache.commons.codec.DecoderException;
import org.apache.commons.codec.binary.Hex;
public class Test {
	 private  static final String AES="AES";  
	 private  static final String UTF8="UTF-8";  
	    
	   /**
	    * AES加密
	    * @param content
	    * @param pkey
	    * @return
	    * @throws DecoderException
	    */
	    private static byte[] encrypt(String content, String pkey) throws DecoderException {  
	        try {  
	            String private_key=pkey;
	            byte[] encodeFormat=null;
				try {
					//秘钥 Hex解码为什么秘钥要进行解码,因为秘钥是某个秘钥明文进行了Hex编码后的值,所以在使用的时候要进行解码
					encodeFormat = Hex.decodeHex(private_key.toCharArray());
				} catch (DecoderException e) {
					e.printStackTrace();
				}
	            SecretKeySpec key = new SecretKeySpec(encodeFormat, AES);  
	            // Cipher对象实际完成加密操作  
	            Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");    
	            // 加密内容进行编码  
	            byte[] byteContent = content.getBytes(UTF8);  
	            // 用密匙初始化Cipher对象  
	            cipher.init(Cipher.ENCRYPT_MODE, key); 
	            // 正式执行加密操作  
	            byte[] result = cipher.doFinal(byteContent);  
	            return result;  
	        } catch (NoSuchAlgorithmException e) {  
	            e.printStackTrace();  
	        } catch (NoSuchPaddingException e) {  
	            e.printStackTrace();  
	        } catch (InvalidKeyException e) {  
	            e.printStackTrace();  
	        } catch (UnsupportedEncodingException e) {  
	            e.printStackTrace();  
	        } catch (IllegalBlockSizeException e) {  
	            e.printStackTrace();  
	        } catch (BadPaddingException e) {  
	            e.printStackTrace();  
	        }  
	        return null;  
	    }  
	  
	    /**
	     * AES解密
	     * @param contents
	     * @param password
	     * @return
	     * @throws DecoderException
	     */
	    private static byte[] decrypt(String contents, String password) throws DecoderException {  
	        try { 
	        	//密文使用Hex解码
	        	byte[]content = Hex.decodeHex(contents.toCharArray());  
	        	//秘钥 Hex解码为什么秘钥要进行解码,因为秘钥是某个秘钥明文进行了Hex编码后的值,所以在使用的时候要进行解码
	            byte[] encodeFormat = Hex.decodeHex(password.toCharArray()); 
	            SecretKeySpec key = new SecretKeySpec(encodeFormat, AES);  
	            // Cipher对象实际完成加密操作  
	            Cipher cipher = Cipher.getInstance(AES);  
	            // 用密匙初始化Cipher对象  
	            cipher.init(Cipher.DECRYPT_MODE, key);  
	            // 正式执行解密操作  
	            byte[] result = cipher.doFinal(content);  
	            return result;  
	        } catch (NoSuchAlgorithmException e) {  
	            e.printStackTrace();  
	        } catch (NoSuchPaddingException e) {  
	            e.printStackTrace();  
	        } catch (InvalidKeyException e) {  
	            e.printStackTrace();  
	        } catch (IllegalBlockSizeException e) {  
	            e.printStackTrace();  
	        } catch (BadPaddingException e) {  
	            e.printStackTrace();  
	        }  
	        return null;  
	    }  
	  
	    /**
	     * Aes加密
	     * @param context 明文
	     * @param private_key 秘钥
	     * @return 
	     * @throws DecoderException
	     */
	   public static String  encryption(String context,String private_key) throws DecoderException{
		   //加密后的明文也就变成了密文
		   byte[] encryptResult = encrypt(context, private_key);  
		   //密码文Hex编码
	       String encryptResultStr = Hex.encodeHexString(encryptResult);
		   return encryptResultStr;
	   }
	   
	   /**
	    * Aes解密
	    * @param context 密文
	    * @param private_key 秘钥
	    * @return
	    * @throws DecoderException
	    * @throws UnsupportedEncodingException
	    */
	   public static String decryption(String context,String private_key) throws DecoderException, UnsupportedEncodingException{
		  //这里的密文解密前先进行了Hex解码
		   byte[] decryptResult = decrypt(context, private_key); 
		   String result = new String(decryptResult, UTF8); 
		   return result;
	   }
	  
	  
	    public static void main(String[] args) throws UnsupportedEncodingException, DecoderException { 
	    	//加密内容
	        String content = "123456787654321";  
	        //AES加密解密秘钥
	        String password = "这个值一般都是给定的,双发都知道";
	        // 加密  
	        System.out.println("加密前:" + content);  
	        // 调用加密方法
	        String encryptResultStr = encryption(content, password);  
	        System.out.println("加密后:" + encryptResultStr);  
	        // 调用解密方法
	        String result  = decryption(encryptResultStr, password);  
	        // 解密内容进行解码  
	        System.out.println("解密后:" + result);  
	    }  
}
这个方法在正式的项目中已经在使用木有问题,注意这里的AES加密解密你要要对哦……
上面使用的就是org.apache.commons.codec.binary.Hex这个类的方法,在maven中配置如下:

<dependency>  
            <groupId>commons-codec</groupId>  
            <artifactId>commons-codec</artifactId>  
            <version>1.4</version>  
        </dependency>  
注意:这里要使用1.4以及以上版本,应为1.4以下的没有Hex.encodeHexString(byte[])这个方法!




hex编码实现AES加密解密功能示例可以按照以下步骤进行: 1. 导入所需的模块: ```python import binascii from Crypto.Cipher import AES from Crypto.Random import get_random_bytes ``` 2. 定义AES加密解密函数: ```python def encrypt(plain_text, key): cipher = AES.new(key, AES.MODE_EAX) nonce = cipher.nonce ciphertext, tag = cipher.encrypt_and_digest(plain_text.encode()) return binascii.hexlify(nonce + ciphertext + tag).decode() def decrypt(cipher_text, key): cipher_data = binascii.unhexlify(cipher_text) nonce = cipher_data[:16] ciphertext = cipher_data[16:-16] tag = cipher_data[-16:] cipher = AES.new(key, AES.MODE_EAX, nonce) decrypted_text = cipher.decrypt_and_verify(ciphertext, tag) return decrypted_text.decode() ``` 3. 生成随机密钥: ```python key = get_random_bytes(16) ``` 4. 加密解密示例数据: ```python plain_text = "This is a sample plaintext." cipher_text = encrypt(plain_text, key) decrypted_text = decrypt(cipher_text, key) ``` 完整的代码示例如下: ```python import binascii from Crypto.Cipher import AES from Crypto.Random import get_random_bytes def encrypt(plain_text, key): cipher = AES.new(key, AES.MODE_EAX) nonce = cipher.nonce ciphertext, tag = cipher.encrypt_and_digest(plain_text.encode()) return binascii.hexlify(nonce + ciphertext + tag).decode() def decrypt(cipher_text, key): cipher_data = binascii.unhexlify(cipher_text) nonce = cipher_data[:16] ciphertext = cipher_data[16:-16] tag = cipher_data[-16:] cipher = AES.new(key, AES.MODE_EAX, nonce) decrypted_text = cipher.decrypt_and_verify(ciphertext, tag) return decrypted_text.decode() key = get_random_bytes(16) plain_text = "This is a sample plaintext." cipher_text = encrypt(plain_text, key) decrypted_text = decrypt(cipher_text, key) print("Plain text:", plain_text) print("Encrypted text:", cipher_text) print("Decrypted text:", decrypted_text) ``` 这样,就可以使用hex编码实现AES加密解密功能了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值