亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? hybrid.java

?? 一個java開發的非常全面的關于證書發放
?? JAVA
?? 第 1 頁 / 共 5 頁
字號:
            if (dataStr != null) {
                // close outputstream
                try {
                    dataStr.close();
                } catch (IOException e) {
                    ;
                }
            }
        }
    }

    /**
     * Decrypts and verifies an inputstream (which must support mark/reset) with HMAC
     *
     * @param is inputstream to decrypt (NOTE: the inputstream must support mark/reset because it must be read three times)
     * @param daos outputstream to store the decrypted data
     * @param privKey the receiver's private key for decryption
     * @param algorithm encryption algorithm (e.g. "Rijndael")
     * @param mode encryption mode (e.g. "CBC")
     * @param padding padding scheme (e.g."PKCS7Padding")
     * @param bufferlength buffer length in bytes
     * @throws IOException I/O errors
     * @throws HeaderException thrown when package header is broken
     * @throws InvalidHMACException thrown when the HMAC code is invalid
     * @throws CryptoException all encryption errors
     */
    public static void decryptAndVerifyHMAC(InputStream is
                                            , DataOutputStream daos
                                            , PrivateKey privKey
                                            , String algorithm
                                            , String mode
                                            , String padding
                                            , int bufferlength)
            throws IOException, HeaderException, InvalidHMACException, CryptoException {

        SecureRandom secRand;
        Mac mac = null;
        Cipher cipher = null;
        Cipher decHMAC = null;

        SecretKey symKey = null; // Symmetric key.
        SecretKey macKey = null; // MAC key.

        byte[] keyIV = null;   // AES IV
        byte[] macCode = null;   // MAC code

        DataInputStream dataIn = null;
        MacInputStream macStr = null;
        DataInputStream dataStr = null;

        try {
            Security.addProvider(new BouncyCastleProvider());

            secRand = SecureRandom.getInstance("SHA1PRNG", "SUN");

            dataIn = new DataInputStream(is);

            int l = 0; // Universal length variable.
            boolean ena = false; // Enable flag.. (Set when file/string header found)
            boolean stop = false; // Stop flag.

            // Setup RSA to decrypt secrets.
            Cipher rsaEng = Cipher.getInstance("RSA/None/OAEPPadding", "BC");
            rsaEng.init(Cipher.DECRYPT_MODE, privKey, secRand); // Initialize cipher for decryption.

            while (!stop) {
                try {
                    int cmd = dataIn.readShort(); // Read in block header.

                    if (cmd == FILE_HEADER) // File header.
                    {
                        ena = true; // Flag file header found.
                        continue;
                    }

                    if (cmd == DATA_BLOCK) // Read in data block
                    {
                        if (!ena) {
                            throw new HeaderException("Broken header");
                        }

                        l = dataIn.readInt(); // Read length.
                        dataIn.skip(l); // Skip this data.
                        continue;
                    }

                    if (cmd == FINAL_DATA_BLOCK) // Final data block.
                    {
                        if (!ena) {
                            throw new HeaderException("Broken header");
                        }
                        l = dataIn.readInt(); // Read length
                        dataIn.skip(l); // Skip this data.
                        continue;
                    }

                    if (cmd == HMAC_BLOCK) // MAC block.
                    {
                        if (!ena) {
                            throw new HeaderException("Broken header");
                        }
                        l = dataIn.readInt(); // Read length.
                        macCode = new byte[l]; // Create new array (l) in size.
                        dataIn.readFully(macCode); // Read in signature.
                        continue;
                    }

                    if (cmd == KEY_BLOCK) // Read in key block.
                    {
                        if (!ena) {
                            throw new HeaderException("Broken header");
                        }

                        l = dataIn.readInt(); // Read length.
                        byte[] d = new byte[l];  // Create new array (l) in size.
                        dataIn.readFully(d); // read in data.
                        // We must use a SecretKeySpec set up
                        // to convert the raw encoded key back into a SecretKey Object.
                        // The key is also decrypted before processing.

                        symKey = new SecretKeySpec(rsaEng.doFinal(d), algorithm);
                        continue;
                    }

                    if (cmd == IV_BLOCK) // Read in IV.
                    {
                        if (!ena) {
                            throw new HeaderException("Broken header");
                        }
                        l = dataIn.readInt(); // Read length
                        keyIV = new byte[l]; // Create new array for IV (l) in size.
                        dataIn.readFully(keyIV); // Read in IV.
                        keyIV = rsaEng.doFinal(keyIV); // Decrypt IV
                        continue;
                    }

                    if (cmd == HMAC_KEY_BLOCK) // Read lock.
                    {
                        if (!ena) {
                            throw new HeaderException("Broken header");
                        }

                        // Set up cipher to decrypt MAC
                        decHMAC = Cipher.getInstance(algorithm + "/" + mode + "/" + padding, "BC");
                        decHMAC.init(Cipher.DECRYPT_MODE, symKey, new IvParameterSpec(keyIV));
                        l = dataIn.readInt(); // Read Length
                        byte[] d = new byte[l]; // Create new byte array (l) in size.
                        dataIn.readFully(d); // Read
                        macKey = new SecretKeySpec(decHMAC.doFinal(d), "HMACSHA1"); // Decrypt lock.

                        continue;
                    }
                } catch (EOFException eof) {
                    stop = true;
                }
            }

            mac = Mac.getInstance("HMACSHA1", "BC"); // Mac algorithm based on SHA1 message digest.
            mac.init(macKey); // initialize it with the mac key.

            // Set up input stream wrappers.
            is.reset();
            macStr = new MacInputStream(is, mac);
            dataStr = new DataInputStream(macStr);

            int cmd = 0; // variable to store block header.
            byte[] buf = new byte[bufferlength]; // Buffer to work in.
            l = 0; // Universal length variable.

            do {
                cmd = dataStr.readShort(); // Read off block header/

                if (cmd == DATA_BLOCK) // Skip HMAC block.
                {
                    l = dataStr.readInt(); // Read length.
                    dataStr.read(buf, 0, l); // dummy read.
                }

                if (cmd == FINAL_DATA_BLOCK) // Skip the KEY Block
                {
                    l = dataStr.readInt();
                    dataStr.read(buf, 0, l); // dummy read
                }


                if (cmd == KEY_BLOCK) // Skip the KEY Block
                {
                    l = dataStr.readInt();
                    dataStr.read(buf, 0, l); // dummy read
                }

                if (cmd == IV_BLOCK) // Skip the IV block.
                {
                    l = dataStr.readInt();
                    dataStr.read(buf, 0, l); // dummy read
                }

                if (cmd == HMAC_KEY_BLOCK) // Skip the IV block.
                {
                    l = dataStr.readInt();
                    dataStr.read(buf, 0, l); // dummy read
                }
            } while (cmd != HMAC_BLOCK);

            buf = mac.doFinal();
            dataStr.close();

            if (!MessageDigest.isEqual(buf, macCode)) {
                throw new InvalidHMACException("Invalid HMAC");
            }

            cipher = Cipher.getInstance(algorithm + "/" + mode + "/" + padding, "BC");
            cipher.init(Cipher.DECRYPT_MODE, symKey, new IvParameterSpec(keyIV));

            is.reset();
            dataStr = new DataInputStream(is);

            stop = false; // Loop breaker.
            cmd = 0; // Variable to hold block header.
            l = 0; // Universal length variable.
            buf = new byte[bufferlength]; // A buffer to work in.
            byte[] out = null; // Output buffer.

            for (; ;) {
                cmd = dataStr.readShort(); // Read in block header.

                if (cmd == DATA_BLOCK) {
                    l = dataStr.readInt(); // Get length of data.
                    dataStr.readFully(buf, 0, l); // Read data.
                    out = cipher.update(buf, 0, l);
                    if (out != null) daos.write(out);
                }

                if (cmd == FINAL_DATA_BLOCK) {
                    l = dataStr.readInt(); // Length of data.
                    dataStr.readFully(buf, 0, l); // Read in data.
                    out = cipher.doFinal(buf, 0, l);
                    if (out != null) daos.write(out);
                    break;
                }

                // The following blocks and their content are skipped.
                if (cmd == KEY_BLOCK) // Skip the KEY Block
                {
                    l = dataStr.readInt();
                    dataStr.skip(l);
                }

                if (cmd == IV_BLOCK) // Skip the IV block.
                {
                    l = dataStr.readInt();
                    dataStr.skip(l);
                }

                if (cmd == HMAC_BLOCK) // Skip the IV block.
                {
                    l = dataStr.readInt();
                    dataStr.skip(l);
                }

                if (cmd == HMAC_KEY_BLOCK) // Skip the IV block.
                {
                    l = dataStr.readInt();
                    dataStr.skip(l);
                }
            }
        } catch (IOException ioe) {
            ioe.printStackTrace();
            throw new IOException(ioe.getMessage());
        } catch (HeaderException he) {
            he.printStackTrace();
            throw new HeaderException(he.getMessage());
        } catch (InvalidHMACException ihe) {
            ihe.printStackTrace();
            throw new InvalidHMACException(ihe.getMessage());
        } catch (Exception ex) {
            ex.printStackTrace();
            throw new CryptoException(ex.getMessage());
        }
    }

    /**
     * Encrypt and sign a text
     *
     * @param text the text to encrypt and sign
     * @param receiverKey the public key of the receiver
     * @param signingKey the private key of the signer
     * @param cert the signer's certificate
     * @param signame the signature's algorithm (e.g."MD5withRSA")
     * @param algorithm encryption algorithm (e.g. "Rijndael")
     * @param seed for SecureRandom (optional)
     * @param strength the keysize in bits (e.g. 128)
     * @param mode encryption mode (e.g. "CBC")
     * @param padding padding scheme (e.g."PKCS7Padding")
     * @return ciphered and signed text
     * @throws CryptoException encryption errors
     */
    public static StringBuffer encryptAndSign(StringBuffer text
                                              , PublicKey receiverKey
                                              , PrivateKey signingKey
                                              , X509Certificate cert
                                              , String signame
                                              , String algorithm
                                              , byte[] seed
                                              , int strength
                                              , String mode
                                              , String padding) throws CryptoException {

        ByteArrayOutputStream bao = null;
        DataOutputStream dao = null;

        try {
            bao = new ByteArrayOutputStream();
            dao = new DataOutputStream(bao);

            // encrypt text with HMAC
            encryptAndSign(new ByteArrayInputStream(text.toString().getBytes()), dao, receiverKey, signingKey, cert, signame, algorithm, seed, strength, mode, padding, BUFFERSIZE_TEXT);
            return new StringBuffer(new String(Base64.encode(bao.toByteArray())));
        } catch (IOException ioe) {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区二区三区在线观看精品 | 日韩精品一级中文字幕精品视频免费观看| 粉嫩在线一区二区三区视频| 中文一区二区完整视频在线观看 | 亚洲国产日韩综合久久精品| 7777精品伊人久久久大香线蕉的| 精品一区二区免费看| 久久精品亚洲麻豆av一区二区 | 亚洲黄色小视频| 精品国产百合女同互慰| 成人国产亚洲欧美成人综合网| 亚洲一区免费观看| 国产精品污污网站在线观看| 欧美日韩一区二区三区视频| 国产精品18久久久久久vr| 亚洲一级电影视频| 亚洲免费观看高清| 久久精品人人做人人爽人人| 555www色欧美视频| 在线观看成人小视频| 成人性生交大片免费看视频在线| 日韩黄色片在线观看| 亚洲小少妇裸体bbw| 亚洲色图色小说| 国产精品福利av | 亚洲人精品一区| 一区二区在线看| 亚洲成人免费观看| 五月婷婷久久丁香| 丝袜诱惑亚洲看片| 麻豆精品久久精品色综合| 蜜桃传媒麻豆第一区在线观看| 日韩电影一区二区三区四区| 日韩精品乱码av一区二区| 三级精品在线观看| 免费av网站大全久久| 国产精品综合一区二区| 91亚洲精品一区二区乱码| 色综合久久99| 欧美一激情一区二区三区| 久久久久久久久久久久久夜| 《视频一区视频二区| 一级中文字幕一区二区| 日本午夜一区二区| 粉嫩久久99精品久久久久久夜| 色综合久久综合中文综合网| 欧美老人xxxx18| 亚洲区小说区图片区qvod| 美女国产一区二区三区| caoporn国产精品| 久久夜色精品国产噜噜av| 日韩毛片精品高清免费| 韩日精品视频一区| 精品国产一区二区精华| 亚洲丰满少妇videoshd| 国产精品一二三在| 欧美一区午夜精品| 樱桃视频在线观看一区| 国产sm精品调教视频网站| 91精品国产欧美一区二区| 亚洲乱码国产乱码精品精98午夜| 极品美女销魂一区二区三区| 欧美日韩亚洲综合在线| 亚洲视频中文字幕| aaa亚洲精品一二三区| 中文字幕一区二区三| 国产在线精品国自产拍免费| 精品剧情在线观看| 奇米精品一区二区三区在线观看一| 欧美性猛交xxxx乱大交退制版| 国产精品国产精品国产专区不蜜| 国产一区在线视频| 国产精品人成在线观看免费| 成人手机在线视频| 一区在线播放视频| 欧美日韩精品一区二区| 香蕉乱码成人久久天堂爱免费| 欧美一区午夜视频在线观看| 亚洲免费视频成人| 精品国产亚洲在线| 91日韩精品一区| 麻豆精品视频在线观看免费| 国产亚洲短视频| 欧美视频在线一区| 日韩精品欧美精品| 国产精品国产三级国产普通话三级 | 成人免费毛片aaaaa**| 亚洲婷婷综合色高清在线| 91麻豆免费看| 精彩视频一区二区三区| 亚洲女同女同女同女同女同69| 欧美日韩国产一级片| 国产mv日韩mv欧美| 另类成人小视频在线| 亚洲一区二区三区中文字幕 | 色噜噜夜夜夜综合网| 国模冰冰炮一区二区| 亚洲高清一区二区三区| 国产色产综合产在线视频| 制服视频三区第一页精品| 99综合电影在线视频| 国产真实乱子伦精品视频| 艳妇臀荡乳欲伦亚洲一区| 中文字幕一区二区三区精华液| 国产人久久人人人人爽| 久久日韩精品一区二区五区| 精品视频一区三区九区| 欧美性受xxxx| 91精品国产一区二区| 欧美精品一级二级三级| 欧美日韩国产色站一区二区三区| eeuss鲁片一区二区三区在线观看| 青青草97国产精品免费观看无弹窗版 | 成人国产亚洲欧美成人综合网 | 男女男精品视频网| 美女www一区二区| 国产一区在线观看视频| 国产成人综合在线| voyeur盗摄精品| 欧美色爱综合网| 久久久久久久久97黄色工厂| 国产午夜精品一区二区| 一区二区三区 在线观看视频| 午夜激情久久久| 国产大陆亚洲精品国产| 一本大道av一区二区在线播放 | 国产成人一区在线| 在线免费不卡视频| 欧美本精品男人aⅴ天堂| 国产精品色婷婷久久58| 日韩影院精彩在线| 91香蕉视频污| 久久蜜桃av一区精品变态类天堂| 亚洲天堂a在线| 激情综合网最新| 欧美日韩视频专区在线播放| 久久久久国产免费免费| 午夜精品久久久久久久99樱桃 | 欧洲一区二区三区在线| 国产无人区一区二区三区| 亚洲国产中文字幕| 91影院在线观看| 国产欧美日韩精品一区| 青青青伊人色综合久久| 欧美日韩电影在线| 一级特黄大欧美久久久| 99久久久久免费精品国产 | 久久综合九色综合欧美亚洲| 日韩精品五月天| 91麻豆精品国产91久久久更新时间| 国产精品国产自产拍高清av王其| 国产在线精品不卡| 2023国产精品| 国产精品99久久久久久似苏梦涵 | 91免费视频网| 亚洲国产精品麻豆| 午夜在线电影亚洲一区| 欧美综合天天夜夜久久| 亚洲国产精品久久不卡毛片| 欧美体内she精视频| 一个色在线综合| 这里只有精品免费| 蜜桃精品视频在线| 欧美高清在线精品一区| 日本精品一区二区三区高清| 亚洲综合在线免费观看| 欧美午夜不卡在线观看免费| 成人免费看的视频| 亚洲小说春色综合另类电影| 777奇米成人网| 成人看片黄a免费看在线| 日本一二三四高清不卡| 日本丰满少妇一区二区三区| 悠悠色在线精品| 国产精品视频yy9299一区| 国产欧美综合在线| 亚洲日本va在线观看| 久久无码av三级| 在线91免费看| 色88888久久久久久影院野外| 国产一区二区久久| 美女视频黄免费的久久| 亚洲亚洲精品在线观看| 亚洲女女做受ⅹxx高潮| 国产嫩草影院久久久久| 国产亚洲精品中文字幕| 日韩欧美国产精品一区| 精品精品国产高清一毛片一天堂| 欧美丰满美乳xxx高潮www| 欧美日韩一卡二卡三卡| 欧美一卡2卡3卡4卡| 日韩三级免费观看| 欧美国产日本视频| 亚洲情趣在线观看| 一区二区三区加勒比av| 一区二区理论电影在线观看| 亚洲自拍欧美精品| 五月婷婷综合在线| 国产乱一区二区| 色一区在线观看|