zoukankan      html  css  js  c++  java
  • 对称加密-DES加密解密

    des对称加密,是一种比较传统的加密方式,其加密运算、解密运算使用的是同样的密钥,信息的发送者和信息的接收者在进行信息的传输与处理时,必须共同持有该密码(称为对称密码),是一种对称加密算法

    前端(js)加解密:

    一:引入需要的cryptojs包

    <script src="https://cdn.bootcss.com/crypto-js/3.1.9-1/crypto-js.min.js"></script>

    2:DES加密解密方法如下

    //DES加密
    function encryptByDES(message, key){
        var keyHex = CryptoJS.enc.Utf8.parse(key);
        var encrypted = CryptoJS.DES.encrypt(message, keyHex, {
            mode: CryptoJS.mode.ECB,
            padding: CryptoJS.pad.Pkcs7
        });
        return encrypted.ciphertext.toString();
    }
    //DES加密
    function decryptByDES(ciphertext, key){
        var keyHex = CryptoJS.enc.Utf8.parse(key);
        var decrypted = CryptoJS.DES.decrypt({
            ciphertext: CryptoJS.enc.Hex.parse(ciphertext)
        }, keyHex, {
            mode: CryptoJS.mode.ECB,
            padding: CryptoJS.pad.Pkcs7
        });
        var result_value = decrypted.toString(CryptoJS.enc.Utf8);
        return result_value;
    }

    3:使用

    var message = '111111';//需要加密的数据
    var key = '12345678';//加密key
    //加密
    desMessage = encryptByDES(message, key);
    console.log(desMessage);
    //解密
    message = decryptByDES(desMessage,key)
    console.log(message);

     后端(java)加解密:

    package com.qt.xxx.util;
    
    import java.io.ByteArrayOutputStream;
    import java.security.KeyFactory;
    import java.security.KeyPair;
    import java.security.KeyPairGenerator;
    import java.security.PrivateKey;
    import java.security.PublicKey;
    import java.security.SecureRandom;
    import java.security.Signature;
    import java.security.interfaces.RSAPrivateKey;
    import java.security.interfaces.RSAPublicKey;
    import java.security.spec.PKCS8EncodedKeySpec;
    import java.security.spec.X509EncodedKeySpec;
    import java.util.HashMap;
    import java.util.Map;
    import javax.crypto.Cipher;
    import javax.crypto.SecretKey;
    import javax.crypto.SecretKeyFactory;
    import javax.crypto.spec.DESKeySpec;
    import com.alibaba.fastjson.JSONObject;
    
    //加密解密工具
    public class EncryptUtil { 
        /**
         * DES加密算法
           * 这个加密算法是对称的加密算法这个加密算法,在本系统中的应用,主要是因为该加密算法加密后密文都是字符串和数字的,没有其他字符。这样的密文可以应用在url地址上,
           * 不用担心被URL 地址上传递的数字被转义
         * @author QT
         *
         */
        /** 加密算法,可用 DES,DESede,Blowfish. */
        private final static String ALGORITHM = "DES";
    
        //------------------------DES----start---------------------------------
        /**
         * DES解密算法
         * @param data
         * @param cryptKey  密钥 要是偶数
         * @return
         * @throws Exception
         */
        public static String decryptByDES(String data, String cryptKey){
            try {
                return new String(decrypt(hex2byte(data.getBytes()),
                        cryptKey.getBytes()));
            } catch (Exception e) {
                e.printStackTrace();
                return "";
            }
        }
    
        /**
         * DES加密算法
         * @param data
         * @param cryptKey
         * @return
         * @throws Exception
         */
        public static String encryptByDES(String data, String cryptKey){
            try {
                return byte2hex(encrypt(data.getBytes(), cryptKey.getBytes()));
            } catch (Exception e) {
                e.printStackTrace();
                return "";
            }
        }
    
        private static byte[] encrypt(byte[] data, byte[] key) throws Exception {
            // DES算法要求有一个可信任的随机数源
            SecureRandom sr = new SecureRandom();
            // 从原始密匙数据创建DESKeySpec对象
            DESKeySpec dks = new DESKeySpec(key);
            // 创建一个密匙工厂,然后用它把DESKeySpec转换成
            // 一个SecretKey对象
            SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(ALGORITHM);
            SecretKey securekey = keyFactory.generateSecret(dks);
            // Cipher对象实际完成加密操作
            Cipher cipher = Cipher.getInstance(ALGORITHM);
            // 用密匙初始化Cipher对象
            cipher.init(Cipher.ENCRYPT_MODE, securekey, sr);
            // 现在,获取数据并加密
            // 正式执行加密操作
            return cipher.doFinal(data);
        }
    
        private static byte[] decrypt(byte[] data, byte[] key) throws Exception {
            // DES算法要求有一个可信任的随机数源
            SecureRandom sr = new SecureRandom();
            // 从原始密匙数据创建一个DESKeySpec对象
            DESKeySpec dks = new DESKeySpec(key);
            // 创建一个密匙工厂,然后用它把DESKeySpec对象转换成
            // 一个SecretKey对象
            SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(ALGORITHM);
            SecretKey securekey = keyFactory.generateSecret(dks);
            // Cipher对象实际完成解密操作
            Cipher cipher = Cipher.getInstance(ALGORITHM);
            // 用密匙初始化Cipher对象
            cipher.init(Cipher.DECRYPT_MODE, securekey, sr);
            // 现在,获取数据并解密
            // 正式执行解密操作
            return cipher.doFinal(data);
        }
    
        private static byte[] hex2byte(byte[] b) {
            if ((b.length % 2) != 0)
                throw new IllegalArgumentException("长度不是偶数");
            byte[] b2 = new byte[b.length / 2];
            for (int n = 0; n < b.length; n += 2) {
                String item = new String(b, n, 2);
                b2[n / 2] = (byte) Integer.parseInt(item, 16);
            }
            return b2;
        }
    
        private static String byte2hex(byte[] b) {
            String hs = "";
            String stmp = "";
            for (int n = 0; n < b.length; n++) {
                stmp = (java.lang.Integer.toHexString(b[n] & 0XFF));
                if (stmp.length() == 1)
                    hs = hs + "0" + stmp;
                else
                    hs = hs + stmp;
            }
            return hs.toUpperCase();
        }
        
      //------------------------DES----end-----------------------------------
    }

    参考:
    https://segmentfault.com/a/1190000021261107?utm_source=tag-newest

  • 相关阅读:
    maven学习(二)
    maven学习(一)
    一步步点亮led之软硬件分析
    mkv210添加校验和
    led部分Makefile
    makefile
    交叉编译工具链
    基础知识
    C语言复杂表达式与指针应用
    指针
  • 原文地址:https://www.cnblogs.com/qiantao/p/13292658.html
Copyright © 2011-2022 走看看