国产精品爱久久久久久久小说,女人扒开腿让男人桶到爽 ,亚洲欧美国产双大乳头,国产成人精品综合久久久久,国产精品制服丝袜无码,免费无码精品黄av电影,黑色丝袜无码中中文字幕,乱熟女高潮一区二区在线

    關(guān)于web項目前后端加密解密總結(jié)

    2021-5-27    前端達人

    首先項目是基于vue開發(fā)的項目

    1、DES加密

    前端

    需要引入js

    import cryptoJs from 'crypto-js'

    // DES加密

    export const encryptDes = (message, key) => {

    return cryptoJs.DES.encrypt(message, cryptoJs.enc.Utf8.parse(key), {

    mode: cryptoJs.mode.ECB,

    padding: cryptoJs.pad.Pkcs7

    }).toString()

    }

    后臺


    package com.huihui.until;

    import java.security.SecureRandom;
    import java.util.Scanner;
     
    import javax.crypto.Cipher;
    import javax.crypto.SecretKeyFactory;
    import javax.crypto.spec.DESKeySpec;
     
    import org.apache.commons.codec.binary.Base64;
     
     
    /**
     * <b>類說明:DES</b>
     * <p>
     * <b>詳細描述:</b>
     * @since 2019年3月31日 下午17:00:16
     */
    public class DESCryptUtil {
        
        private static final String DES = "DES";
        
        public static final String desKey = "ba54ee44";
     
        public static String doEncrypt(String plainMessage, String hexDesKey) throws Exception {
            byte desKey[] = hexDesKey.getBytes();
            byte desPlainMsg[] = plainMessage.getBytes();
            return Base64.encodeBase64URLSafeString(desCrypt(desKey, desPlainMsg, Cipher.ENCRYPT_MODE));
        }
        /**
         * 獲取解密后的字符串
         * @param hexEncryptMessage
         * @param hexDesKey
         * @return
         * @throws Exception
         */
        public static String doDecrypt(String hexEncryptMessage, String hexDesKey) throws Exception{
            if (hexEncryptMessage == null) {
                return null;
            }
            byte desKey[] = hexDesKey.getBytes();
            byte desPlainMsg[] = Base64.decodeBase64(hexEncryptMessage);
            return new String(desCrypt(desKey, desPlainMsg, Cipher.DECRYPT_MODE));
        }
        /**
         * 獲取解密后的數(shù)組
         * @param desPlainMsg
         * @param hexDesKey
         * @return
         * @throws Exception
         */
        public static byte[] doDecryptByte(byte[] desPlainMsg, String hexDesKey) throws Exception{
            if (desPlainMsg == null) {
                return null;
            }
            byte desKey[] = hexDesKey.getBytes();
            return desCrypt(desKey, desPlainMsg, Cipher.DECRYPT_MODE);
        }
        
        private static byte[] desCrypt(byte[] desKey, byte[] desPlainMsg, int CipherMode) throws Exception{
            try {
                SecureRandom sr = new SecureRandom();
                DESKeySpec dks = new DESKeySpec(desKey);
                SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES);
                javax.crypto.SecretKey key = keyFactory.generateSecret(dks);
                Cipher cipher = Cipher.getInstance(DES);
                cipher.init(CipherMode, key, sr);
                return cipher.doFinal(desPlainMsg);
            } catch (Exception e) {
                String message = "";
                if (CipherMode == Cipher.ENCRYPT_MODE) {
                    message = "DES\u52A0\u5BC6\u5931\u8D25";
                } else {
                    message = "DES\u89E3\u5BC6\u5931\u8D25";
                }
                throw new Exception(message, e);
            }
        }
        /**
         * 獲取8位的key
         * @param str
         * @return
         */
        public static String processString(String str) {
            if(str==null||"".equals(str)) {
                return "";
            }
            StringBuilder sb = new StringBuilder();
            for(int i=0;i<8;i++) {
                int index = i<<2&(32-i);
                sb.append(str.charAt(index));
            }
            
            return sb.toString();
        }
        public static void main(String[] args) throws Exception{
            DESCryptUtil se=new DESCryptUtil();
            for (int i = 0; i < 5; i++) {
                Scanner scanner=new Scanner(System.in);
                /*
                 * 加密
                 */
                System.out.println("請輸入要加密的內(nèi)容:");
                String content = scanner.next();
                System.out.println("加密后的密文是:"+se.doEncrypt(content, desKey));
               
                /*
                 * 解密
                 */
                System.out.println("請輸入要解密的內(nèi)容:");
                 content = scanner.next();
                System.out.println("解密后的明文是:"+se.doDecrypt(content, desKey));
            }
        }

    }
     

    2 RSA加密解密

    這是我是在在線生成公鑰私鑰的網(wǎng)站中生成了自己的公鑰私鑰用來測試

    前臺

    import JsEncrypt from 'jsencrypt'

    // RSA加密

    export function encryptRsa(publickey, message) {

    const rsa = new JsEncrypt()

    rsa.setPublicKey(publickey)

    return rsa.encrypt(message)

    }

    后臺

    package com.huihui.until;

    import org.apache.commons.codec.binary.Base64;

    import com.googosoft.config.GlobalConstants;

    import javax.crypto.Cipher;
    import java.security.KeyFactory;
    import java.security.KeyPair;
    import java.security.KeyPairGenerator;
    import java.security.NoSuchAlgorithmException;
    import java.security.SecureRandom;
    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;
      
      
    public class RSAUtil {  
          
        private static Map<Integer, String> keyMap = new HashMap<Integer, String>();  //用于封裝隨機產(chǎn)生的公鑰與私鑰
        public static void main(String[] args) throws Exception {
            //生成公鑰和私鑰
            genKeyPair();
            //加密字符串
            String message = "df723820";
        //GlobalConstants.PUBLICKEY 公鑰加密
            String messageEn = encrypt(message,GlobalConstants.PUBLICKEY);
            System.out.println(message + "\t加密后的字符串為:" + messageEn);

    //GlobalConstants.PRIVATEKEY 私鑰解密
            String messageDe = decrypt(messageEn,GlobalConstants.PRIVATEKEY);
            System.out.println("還原后的字符串為:" + messageDe);
        }

        /** 
         * 隨機生成密鑰對 
         * @throws NoSuchAlgorithmException 
         */  
        public static void genKeyPair() throws NoSuchAlgorithmException {  
            // KeyPairGenerator類用于生成公鑰和私鑰對,基于RSA算法生成對象  
            KeyPairGenerator keyPairGen = KeyPairGenerator.getInstance("RSA");  
            // 初始化密鑰對生成器,密鑰大小為96-1024位  
            keyPairGen.initialize(1024,new SecureRandom());  
            // 生成一個密鑰對,保存在keyPair中  
            KeyPair keyPair = keyPairGen.generateKeyPair();  
            RSAPrivateKey privateKey = (RSAPrivateKey) keyPair.getPrivate();   // 得到私鑰  
            RSAPublicKey publicKey = (RSAPublicKey) keyPair.getPublic();  // 得到公鑰  
            String publicKeyString = new String(Base64.encodeBase64(publicKey.getEncoded()));  
            // 得到私鑰字符串  
            String privateKeyString = new String(Base64.encodeBase64((privateKey.getEncoded())));  
            // 將公鑰和私鑰保存到Map
            keyMap.put(0,publicKeyString);  //0表示公鑰
            keyMap.put(1,privateKeyString);  //1表示私鑰
        }  
        /** 
         * RSA公鑰加密 
         *  
         * @param str 
         *            加密字符串
         * @param publicKey 
         *            公鑰 
         * @return 密文 
         * @throws Exception 
         *             加密過程中的異常信息 
         */  
        public static String encrypt( String str, String publicKey ) throws Exception{
            //base64編碼的公鑰
            byte[] decoded = Base64.decodeBase64(publicKey);
            RSAPublicKey pubKey = (RSAPublicKey) KeyFactory.getInstance("RSA").generatePublic(new X509EncodedKeySpec(decoded));
            //RSA加密
            Cipher cipher = Cipher.getInstance("RSA");
            cipher.init(Cipher.ENCRYPT_MODE, pubKey);
            String outStr = Base64.encodeBase64String(cipher.doFinal(str.getBytes("UTF-8")));
            return outStr;
        }

        /** 
         * RSA私鑰解密
         *  
         * @param str 
         *            加密字符串
         * @param privateKey 
         *            私鑰 
         * @return 銘文
         * @throws Exception 
         *             解密過程中的異常信息 
         */  
        public static String decrypt(String str, String privateKey) throws Exception{
            //64位解碼加密后的字符串
            byte[] inputByte = Base64.decodeBase64(str.getBytes("UTF-8"));
            //base64編碼的私鑰
            byte[] decoded = Base64.decodeBase64(privateKey);  
            RSAPrivateKey priKey = (RSAPrivateKey) KeyFactory.getInstance("RSA").generatePrivate(new PKCS8EncodedKeySpec(decoded));  
            //RSA解密
            Cipher cipher = Cipher.getInstance("RSA");
            cipher.init(Cipher.DECRYPT_MODE, priKey);
            String outStr = new String(cipher.doFinal(inputByte));
            return outStr;
        }

    }  

    藍藍設(shè)計建立了UI設(shè)計分享群,每天會分享國內(nèi)外的一些優(yōu)秀設(shè)計,如果有興趣的話,可以進入一起成長學(xué)習(xí),請掃碼藍小助,報下信息,藍小助會請您入群。歡迎您加入噢~~希望得到建議咨詢、商務(wù)合作,也請與我們聯(lián)系。

    截屏2021-05-13 上午11.41.03.png


    文章來源:csdn   

    分享此文一切功德,皆悉回向給文章原作者及眾讀者.
    免責(zé)聲明:藍藍設(shè)計尊重原作者,文章的版權(quán)歸原作者。如涉及版權(quán)問題,請及時與我們?nèi)〉寐?lián)系,我們立即更正或刪除。

    藍藍設(shè)計www.dzxscac.cn )是一家專注而深入的界面設(shè)計公司,為期望卓越的國內(nèi)外企業(yè)提供卓越的UI界面設(shè)計、BS界面設(shè)計 、 cs界面設(shè)計 、 ipad界面設(shè)計 、 包裝設(shè)計 、 圖標(biāo)定制 、 用戶體驗 、交互設(shè)計、 網(wǎng)站建設(shè) 平面設(shè)計服務(wù)

    日歷

    鏈接

    個人資料

    藍藍設(shè)計的小編 http://www.dzxscac.cn

    存檔

    主站蜘蛛池模板: 国产精品高清视亚洲精品| 麻豆乱淫一区二区三区| 亚洲少妇中文字幕| 亚洲日本在线电影| 亚洲熟妇丰满xxxxx国语| 91最新地址永久入口| 九九热这里只有精品在线| 国内精品自国内精品66j影院| av在线视| 欧美一级啪啪| 国产美女精品一区二区三区| 成人aa免费视频在线播放| 在线不卡一区二区| 人人爽人人爽人人片av东京热| 亚洲国产精品成人精品无码区蜜臀| 精品在线一区| 性欧美在线观看| 2020精品国产自在现线看| 国产精品麻花传媒二三区别| 亚洲喷水| av在线浏览| 国产人妻精品一区二区三区不卡| 国产精品a久久777777| 久久免费视频播放| www.欧美国产| av无码不卡一区二区三区| 免费无码又爽又刺激高潮的漫画| 久久sese| 亚洲天堂在线观看完整版| 97国产精华最好的产品亚洲| 日韩精品视频在线| av色网站| 亚洲日韩久热中文字幕| 性欧美性另类巨大| 在线永久看片免费的视频| 99热精品在线播放| 无码人妻一区二区三区线| 免费国产va在线观看视频| 日本xxxxxⅹxxxx69| 白石茉莉奈番号| 怡红院av亚洲一区二区三区h |