plsql实现DES对称加密Java解密
背景
某项⽬接⼝采⽤plsql开发,接⼝返回⽤户密码,但要求密码不能是明⽂返回,因为程序内部需要⽤到明⽂密码,所以只能在plsql中对密码进⾏对称加密,在程序内部进⾏解密,程序采⽤java开发。
实现
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位的倍数。对于最后⼀个分组,如果长度⼩于64位,则需要⽤数据填充⾄64位。PKCS5Padding是常⽤的填充⽅式,如果没有指定,默认的⽅式就是它。
iv:如果是采⽤CBC模式进⾏加密,需要指定始化向量IV
这⾥将返回值进⾏了base64的编码,因为加密出来的数据可能是⼆进制数据,为了便于传输进⾏了base64编码,以下是测试的结果
输⼊:zhengjianfeng
输出:N8pbaNezTEJO34jIgJhUFg==
java解密
pto.Cipher;
pto.SecretKeyFactory;
pto.spec.DESKeySpec;
pto.spec.IvParameterSpec;
import java.security.Key;
import java.util.Base64;
plsql12配置数据库连接/**
* @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 Bytes(CHARSET));
SecretKeyFactory keyFactory = Instance(ALGORITHM);
Key secretKey = ateSecret(dks);
Cipher cipher = Instance(CIPHER_ALGORITHM);
//设置始化向量
IvParameterSpec iv = new IvParameterSpec(Bytes(CHARSET));
cipher.init(Cipher.DECRYPT_MODE, secretKey, iv);
return new String(cipher.Decoder().Bytes(CHARSET))), CHARSET);
} catch (Exception e) {
e.printStackTrace();
return data;
}
}
}
运⾏结果
密⽂:N8pbaNezTEJO34jIgJhUFg==
明⽂:zhengjianfeng
可以看到是可以拿到明⽂的
以上就是plsql实现DES对称加密 Java解密的详细内容,更多关于plsql对称加密 java解密的资料请关注其它相关⽂章!
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论