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

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

?? md4digest.java

?? 內容:基于jdk1.4的加密算法的具體實現
?? JAVA
字號:
package org.bouncycastle.crypto.digests;/** * implementation of MD4 as RFC 1320 by R. Rivest, MIT Laboratory for * Computer Science and RSA Data Security, Inc. * <p> * <b>NOTE</b>: This algorithm is only included for backwards compatability * with legacy applications, it's not secure, don't use it for anything new! */public class MD4Digest    extends GeneralDigest{    private static final int    DIGEST_LENGTH = 16;    private int     H1, H2, H3, H4;         // IV's    private int[]   X = new int[16];    private int     xOff;    /**     * Standard constructor     */    public MD4Digest()    {        reset();    }    /**     * Copy constructor.  This will copy the state of the provided     * message digest.     */    public MD4Digest(MD4Digest t)    {        super(t);        H1 = t.H1;        H2 = t.H2;        H3 = t.H3;        H4 = t.H4;        System.arraycopy(t.X, 0, X, 0, t.X.length);        xOff = t.xOff;    }    public String getAlgorithmName()    {        return "MD4";    }    public int getDigestSize()    {        return DIGEST_LENGTH;    }    protected void processWord(        byte[]  in,        int     inOff)    {        X[xOff++] = (in[inOff] & 0xff) | ((in[inOff + 1] & 0xff) << 8)            | ((in[inOff + 2] & 0xff) << 16) | ((in[inOff + 3] & 0xff) << 24);         if (xOff == 16)        {            processBlock();        }    }    protected void processLength(        long    bitLength)    {        if (xOff > 14)        {            processBlock();        }        X[14] = (int)(bitLength & 0xffffffff);        X[15] = (int)(bitLength >>> 32);    }    private void unpackWord(        int     word,        byte[]  out,        int     outOff)    {        out[outOff]     = (byte)word;        out[outOff + 1] = (byte)(word >>> 8);        out[outOff + 2] = (byte)(word >>> 16);        out[outOff + 3] = (byte)(word >>> 24);    }    public int doFinal(        byte[]  out,        int     outOff)    {        finish();        unpackWord(H1, out, outOff);        unpackWord(H2, out, outOff + 4);        unpackWord(H3, out, outOff + 8);        unpackWord(H4, out, outOff + 12);        reset();        return DIGEST_LENGTH;    }    /**     * reset the chaining variables to the IV values.     */    public void reset()    {        super.reset();        H1 = 0x67452301;        H2 = 0xefcdab89;        H3 = 0x98badcfe;        H4 = 0x10325476;        xOff = 0;        for (int i = 0; i != X.length; i++)        {            X[i] = 0;        }    }    //    // round 1 left rotates    //    private static final int S11 = 3;    private static final int S12 = 7;    private static final int S13 = 11;    private static final int S14 = 19;    //    // round 2 left rotates    //    private static final int S21 = 3;    private static final int S22 = 5;    private static final int S23 = 9;    private static final int S24 = 13;    //    // round 3 left rotates    //    private static final int S31 = 3;    private static final int S32 = 9;    private static final int S33 = 11;    private static final int S34 = 15;    /*     * rotate int x left n bits.     */    private int rotateLeft(        int x,        int n)    {        return (x << n) | (x >>> (32 - n));    }    /*     * F, G, H and I are the basic MD4 functions.     */    private int F(        int u,        int v,        int w)    {        return (u & v) | (~u & w);    }    private int G(        int u,        int v,        int w)    {        return (u & v) | (u & w) | (v & w);    }    private int H(        int u,        int v,        int w)    {        return u ^ v ^ w;    }    protected void processBlock()    {        int a = H1;        int b = H2;        int c = H3;        int d = H4;        //        // Round 1 - F cycle, 16 times.        //        a = rotateLeft(a + F(b, c, d) + X[ 0], S11);        d = rotateLeft(d + F(a, b, c) + X[ 1], S12);        c = rotateLeft(c + F(d, a, b) + X[ 2], S13);        b = rotateLeft(b + F(c, d, a) + X[ 3], S14);        a = rotateLeft(a + F(b, c, d) + X[ 4], S11);        d = rotateLeft(d + F(a, b, c) + X[ 5], S12);        c = rotateLeft(c + F(d, a, b) + X[ 6], S13);        b = rotateLeft(b + F(c, d, a) + X[ 7], S14);        a = rotateLeft(a + F(b, c, d) + X[ 8], S11);        d = rotateLeft(d + F(a, b, c) + X[ 9], S12);        c = rotateLeft(c + F(d, a, b) + X[10], S13);        b = rotateLeft(b + F(c, d, a) + X[11], S14);        a = rotateLeft(a + F(b, c, d) + X[12], S11);        d = rotateLeft(d + F(a, b, c) + X[13], S12);        c = rotateLeft(c + F(d, a, b) + X[14], S13);        b = rotateLeft(b + F(c, d, a) + X[15], S14);        //        // Round 2 - G cycle, 16 times.        //        a = rotateLeft(a + G(b, c, d) + X[ 0] + 0x5a827999, S21);        d = rotateLeft(d + G(a, b, c) + X[ 4] + 0x5a827999, S22);        c = rotateLeft(c + G(d, a, b) + X[ 8] + 0x5a827999, S23);        b = rotateLeft(b + G(c, d, a) + X[12] + 0x5a827999, S24);        a = rotateLeft(a + G(b, c, d) + X[ 1] + 0x5a827999, S21);        d = rotateLeft(d + G(a, b, c) + X[ 5] + 0x5a827999, S22);        c = rotateLeft(c + G(d, a, b) + X[ 9] + 0x5a827999, S23);        b = rotateLeft(b + G(c, d, a) + X[13] + 0x5a827999, S24);        a = rotateLeft(a + G(b, c, d) + X[ 2] + 0x5a827999, S21);        d = rotateLeft(d + G(a, b, c) + X[ 6] + 0x5a827999, S22);        c = rotateLeft(c + G(d, a, b) + X[10] + 0x5a827999, S23);        b = rotateLeft(b + G(c, d, a) + X[14] + 0x5a827999, S24);        a = rotateLeft(a + G(b, c, d) + X[ 3] + 0x5a827999, S21);        d = rotateLeft(d + G(a, b, c) + X[ 7] + 0x5a827999, S22);        c = rotateLeft(c + G(d, a, b) + X[11] + 0x5a827999, S23);        b = rotateLeft(b + G(c, d, a) + X[15] + 0x5a827999, S24);        //        // Round 3 - H cycle, 16 times.        //        a = rotateLeft(a + H(b, c, d) + X[ 0] + 0x6ed9eba1, S31);        d = rotateLeft(d + H(a, b, c) + X[ 8] + 0x6ed9eba1, S32);        c = rotateLeft(c + H(d, a, b) + X[ 4] + 0x6ed9eba1, S33);        b = rotateLeft(b + H(c, d, a) + X[12] + 0x6ed9eba1, S34);        a = rotateLeft(a + H(b, c, d) + X[ 2] + 0x6ed9eba1, S31);        d = rotateLeft(d + H(a, b, c) + X[10] + 0x6ed9eba1, S32);        c = rotateLeft(c + H(d, a, b) + X[ 6] + 0x6ed9eba1, S33);        b = rotateLeft(b + H(c, d, a) + X[14] + 0x6ed9eba1, S34);        a = rotateLeft(a + H(b, c, d) + X[ 1] + 0x6ed9eba1, S31);        d = rotateLeft(d + H(a, b, c) + X[ 9] + 0x6ed9eba1, S32);        c = rotateLeft(c + H(d, a, b) + X[ 5] + 0x6ed9eba1, S33);        b = rotateLeft(b + H(c, d, a) + X[13] + 0x6ed9eba1, S34);        a = rotateLeft(a + H(b, c, d) + X[ 3] + 0x6ed9eba1, S31);        d = rotateLeft(d + H(a, b, c) + X[11] + 0x6ed9eba1, S32);        c = rotateLeft(c + H(d, a, b) + X[ 7] + 0x6ed9eba1, S33);        b = rotateLeft(b + H(c, d, a) + X[15] + 0x6ed9eba1, S34);        H1 += a;        H2 += b;        H3 += c;        H4 += d;        //        // reset the offset and clean out the word buffer.        //        xOff = 0;        for (int i = 0; i != X.length; i++)        {            X[i] = 0;        }    }}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区二三区好的| 欧美久久免费观看| 亚洲精品国产精品乱码不99| 色婷婷综合久久| 亚洲成人精品一区二区| 欧美精品 日韩| 精彩视频一区二区三区| 国产日韩精品一区二区三区在线| 99在线精品一区二区三区| 亚洲精品第一国产综合野| 欧美人与性动xxxx| 久久不见久久见免费视频1| 久久精品这里都是精品| 91免费版在线| 男女男精品视频网| 日本一区二区三区视频视频| 日本丰满少妇一区二区三区| 日韩在线一二三区| 久久久精品国产免大香伊| 91在线无精精品入口| 午夜精品久久久久| 国产性做久久久久久| 色丁香久综合在线久综合在线观看| 五月激情综合网| 久久久欧美精品sm网站| 色婷婷狠狠综合| 免费观看在线色综合| 中文字幕欧美激情| 欧美丰满少妇xxxxx高潮对白| 国产自产视频一区二区三区| 亚洲免费观看高清完整版在线观看| 制服丝袜中文字幕亚洲| 高清av一区二区| 亚洲丶国产丶欧美一区二区三区| 久久久美女毛片| 欧美三区在线观看| 国产成人精品一区二区三区四区| 亚洲综合色成人| 国产亚洲综合在线| 欧美日韩国产大片| 国产1区2区3区精品美女| 天天av天天翘天天综合网| 欧美国产激情二区三区| 4438成人网| 91视频在线观看免费| 久久99久久99小草精品免视看| 自拍av一区二区三区| 26uuu亚洲综合色| 欧美亚洲图片小说| 成年人网站91| 狠狠色伊人亚洲综合成人| 亚洲一区二区三区激情| 国产精品欧美一级免费| 日韩你懂的在线播放| 色欧美日韩亚洲| 国产成人高清在线| 另类小说综合欧美亚洲| 亚洲一区二区欧美| 国产精品美女视频| 精品噜噜噜噜久久久久久久久试看| 在线观看av一区二区| 成人性生交大片| 精品制服美女丁香| 五月天婷婷综合| 亚洲欧美偷拍另类a∨色屁股| 2023国产一二三区日本精品2022| 欧美色综合影院| 99久久精品免费| 国产麻豆一精品一av一免费| 日韩综合在线视频| 亚洲黄色在线视频| 国产精品三级av| 久久精品亚洲精品国产欧美| 欧美一区二区精品在线| 欧美伊人久久久久久久久影院 | 蜜臀精品久久久久久蜜臀| 亚洲欧美日韩电影| 国产精品久久影院| 国产亚洲欧洲997久久综合| 日韩一区二区麻豆国产| 在线看日韩精品电影| youjizz久久| 国产精品18久久久久久久久 | 日韩一区二区三区四区| 在线观看欧美精品| 99re亚洲国产精品| 成人蜜臀av电影| 国产精品亚洲а∨天堂免在线| 免费成人美女在线观看| 五月婷婷色综合| 亚洲午夜av在线| 一区二区三区免费看视频| 中文文精品字幕一区二区| 欧美精品一区二区三| 欧美大片一区二区| 欧美一区欧美二区| 日韩一区和二区| 91精品国产免费| 日韩女优av电影在线观看| 日韩三级中文字幕| 日韩欧美在线观看一区二区三区| 91超碰这里只有精品国产| 日本精品视频一区二区三区| 91色.com| 91久久精品国产91性色tv | 99久久99久久精品免费看蜜桃| 国产激情视频一区二区三区欧美 | 91精品久久久久久蜜臀| 欧美嫩在线观看| 欧美一区日本一区韩国一区| 4438亚洲最大| 精品伦理精品一区| 久久久久99精品一区| 欧美国产精品久久| 《视频一区视频二区| 亚洲视频免费在线| 依依成人综合视频| 亚洲一区视频在线| 日韩精品午夜视频| 精品在线一区二区| 国产成a人亚洲| 99久久精品国产精品久久| 色999日韩国产欧美一区二区| 欧美在线视频全部完| 欧美日韩不卡视频| 日韩一二三区不卡| 26uuu精品一区二区在线观看| 久久久久久久久久看片| 国产精品毛片久久久久久久| 伊人性伊人情综合网| 亚洲一区二区在线免费观看视频| 亚洲mv在线观看| 久久国产精品99精品国产 | 亚洲国产精品黑人久久久| 国产精品毛片无遮挡高清| 一区二区视频在线| 日韩av一级电影| 国产一区欧美一区| 成人性色生活片| 欧美日韩一区久久| 精品国产91久久久久久久妲己| 国产欧美日韩亚州综合| 亚洲男同1069视频| 三级一区在线视频先锋| 国产一区二区女| 91在线免费播放| 56国语精品自产拍在线观看| 久久久久久久久久久99999| 亚洲美女屁股眼交3| 日韩电影免费在线看| 国产馆精品极品| 91成人国产精品| 精品粉嫩超白一线天av| 日韩理论片一区二区| 日本成人在线视频网站| 高清国产一区二区| 欧美性大战久久久久久久| 2021国产精品久久精品| 亚洲免费观看在线视频| 久久精品国产**网站演员| 91在线视频免费91| 日韩免费观看高清完整版 | 色综合 综合色| 日韩亚洲欧美中文三级| 国产精品久久国产精麻豆99网站| 香蕉加勒比综合久久| 成人性生交大片免费看视频在线| 欧美日韩免费电影| 国产午夜亚洲精品理论片色戒| 亚洲自拍欧美精品| 国产成人在线电影| 在线成人av影院| 中文字幕二三区不卡| 日韩精品福利网| 波多野结衣在线aⅴ中文字幕不卡| 欧美色图在线观看| 国产欧美视频一区二区| 日韩精品亚洲专区| 91在线一区二区| 久久五月婷婷丁香社区| 一区二区三区不卡在线观看| 国内精品视频一区二区三区八戒| 在线观看国产一区二区| 国产喷白浆一区二区三区| 日韩精品欧美精品| 91蜜桃免费观看视频| 欧美精品一区二区三区四区| 亚洲成av人影院在线观看网| 风流少妇一区二区| 欧美一级精品大片| 亚洲国产综合色| 成人开心网精品视频| 日韩久久免费av| 亚洲国产裸拍裸体视频在线观看乱了 | 精品亚洲国内自在自线福利| 欧美又粗又大又爽| 国产精品久久久久久户外露出| 国内国产精品久久| 制服丝袜av成人在线看| 一区二区成人在线观看|