欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java使用Hex編碼解碼實現Aes加密解密功能示例

 更新時間:2017年01月05日 14:09:25   作者:QH_JAVA  
這篇文章主要介紹了java使用Hex編碼解碼實現Aes加密解密功能,結合完整實例形式分析了Aes加密解密功能的定義與使用方法,需要的朋友可以參考下

本文實例講述了java使用Hex編碼解碼實現Aes加密解密功能。分享給大家供大家參考,具體如下:

這里的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);
        // 正式執(zhí)行加密操作
        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);
        // 正式執(zhí)行解密操作
        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 = "這個值一般都是給定的,雙發(fā)都知道";
      // 加密
      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[])這個方法!

PS:關于加密解密感興趣的朋友還可以參考本站在線工具:

密碼安全性在線檢測:
http://tools.jb51.net/password/my_password_safe

高強度密碼生成器:
http://tools.jb51.net/password/CreateStrongPassword

迅雷、快車、旋風URL加密/解密工具:
http://tools.jb51.net/password/urlrethunder

在線散列/哈希算法加密工具:
http://tools.jb51.net/password/hash_encrypt

在線MD5/hash/SHA-1/SHA-2/SHA-256/SHA-512/SHA-3/RIPEMD-160加密工具:
http://tools.jb51.net/password/hash_md5_sha

在線sha1/sha224/sha256/sha384/sha512加密工具:
http://tools.jb51.net/password/sha_encode

希望本文所述對大家java程序設計有所幫助。

相關文章

  • Java源碼解析重寫鎖的設計結構和細節(jié)

    Java源碼解析重寫鎖的設計結構和細節(jié)

    這篇文章主要為大家介紹了Java源碼解析重寫鎖的設計結構和細節(jié),這小節(jié)我們以共享鎖作為案列,自定義一個共享鎖。有需要的朋友可以借鑒參考下
    2022-03-03
  • Java判斷時間段內文件是否更新的方法

    Java判斷時間段內文件是否更新的方法

    這篇文章主要介紹了Java判斷時間段內文件是否更新的方法,通過實例形式講述了定時器、類加載器及線程等方法實現判斷文件更新的功能,具有一定的參考借鑒價值,需要的朋友可以參考下
    2014-12-12
  • Java 數據類型及類型轉換的互相轉換實例代碼

    Java 數據類型及類型轉換的互相轉換實例代碼

    這篇文章主要介紹了Java 數據類型及類型轉換的互相轉換實例代碼,需要的朋友可以參考下
    2020-10-10
  • Java客戶端調用.NET的WebService實例

    Java客戶端調用.NET的WebService實例

    下面小編就為大家?guī)硪黄狫ava客戶端調用.NET的WebService實例。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • java實現簡單網絡象棋游戲

    java實現簡單網絡象棋游戲

    這篇文章主要為大家詳細介紹了java實現簡單網絡象棋游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-12-12
  • 淺談Java編程中的內存泄露情況

    淺談Java編程中的內存泄露情況

    這篇文章主要介紹了Java編程中的內存泄露情況,牽扯到JVM的垃圾回收相關知識,需要的朋友可以參考下
    2015-10-10
  • java和 javaw 及 javaws的區(qū)別解析

    java和 javaw 及 javaws的區(qū)別解析

    這篇文章主要介紹了java和 javaw 及 javaws的區(qū)別解析,本文通過實例給大家詳細介紹,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-06-06
  • 使用maven實現版本覆蓋的案例分享

    使用maven實現版本覆蓋的案例分享

    這篇文章主要介紹了使用maven實現版本覆蓋的案例分享,文中通過圖文結合的方式給大家講解的非常詳細,對大家的學習或工作有一定的幫助,需要的朋友可以參考下
    2024-10-10
  • 關于java連接池/線程池/內存池/進程池等匯總分析

    關于java連接池/線程池/內存池/進程池等匯總分析

    這篇文章主要介紹了關于java連接池/線程池/內存池/進程池等匯總分析,本文將介紹池技術的由來、原理、優(yōu)缺點以及常見的池技術類型,需要的朋友可以參考下
    2023-04-04
  • Java Web之限制用戶多處登錄實例代碼

    Java Web之限制用戶多處登錄實例代碼

    本篇文章主要介紹了Java Web之限制用戶多處登錄實例代碼,可以限制單個用戶在多個終端登錄。非常具有實用價值,需要的朋友可以參考下。
    2017-03-03

最新評論