plsql实现DES对称加密 Java解密

 更新时间:2021年02月20日 09:45:33   作者:郑剑峰  
这篇文章主要介绍了plsql实现DES对称加密 Java解密的方法,帮助大家更好的理解和学习使用Oracle与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解密

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实现DES对称加密 Java解密的详细内容,更多关于plsql对称加密 java解密的资料请关注脚本之家其它相关文章!

相关文章

  • Java有效处理异常的三个原则

    Java有效处理异常的三个原则

    Java中异常提供了一种识别及响应错误情况的一致性机制,有效地异常处理能使程序更加健壮、易于调试。那么这篇文章总结了Java有效处理异常的三个原则,有需要的朋友们可以参考借鉴。
    2016-09-09
  • spring boot 动态生成接口实现类的场景分析

    spring boot 动态生成接口实现类的场景分析

    本文不具体介绍动态代理,主要看一下它在springboot项目中的实际应用,下面我们模仿feign来实现一个调用三方接口的 httpclient,感谢的朋友跟随小编一起看看吧
    2021-11-11
  • Java日常练习题,每天进步一点点(34)

    Java日常练习题,每天进步一点点(34)

    下面小编就为大家带来一篇Java基础的几道练习题(分享)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧,希望可以帮到你
    2021-07-07
  • Spring的@Value如何从Nacos配置中心获取值并自动刷新

    Spring的@Value如何从Nacos配置中心获取值并自动刷新

    这篇文章主要介绍了Spring的@Value如何从Nacos配置中心获取值并自动刷新,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • java中线程的状态学习笔记

    java中线程的状态学习笔记

    在本文里我们给大家整理了关于java中线程的状态的相关知识点内容,对此有需要的朋友们学习参考下。
    2019-03-03
  • MyBatis-Plus 批量保存的操作方法

    MyBatis-Plus 批量保存的操作方法

    在项目开发中,需要插入批量插入20多万条数据,通过日志观察,发现在调用MyBatis-Plus中的saveBatch()方法性能非常的差,本篇文章主要分享一下saveBatch()的原理以及使用的注意事项,感兴趣的朋友跟随小编一起看看吧
    2024-01-01
  • 浅谈Java中随机数的几种实现方式

    浅谈Java中随机数的几种实现方式

    这篇文章主要介绍了Java中随机数的几种实现方式,从最简单的Math.random到多线程的并发实现都在本文所列之中,需要的朋友可以参考下
    2015-07-07
  • SpringCloud @RefreshScope刷新机制深入探究

    SpringCloud @RefreshScope刷新机制深入探究

    RefeshScope这个注解想必大家都用过,在微服务配置中心的场景下经常出现,他可以用来刷新Bean中的属性配置,那大家对他的实现原理了解吗?它为什么可以做到动态刷新呢
    2023-03-03
  • Java response响应体和文件下载实现原理

    Java response响应体和文件下载实现原理

    这篇文章主要介绍了Java response响应体和文件下载实现原理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-05-05
  • java生成xml格式文件的方法

    java生成xml格式文件的方法

    这篇文章主要介绍了java生成xml格式文件的方法,涉及java节点遍历与属性操作的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2016-07-07

最新评论