侧边栏壁纸
  • 累计撰写 49 篇文章
  • 累计创建 29 个标签
  • 累计收到 6 条评论

目 录CONTENT

文章目录

【DES】java/oracle通用的对称加密算法

JHL&WWZ
2023-03-31 / 0 评论 / 0 点赞 / 731 阅读 / 823 字 / 正在检测是否收录...

Oracle

# 创建解密函数
create or replace FUNCTION "DECRYPT_FUNCTION" (V_STR VARCHAR2, V_KEY VARCHAR2)
  RETURN VARCHAR2 AS
  V_KEY_RAW    RAW(24);
  V_STR_RAW    RAW(2000);
  V_RETURN_STR VARCHAR2(2000);
  V_TYPE       PLS_INTEGER;
BEGIN
  /************************************************
     解密函数 FUN_DECRYPTION 
        入参:
          V_STR 输入密文字符串,约定密文为16进制字符串
          V_KEY 输入密钥字符串,长度为24字节
        返回值:
          V_RETURN_STR 返回明文字符串
        异常处理:
          此函数不对任何异常做捕捉处理,请相应的程序模块对异常做捕捉处理。
        加密方式:
          密钥位数:AES192   DBMS_CRYPTO.ENCRYPT_AES192
          连接方式:CBC      DBMS_CRYPTO.CHAIN_CBC
          填充方式:PKCS5    DBMS_CRYPTO.PAD_PKCS5
  ***************************************************/
  V_KEY_RAW := UTL_I18N.STRING_TO_RAW(V_KEY, 'ZHS16GBK');
  V_STR_RAW := HEXTORAW(V_STR);
  -- 指定‘密钥算法’、‘工作模式’、‘填充方式’
  V_TYPE       := DBMS_CRYPTO.ENCRYPT_DES + DBMS_CRYPTO.CHAIN_ECB +
                  DBMS_CRYPTO.PAD_PKCS5;
  V_STR_RAW    := DBMS_CRYPTO.DECRYPT(SRC => V_STR_RAW,
                                      TYP => V_TYPE,
                                      KEY => V_KEY_RAW);
  V_RETURN_STR := UTL_I18N.RAW_TO_CHAR(V_STR_RAW, 'ZHS16GBK');
  RETURN V_RETURN_STR;
  EXCEPTION
  WHEN OTHERS THEN
  V_RETURN_STR := null;
  RETURN V_RETURN_STR ; 
END;

# 创建加密函数
create or replace FUNCTION "ENCRYPT_FUNCTION" (
  V_STR        VARCHAR2, V_KEY VARCHAR2) RETURN VARCHAR2 AS V_KEY_RAW RAW(24);
  V_STR_RAW    RAW(2000);
  V_RETURN_STR VARCHAR2(2000);
  V_TYPE       PLS_INTEGER;
BEGIN
  /*************************************************
    加密函数 FUN_ENCRYPTION 
        入参:
          V_STR 输入明文字符串
          V_KEY 输入密钥字符串,长度为24字节
        返回值:
          V_RETURN_STR 返回密文字符串,约定返回为 16进制密文字符串
        异常处理:
          此函数不对任何异常做捕捉处理,请相应的程序模块对异常做捕捉处理。
        加密方式:
          密钥位数:AES192   DBMS_CRYPTO.ENCRYPT_AES192
          连接方式:CBC      DBMS_CRYPTO.CHAIN_CBC
          填充方式:PKCS5    DBMS_CRYPTO.PAD_PKCS5
  **************************************************/
  V_KEY_RAW    := UTL_I18N.STRING_TO_RAW(V_KEY, 'ZHS16GBK');
  V_STR_RAW    := UTL_I18N.STRING_TO_RAW(V_STR, 'ZHS16GBK');
  -- 指定‘密钥算法’、‘工作模式’、‘填充方式’
  V_TYPE       := DBMS_CRYPTO.ENCRYPT_DES + DBMS_CRYPTO.CHAIN_ECB +
                  DBMS_CRYPTO.PAD_PKCS5;
  V_STR_RAW    := DBMS_CRYPTO.ENCRYPT(SRC => V_STR_RAW,
                                      TYP => V_TYPE,
                                      KEY => V_KEY_RAW);
  V_RETURN_STR := RAWTOHEX(V_STR_RAW);
  RETURN V_RETURN_STR;
  /* EXCEPTION
  WHEN OTHERS THEN
  RETURN SQLERRM||SQLCODE ;   */
END;

# 函数使用
SELECT ENCRYPT_FUNCTION('123', 'abcdefg2') FROM dual;
SELECT DECRYPT_FUNCTION('EB13B05FAA8B5016', 'abcdefg2') FROM dual;

Java

import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;
import java.nio.charset.StandardCharsets;

public class Des {

    public static String decrypt(String cipherText, String secretKey) throws Exception {
        byte[] keyBytes = secretKey.getBytes(StandardCharsets.UTF_8);

        SecretKeySpec keySpec = new SecretKeySpec(keyBytes, "DES");

        Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding");
        cipher.init(Cipher.DECRYPT_MODE, keySpec);

        // 将十六进制字符串转换为 byte 数组
        byte[] encrypted = new byte[cipherText.length() / 2];
        for (int i = 0; i < encrypted.length; i++) {
            int index = i * 2;
            int j = Integer.parseInt(cipherText.substring(index, index + 2), 16);
            encrypted[i] = (byte) j;
        }

        byte[] decrypted = cipher.doFinal(encrypted);
        return new String(decrypted, StandardCharsets.UTF_8);
    }



    public static String encrypt(String plainText, String secretKey) throws Exception {
        byte[] keyBytes = secretKey.getBytes(StandardCharsets.UTF_8);
        SecretKeySpec keySpec = new SecretKeySpec(keyBytes, "DES");

        Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding");
        cipher.init(Cipher.ENCRYPT_MODE, keySpec);

        byte[] encrypted = cipher.doFinal(plainText.getBytes(StandardCharsets.UTF_8));

        StringBuilder hexString = new StringBuilder();
        for (byte b : encrypted) {
            // 使用 String.format 将 byte 格式化为两位的十六进制字符串
            hexString.append(String.format("%02x", b & 0xFF));
        }

        return hexString.toString().toUpperCase();
    }


    public static void main(String[] args) throws Exception {
        System.out.println(decrypt("FAD3A91C75EE66C0", "abcdefg2"));
        System.out.println(encrypt("123", "abcdefg2"));
    }

}
0

评论区