午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

plsql實(shí)現(xiàn)DES對(duì)稱加密 Java解密

瀏覽:140日期:2022-08-16 15:19:48
背景

某項(xiàng)目接口采用plsql開(kāi)發(fā),接口返回用戶密碼,但要求密碼不能是明文返回,因?yàn)槌绦騼?nèi)部需要用到明文密碼,所以只能在plsql中對(duì)密碼進(jìn)行對(duì)稱加密,在程序內(nèi)部進(jìn)行解密,程序采用java開(kāi)發(fā)。

實(shí)現(xiàn)

dbms_crypto是oracle自帶的加密包,包含多種加密解密方法,非dba用戶需要授權(quán)才能進(jìn)行使用

grant execute on dbms_crypto to xxx;

下面是一個(gè)通過(guò)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加密算法,可以使用密鑰進(jìn)行加密,使用相同的密鑰進(jìn)行解密,DES_CBC_PKCS5分為三段,DES表示加密算法是DES,CBC表示使用CBC模式進(jìn)行加密,PKCS5表示分組的填充方式,大部分情況下,明文并非剛好64位的倍數(shù)。對(duì)于最后一個(gè)分組,如果長(zhǎng)度小于64位,則需要用數(shù)據(jù)填充至64位。PKCS5Padding是常用的填充方式,如果沒(méi)有指定,默認(rèn)的方式就是它。 iv:如果是采用CBC模式進(jìn)行加密,需要指定始化向量IV

這里將返回值進(jìn)行了base64的編碼,因?yàn)榧用艹鰜?lái)的數(shù)據(jù)可能是二進(jìn)制數(shù)據(jù),為了便于傳輸進(jìn)行了base64編碼,以下是測(cè)試的結(jié)果

輸入: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); //設(shè)置始化向量 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; } } }

運(yùn)行結(jié)果

密文:N8pbaNezTEJO34jIgJhUFg== 明文:zhengjianfeng

可以看到是可以拿到明文的

以上就是plsql實(shí)現(xiàn)DES對(duì)稱加密 Java解密的詳細(xì)內(nèi)容,更多關(guān)于plsql對(duì)稱加密 java解密的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 国产乱码久久久久 | 国产亚洲欧美一区二区 | 亚洲网站在线播放 | 网曝门在线 | 久久久久无码国产精品一区 | 国产欧美精品区一区二区三区 | 国产精品99久久久久久久 | 黄色一级大片 | 91免费网站在线观看 | 久久av一区二区 | 欧美另类69| 一区二区中文 | 超碰免费在线播放 | 国产一区免费看 | 亚洲男女av| 亚洲v欧美 | 亚洲精品视频在线 | 色网站免费观看 | 午夜h视频 | 精品欧美乱码久久久久久 | 日韩三级中文字幕 | 欧美不卡视频在线观看 | 在线观看视频中文字幕 | 欧美黄色免费看 | 欧美一区二区三区爽爽爽 | 亚洲成人av在线播放 | 日韩美女免费视频 | 成人一级视频 | 日本久久久久久久久 | 日韩精品导航 | 成年人三级网站 | 一极黄色大片 | 自拍视频一区 | 青青青视频在线免费观看 | www成人免费视频 | 欧美一级一区二区三区 | 中文字幕av一区 | 欧美精品一二三 | 亚洲日本天堂 | 色综合久久久久 | 日韩在线第二页 |