如何将PLSQL中的DES对称加密方法在Java中实现解密操作?
- 内容介绍
- 文章标签
- 相关推荐
本文共计630个文字,预计阅读时间需要3分钟。
背景:某项目接口采用PLSQL开发,接口返回用户密码,但密码不是明文返回,因为程序内部需要使用明文密码。
接口内容:sqlCREATE OR REPLACE PROCEDURE get_user_password(p_user_id IN NUMBER, p_password OUT VARCHAR2) ISBEGIN SELECT password INTO p_password FROM users WHERE user_id=p_user_id; -- 对密码进行加密处理 p_password :=DBMS_CRYPTO.ENCRYPT(AES128, DBMS_CRYPTO.ENCRYPT_DECRYPT, p_password);END get_user_password;
背景
某项目接口采用plsql开发,接口返回用户密码,但要求密码不能是明文返回,因为程序内部需要用到明文密码,所以只能在plsql中对密码进行对称加密,在程序内部进行解密,程序采用java开发。
实现
dbms_crypto是oracle自带的加密包,包含多种加密解密方法,非dba用户需要授权才能进行使用
grantexecuteondbms_cryptotoxxx;
下面是一个通过DES算法加密的function
functionencrypt_password(p_passwordinvarchar2)returnvarchar2is v_keyvarchar2(32):='TucM2fYDaxnd1UeRL7HVvyshXvXaMKO9'; v_encrypted_rawRAW(256); begin v_encrypted_raw:=dbms_crypto.Encrypt(src=>UTL_RAW.CAST_TO_RAW(p_password), typ=>DBMS_CRYPTO.DES_CBC_PKCS5, iv=>UTL_RAW.CAST_TO_RAW('12345678'), key=>UTL_RAW.CAST_TO_RAW(v_key)); returnutl_raw.cast_to_varchar2(utl_encode.base64_encode(v_encrypted_raw)); end;
- v_key:密钥
- typ:加密算法,这里采用DES加密算法,可以使用密钥进行加密,使用相同的密钥进行解密,DES_CBC_PKCS5分为三段,DES表示加密算法是DES,CBC表示使用CBC模式进行加密,PKCS5表示分组的填充方式,大部分情况下,明文并非刚好64位的倍数。对于最后一个分组,如果长度小于64位,则需要用数据填充至64位。PKCS5Padding是常用的填充方式,如果没有指定,默认的方式就是它。
- iv:如果是采用CBC模式进行加密,需要指定始化向量IV
这里将返回值进行了base64的编码,因为加密出来的数据可能是二进制数据,为了便于传输进行了base64编码,以下是测试的结果
输入:zhengjianfeng 输出:N8pbaNezTEJO34jIgJhUFg==
java解密
importjavax.crypto.Cipher; importjavax.crypto.SecretKeyFactory; importjavax.crypto.spec.DESKeySpec; importjavax.crypto.spec.IvParameterSpec; importjava.security.Key; importjava.util.Base64; /** *@Description: *@author:jianfeng.zheng *@since:2021/2/2012:12上午 *@history:1.2021/2/20createdbyjianfeng.zheng */ publicclassDesDecryptDemo{ privatefinalstaticStringIV_PARAMETER="12345678"; privatestaticfinalStringALGORITHM="DES"; privatestaticfinalStringCIPHER_ALGORITHM="DES/CBC/PKCS5Padding"; privatestaticfinalStringCHARSET="utf-8"; privatestaticfinalStringKEY="TucM2fYDaxnd1UeRL7HVvyshXvXaMKO9"; publicstaticvoidmain(String[]args){ StringencryptData="N8pbaNezTEJO34jIgJhUFg=="; System.out.println("密文:"+encryptData); StringplainText=decrypt(KEY,encryptData); System.out.println("明文:"+plainText); } publicstaticStringdecrypt(Stringkey,Stringdata){ if(key==null||key.length()<8){ thrownewRuntimeException("加密失败,key不能小于8位"); } if(data==null){ returnnull; } try{ DESKeySpecdks=newDESKeySpec(key.getBytes(CHARSET)); SecretKeyFactorykeyFactory=SecretKeyFactory.getInstance(ALGORITHM); KeysecretKey=keyFactory.generateSecret(dks); Ciphercipher=Cipher.getInstance(CIPHER_ALGORITHM); //设置始化向量 IvParameterSpeciv=newIvParameterSpec(IV_PARAMETER.getBytes(CHARSET)); cipher.init(Cipher.DECRYPT_MODE,secretKey,iv); returnnewString(cipher.doFinal(Base64.getDecoder().decode(data.getBytes(CHARSET))),CHARSET); }catch(Exceptione){ e.printStackTrace(); returndata; } } }
运行结果
密文:N8pbaNezTEJO34jIgJhUFg== 明文:zhengjianfeng
可以看到是可以拿到明文的
以上就是plsql实现DES对称加密 Java解密的详细内容,更多关于plsql对称加密 java解密的资料请关注易盾网络其它相关文章!
本文共计630个文字,预计阅读时间需要3分钟。
背景:某项目接口采用PLSQL开发,接口返回用户密码,但密码不是明文返回,因为程序内部需要使用明文密码。
接口内容:sqlCREATE OR REPLACE PROCEDURE get_user_password(p_user_id IN NUMBER, p_password OUT VARCHAR2) ISBEGIN SELECT password INTO p_password FROM users WHERE user_id=p_user_id; -- 对密码进行加密处理 p_password :=DBMS_CRYPTO.ENCRYPT(AES128, DBMS_CRYPTO.ENCRYPT_DECRYPT, p_password);END get_user_password;
背景
某项目接口采用plsql开发,接口返回用户密码,但要求密码不能是明文返回,因为程序内部需要用到明文密码,所以只能在plsql中对密码进行对称加密,在程序内部进行解密,程序采用java开发。
实现
dbms_crypto是oracle自带的加密包,包含多种加密解密方法,非dba用户需要授权才能进行使用
grantexecuteondbms_cryptotoxxx;
下面是一个通过DES算法加密的function
functionencrypt_password(p_passwordinvarchar2)returnvarchar2is v_keyvarchar2(32):='TucM2fYDaxnd1UeRL7HVvyshXvXaMKO9'; v_encrypted_rawRAW(256); begin v_encrypted_raw:=dbms_crypto.Encrypt(src=>UTL_RAW.CAST_TO_RAW(p_password), typ=>DBMS_CRYPTO.DES_CBC_PKCS5, iv=>UTL_RAW.CAST_TO_RAW('12345678'), key=>UTL_RAW.CAST_TO_RAW(v_key)); returnutl_raw.cast_to_varchar2(utl_encode.base64_encode(v_encrypted_raw)); end;
- v_key:密钥
- typ:加密算法,这里采用DES加密算法,可以使用密钥进行加密,使用相同的密钥进行解密,DES_CBC_PKCS5分为三段,DES表示加密算法是DES,CBC表示使用CBC模式进行加密,PKCS5表示分组的填充方式,大部分情况下,明文并非刚好64位的倍数。对于最后一个分组,如果长度小于64位,则需要用数据填充至64位。PKCS5Padding是常用的填充方式,如果没有指定,默认的方式就是它。
- iv:如果是采用CBC模式进行加密,需要指定始化向量IV
这里将返回值进行了base64的编码,因为加密出来的数据可能是二进制数据,为了便于传输进行了base64编码,以下是测试的结果
输入:zhengjianfeng 输出:N8pbaNezTEJO34jIgJhUFg==
java解密
importjavax.crypto.Cipher; importjavax.crypto.SecretKeyFactory; importjavax.crypto.spec.DESKeySpec; importjavax.crypto.spec.IvParameterSpec; importjava.security.Key; importjava.util.Base64; /** *@Description: *@author:jianfeng.zheng *@since:2021/2/2012:12上午 *@history:1.2021/2/20createdbyjianfeng.zheng */ publicclassDesDecryptDemo{ privatefinalstaticStringIV_PARAMETER="12345678"; privatestaticfinalStringALGORITHM="DES"; privatestaticfinalStringCIPHER_ALGORITHM="DES/CBC/PKCS5Padding"; privatestaticfinalStringCHARSET="utf-8"; privatestaticfinalStringKEY="TucM2fYDaxnd1UeRL7HVvyshXvXaMKO9"; publicstaticvoidmain(String[]args){ StringencryptData="N8pbaNezTEJO34jIgJhUFg=="; System.out.println("密文:"+encryptData); StringplainText=decrypt(KEY,encryptData); System.out.println("明文:"+plainText); } publicstaticStringdecrypt(Stringkey,Stringdata){ if(key==null||key.length()<8){ thrownewRuntimeException("加密失败,key不能小于8位"); } if(data==null){ returnnull; } try{ DESKeySpecdks=newDESKeySpec(key.getBytes(CHARSET)); SecretKeyFactorykeyFactory=SecretKeyFactory.getInstance(ALGORITHM); KeysecretKey=keyFactory.generateSecret(dks); Ciphercipher=Cipher.getInstance(CIPHER_ALGORITHM); //设置始化向量 IvParameterSpeciv=newIvParameterSpec(IV_PARAMETER.getBytes(CHARSET)); cipher.init(Cipher.DECRYPT_MODE,secretKey,iv); returnnewString(cipher.doFinal(Base64.getDecoder().decode(data.getBytes(CHARSET))),CHARSET); }catch(Exceptione){ e.printStackTrace(); returndata; } } }
运行结果
密文:N8pbaNezTEJO34jIgJhUFg== 明文:zhengjianfeng
可以看到是可以拿到明文的
以上就是plsql实现DES对称加密 Java解密的详细内容,更多关于plsql对称加密 java解密的资料请关注易盾网络其它相关文章!

