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解密

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解密的资料请关注我们其它相关文章!

(0)

相关推荐

  • Java使用Hutool实现AES、DES加密解密的方法

    在Java世界中,AES.DES加密解密需要使用Cipher对象构建加密解密系统,Hutool中对这一对象做再包装,简化了加密解密过程. 介绍 AES和DES同属对称加密算法,数据发信方将明文(原始数据)和加密密钥一起经过特殊加密算法处理后,使其变成复杂的加密密文发送出去.收信方收到密文后,若想解读原文,则需要使用加密用过的密钥及相同算法的逆算法对密文进行解密,才能使其恢复成可读明文.在对称加密算法中,使用的密钥只有一个,发收信双方都使用这个密钥对数据进行加密和解密,这就要求解密方事先必须知道加

  • java基于Des对称加密算法实现的加密与解密功能详解

    本文实例讲述了java基于Des对称加密算法实现的加密与解密功能.分享给大家供大家参考,具体如下: Des 加密相关类介绍: SecureRandom  这个类是继承自java.util.Random 这个类 SecureRandom 这个类的构造器有三种,下面例举两种: SecureRandom()构造一个实现默认随机数算法的安全随机数生成器 (RNG). SecureRandom(byte[] seed)构造一个实现默认随机数算法的安全随机数生成器 (RNG). DESKeySpec 这个类

  • PHP、Java des加密解密实例

    des加密是对称加密中在互联网应用的比较多的一种加密方式,php 通过mcrypt扩展库来支持des加密,要在Php中使用des加密,需要先安装mcrypt扩展库 下面是加密解密的实例 复制代码 代码如下: $iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_256, MCRYPT_MODE_ECB);  $iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);  $key = "This is a very secre

  • Java实现的3des加密解密工具类示例

    本文实例讲述了Java实现的3des加密解密工具类.分享给大家供大家参考,具体如下: package com.gcloud.common; import org.apache.poi.poifs.property.Child; import org.bouncycastle.jce.provider.BouncyCastleProvider; import javax.crypto.*; import javax.crypto.spec.IvParameterSpec; import javax

  • [J2SE]Java中3DES加密解密调用示例

    jce.jar security/US_export_policy.jar security/local_policy.jar ext/sunjce_provider.jar Java运行时会自动加载这些包,因此对于带main函数的应用程序不需要设置到CLASSPATH环境变量中.对于WEB应用,不需要把这些包加到WEB-INF/lib目录下. 以下是java中调用sun公司提供的3DES加密解密算法的样本代码: 复制代码 代码如下: /*字符串 DESede(3DES) 加密*/ import

  • Python和Java进行DES加密和解密的实例

    DES 为 Data Encryption Standard (数据加密标准)的缩写,是一种常见的对称加密算法.有关对称加密与非对称加密的特点及其应用场景,本文就不描述了,读者可以自行 google .本文说明如何使用 Java 和 Python 两种语言来实现 DES 的加解密. 最近碰到的应用场景是这样的.我们需要对接一个系统 S,系统 S 已经对用户的身份进行了验证,新系统 N 也需要对用户的身份进行验证.采用的身份验证方法是由旧系统 S 对用户 ID 进行加密,然后新系统 N 对加密后的

  • java 实现DES 加密解密的示例

    package com.cn.peitest; import javax.crypto.Cipher; import javax.crypto.SecretKey; import javax.crypto.SecretKeyFactory; import javax.crypto.spec.DESKeySpec; import javax.crypto.spec.IvParameterSpec; /** * @功能说明: <BR> * @创建日期:2016年9月21日<BR> *

  • Java实现的DES加密解密工具类实例

    本文实例讲述了Java实现的DES加密解密工具类.分享给大家供大家参考,具体如下: 一个工具类,很常用,不做深入研究了,那来可直接用 DesUtil.java package lsy; import java.security.Key; import java.security.SecureRandom; import javax.crypto.Cipher; import javax.crypto.KeyGenerator; import javax.crypto.SecretKey; imp

  • java中DES加密解密

    废话不多说,直接奉上代码: 复制代码 代码如下: package com.eabax.plugin.yundada.utils; import java.io.IOException; import java.security.InvalidKeyException; import java.security.NoSuchAlgorithmException; import java.security.SecureRandom; import java.security.spec.Invalid

  • java使用des加密解密示例分享

    复制代码 代码如下: import java.security.Key;import java.security.SecureRandom;import java.security.spec.AlgorithmParameterSpec; import javax.crypto.Cipher;import javax.crypto.SecretKeyFactory;import javax.crypto.spec.DESKeySpec;import javax.crypto.spec.IvPar

  • Java实现DES加密与解密,md5加密以及Java实现MD5加密解密类

    很多时候要对秘要进行持久化加密,此时的加密采用md5.采用对称加密的时候就采用DES方法了 import java.io.IOException; import java.security.MessageDigest; import java.security.SecureRandom; import javax.crypto.Cipher; import javax.crypto.SecretKey; import javax.crypto.SecretKeyFactory; import j

随机推荐