plsql實現(xiàn)DES對稱加密 Java解密
背景
某項目接口采用plsql開發(fā),接口返回用戶密碼,但要求密碼不能是明文返回,因為程序內(nèi)部需要用到明文密碼,所以只能在plsql中對密碼進行對稱加密,在程序內(nèi)部進行解密,程序采用java開發(fā)。
實現(xiàn)
dbms_crypto是oracle自帶的加密包,包含多種加密解密方法,非dba用戶需要授權才能進行使用
grant execute on dbms_crypto to xxx;
下面是一個通過DES算法加密的function
function encrypt_password(p_password in varchar2) return varchar2 is v_key varchar2(32) := 'TucM2fYDaxnd1UeRL7HVvyshXvXaMKO9'; v_encrypted_raw RAW(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)); return utl_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位的倍數(shù)。對于最后一個分組,如果長度小于64位,則需要用數(shù)據(jù)填充至64位。PKCS5Padding是常用的填充方式,如果沒有指定,默認的方式就是它。
- iv:如果是采用CBC模式進行加密,需要指定始化向量IV
這里將返回值進行了base64的編碼,因為加密出來的數(shù)據(jù)可能是二進制數(shù)據(jù),為了便于傳輸進行了base64編碼,以下是測試的結果
輸入:zhengjianfeng 輸出:N8pbaNezTEJO34jIgJhUFg==
java解密
import javax.crypto.Cipher; import javax.crypto.SecretKeyFactory; import javax.crypto.spec.DESKeySpec; import javax.crypto.spec.IvParameterSpec; import java.security.Key; import java.util.Base64; /** * @Description: * @author: jianfeng.zheng * @since: 2021/2/20 12:12 上午 * @history: 1.2021/2/20 created by jianfeng.zheng */ public class DesDecryptDemo { private final static String IV_PARAMETER = "12345678"; private static final String ALGORITHM = "DES"; private static final String CIPHER_ALGORITHM = "DES/CBC/PKCS5Padding"; private static final String CHARSET = "utf-8"; private static final String KEY = "TucM2fYDaxnd1UeRL7HVvyshXvXaMKO9"; public static void main(String[] args) { String encryptData = "N8pbaNezTEJO34jIgJhUFg=="; System.out.println("密文:" + encryptData); String plainText = decrypt(KEY, encryptData); System.out.println("明文:" + plainText); } public static String decrypt(String key, String data) { if (key == null || key.length() < 8) { throw new RuntimeException("加密失敗,key不能小于8位"); } if (data == null) { return null; } try { DESKeySpec dks = new DESKeySpec(key.getBytes(CHARSET)); SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(ALGORITHM); Key secretKey = keyFactory.generateSecret(dks); Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM); //設置始化向量 IvParameterSpec iv = new IvParameterSpec(IV_PARAMETER.getBytes(CHARSET)); cipher.init(Cipher.DECRYPT_MODE, secretKey, iv); return new String(cipher.doFinal(Base64.getDecoder().decode(data.getBytes(CHARSET))), CHARSET); } catch (Exception e) { e.printStackTrace(); return data; } } }
運行結果
密文:N8pbaNezTEJO34jIgJhUFg== 明文:zhengjianfeng
可以看到是可以拿到明文的
以上就是plsql實現(xiàn)DES對稱加密 Java解密的詳細內(nèi)容,更多關于plsql對稱加密 java解密的資料請關注腳本之家其它相關文章!
相關文章
VsCode搭建Spring Boot項目并進行創(chuàng)建、運行、調(diào)試
這篇文章主要介紹了VsCode搭建Spring Boot項目并進行創(chuàng)建、運行、調(diào)試 ,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-05-05springboot yml定義屬性,下文中${} 引用說明
這篇文章主要介紹了springboot yml定義屬性,下文中${} 引用說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-04-04Springboot動態(tài)切換數(shù)據(jù)源的具體實現(xiàn)與原理分析
目前有個需求,需要使用不同的數(shù)據(jù)源,例如某業(yè)務要用A數(shù)據(jù)源,另一個業(yè)務要用B數(shù)據(jù)源,所以下面這篇文章主要給大家介紹了關于Springboot動態(tài)切換數(shù)據(jù)源的具體實現(xiàn)與原理分析,需要的朋友可以參考下2021-12-12聊聊Arrays.deepToString()和Arrays.toString()的區(qū)別
這篇文章主要介紹了聊聊Arrays.deepToString()和Arrays.toString()的區(qū)別,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-02-02Spring?Boot整合阿里開源中間件Canal實現(xiàn)數(shù)據(jù)增量同步
這篇文章主要為大家介紹了Spring?Boot整合阿里開源中間件Canal實現(xiàn)數(shù)據(jù)增量同步示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-06-06