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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? iso9796d2psssigner.java

?? 內(nèi)容:基于jdk1.4的加密算法的具體實(shí)現(xiàn)
?? JAVA
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
package org.bouncycastle.crypto.signers;import java.security.SecureRandom;import org.bouncycastle.crypto.AsymmetricBlockCipher;import org.bouncycastle.crypto.CipherParameters;import org.bouncycastle.crypto.CryptoException;import org.bouncycastle.crypto.Digest;import org.bouncycastle.crypto.SignerWithRecovery;import org.bouncycastle.crypto.digests.RIPEMD128Digest;import org.bouncycastle.crypto.digests.RIPEMD160Digest;import org.bouncycastle.crypto.digests.SHA1Digest;import org.bouncycastle.crypto.params.ParametersWithRandom;import org.bouncycastle.crypto.params.ParametersWithSalt;import org.bouncycastle.crypto.params.RSAKeyParameters;/** * ISO9796-2 - mechanism using a hash function with recovery (scheme 2 and 3). * <p> * Note: the usual length for the salt is the length of the hash  * function used in bytes. */public class ISO9796d2PSSSigner    implements SignerWithRecovery{    static final public int   TRAILER_IMPLICIT    = 0xBC;    static final public int   TRAILER_RIPEMD160   = 0x31CC;    static final public int   TRAILER_RIPEMD128   = 0x32CC;    static final public int   TRAILER_SHA1        = 0x33CC;    private Digest                      digest;    private AsymmetricBlockCipher       cipher;        private SecureRandom                random;    private byte[]                      standardSalt;    private int         hLen;    private int         trailer;    private int         keyBits;    private byte[]      block;    private byte[]      mBuf;    private int         messageLength;    private int         saltLength;    private boolean     fullMessage;    private byte[]      recoveredMessage;    /**     * Generate a signer for the with either implicit or explicit trailers     * for ISO9796-2, scheme 2 or 3.     *      * @param cipher base cipher to use for signature creation/verification     * @param digest digest to use.     * @param saltLength length of salt in bytes.     * @param implicit whether or not the trailer is implicit or gives the hash.     */    public ISO9796d2PSSSigner(        AsymmetricBlockCipher   cipher,        Digest                  digest,        int                     saltLength,        boolean                 implicit)    {        this.cipher = cipher;        this.digest = digest;        this.hLen = digest.getDigestSize();        this.saltLength = saltLength;        if (implicit)        {            trailer = TRAILER_IMPLICIT;        }        else        {            if (digest instanceof SHA1Digest)            {                trailer = TRAILER_SHA1;            }            else if (digest instanceof RIPEMD160Digest)            {                trailer = TRAILER_RIPEMD160;            }            else if (digest instanceof RIPEMD128Digest)            {                trailer = TRAILER_RIPEMD128;            }            else            {                throw new IllegalArgumentException("no valid trailer for digest");            }        }    }    /**     * Constructor for a signer with an explicit digest trailer.     *      * @param cipher cipher to use.     * @param digest digest to sign with.     * @param saltLength length of salt in bytes.     */    public ISO9796d2PSSSigner(        AsymmetricBlockCipher   cipher,        Digest                  digest,        int                     saltLength)    {        this(cipher, digest, saltLength, false);    }        /**     * Initialise the signer.     *      * @param forSigning true if for signing, false if for verification.     * @param param parameters for signature generation/verification. If the     * parameters are for generation they should be a ParametersWithRandom,     * a ParametersWithSalt, or just an RSAKeyParameters object. If RSAKeyParameters     * are passed in a SecureRandom will be created.     * @exception IllegalArgumentException if wrong parameter type or a fixed      * salt is passed in which is the wrong length.     */    public void init(        boolean                 forSigning,        CipherParameters        param)    {        RSAKeyParameters    kParam = null;        int                    lengthOfSalt = saltLength;        if (param instanceof ParametersWithRandom)        {            ParametersWithRandom    p = (ParametersWithRandom)param;            kParam = (RSAKeyParameters)p.getParameters();            random = p.getRandom();        }        else if (param instanceof ParametersWithSalt)        {            ParametersWithSalt    p = (ParametersWithSalt)param;            kParam = (RSAKeyParameters)p.getParameters();            standardSalt = p.getSalt();            lengthOfSalt = standardSalt.length;        }        else        {            kParam = (RSAKeyParameters)param;            if (forSigning)            {                random = new SecureRandom();            }        }                cipher.init(forSigning, kParam);        keyBits = kParam.getModulus().bitLength();        block = new byte[(keyBits + 7) / 8];                if (trailer == TRAILER_IMPLICIT)        {            mBuf = new byte[block.length - digest.getDigestSize() - lengthOfSalt - 1 - 1];        }        else        {            mBuf = new byte[block.length - digest.getDigestSize() - lengthOfSalt - 1 - 2];        }        reset();    }    /**     * compare two byte arrays.     */    private boolean isSameAs(        byte[]    a,        byte[]    b)    {        if (messageLength != b.length)        {            return false;        }                for (int i = 0; i != b.length; i++)        {            if (a[i] != b[i])            {                return false;            }        }                return true;    }        /**     * clear possible sensitive data     */    private void clearBlock(        byte[]  block)    {        for (int i = 0; i != block.length; i++)        {            block[i] = 0;        }    }    /**     * update the internal digest with the byte b     */    public void update(        byte    b)    {        if (messageLength < mBuf.length)        {            mBuf[messageLength++] = b;        }        else        {            digest.update(b);        }    }    /**     * update the internal digest with the byte array in     */    public void update(        byte[]  in,        int     off,        int     len)    {        while (len > 0 && messageLength < mBuf.length)        {            this.update(in[off]);            off++;            len--;        }                if (len > 0)        {            digest.update(in, off, len);        }    }    /**     * reset the internal state     */    public void reset()    {        digest.reset();        messageLength = 0;        if (recoveredMessage != null)        {            clearBlock(recoveredMessage);        }        recoveredMessage = null;        fullMessage = false;    }    /**     * generate a signature for the loaded message using the key we were     * initialised with.     */    public byte[] generateSignature()        throws CryptoException    {        int     digSize = digest.getDigestSize();        int t = 0;        int delta = 0;        byte[]    m2Hash = new byte[digSize];          digest.doFinal(m2Hash, 0);        byte[]  C = new byte[8];        LtoOSP(messageLength * 8, C);        digest.update(C, 0, C.length);        digest.update(mBuf, 0, messageLength);                digest.update(m2Hash, 0, m2Hash.length);                byte[]    salt;                if (standardSalt != null)        {            salt = standardSalt;        }        else        {            salt = new byte[saltLength];            random.nextBytes(salt);        }                digest.update(salt, 0, salt.length);        byte[]    hash = new byte[digest.getDigestSize()];                digest.doFinal(hash, 0);                int tLength = 2;        if (trailer == TRAILER_IMPLICIT)        {            tLength = 1;        }                int    off = block.length - messageLength - salt.length - hLen - tLength - 1;        

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品sm在线观看| 国产精品进线69影院| 国产成人精品aa毛片| 亚洲福利视频一区二区| 中文成人综合网| 欧美mv和日韩mv的网站| 色成人在线视频| 国产91露脸合集magnet| 免费黄网站欧美| 亚洲一区二区三区三| 国产女同互慰高潮91漫画| 欧美一区二区国产| 色综合久久久久久久久| 国产成人精品一区二| 蜜臀av亚洲一区中文字幕| 亚洲综合999| 国产精品久久久久永久免费观看| 精品久久久久99| 在线综合亚洲欧美在线视频| 91精品福利视频| 99久久婷婷国产综合精品| 国产福利一区在线| 国内一区二区在线| 蜜桃视频在线一区| 日韩中文字幕91| 午夜久久久影院| 亚洲va欧美va天堂v国产综合| 亚洲激情自拍偷拍| 亚洲三级久久久| 综合欧美一区二区三区| 国产精品久久久久久久久免费樱桃| 亚洲综合免费观看高清完整版 | 久久久国产一区二区三区四区小说 | 综合自拍亚洲综合图不卡区| 久久精品一级爱片| 久久久精品免费免费| 精品国产网站在线观看| 精品国产网站在线观看| 欧美成人a∨高清免费观看| 日韩欧美综合一区| 日韩精品一区二区三区swag | 成人h精品动漫一区二区三区| 国产成人在线视频播放| 国产成人在线色| 成人激情视频网站| 91丝袜国产在线播放| 色94色欧美sute亚洲线路一久| 色屁屁一区二区| 欧美视频完全免费看| 91精品久久久久久久久99蜜臂| 日韩午夜激情视频| 26uuu色噜噜精品一区二区| www亚洲一区| 欧美韩国一区二区| 亚洲乱码国产乱码精品精小说 | 精品国产乱码久久| 国产网站一区二区三区| 中文欧美字幕免费| 洋洋成人永久网站入口| 午夜av一区二区三区| 在线亚洲一区二区| 欧美日精品一区视频| 日韩午夜激情视频| 国产日产欧美一区二区视频| 亚洲色图视频网站| 日韩中文字幕区一区有砖一区| 久久爱www久久做| 高清beeg欧美| 在线观看91视频| 精品国产免费人成电影在线观看四季| 国产亚洲精品免费| 亚洲激情自拍偷拍| 久久99久久99| 不卡一区二区在线| 欧美日韩国产综合一区二区| 精品欧美乱码久久久久久1区2区| www日韩大片| 一区av在线播放| 久久国产精品免费| 91美女片黄在线观看91美女| 91精品国产综合久久久久久久| 国产欧美日韩久久| 五月天丁香久久| 成人av综合在线| 91精品国产一区二区三区蜜臀| 欧美国产禁国产网站cc| 亚洲不卡一区二区三区| 国产精品亚洲一区二区三区妖精| 欧美在线高清视频| 国产女人aaa级久久久级| 亚洲电影在线播放| 国产成人精品一区二区三区四区 | 久久久亚洲精品一区二区三区 | 最新国产精品久久精品| 日本成人中文字幕| 97aⅴ精品视频一二三区| 日韩一区二区三区av| 亚洲欧美偷拍另类a∨色屁股| 久久精品久久99精品久久| 97久久人人超碰| 久久精品一区八戒影视| 天天综合天天做天天综合| av电影在线观看完整版一区二区| 欧美一区二区在线视频| 亚洲精品国产第一综合99久久| 国产一区二区不卡在线| 91精品国产福利| 亚洲电影中文字幕在线观看| av一区二区三区四区| 久久久国产午夜精品| 日本不卡的三区四区五区| 欧美亚洲动漫另类| 国产在线精品视频| 欧美男人的天堂一二区| 亚洲激情欧美激情| 99久久久久久| 国产精品视频免费| 国产经典欧美精品| 精品国产自在久精品国产| 天堂va蜜桃一区二区三区| 日本道色综合久久| 亚洲少妇30p| 99re在线精品| 亚洲桃色在线一区| 成人国产精品免费| 欧美激情一区二区| 成人不卡免费av| 国产精品久久网站| av爱爱亚洲一区| 国产精品久线在线观看| 成人ar影院免费观看视频| 欧美激情在线看| 成人黄色片在线观看| 欧美—级在线免费片| 岛国av在线一区| 国产精品美日韩| 9i看片成人免费高清| 日韩一区欧美一区| 91小视频免费观看| 亚洲狠狠丁香婷婷综合久久久| 色综合久久中文字幕综合网| 一区二区三国产精华液| 欧美日韩精品一区二区天天拍小说 | 91国产精品成人| 亚洲国产一区二区三区青草影视| 欧美天堂一区二区三区| 亚洲mv大片欧洲mv大片精品| 欧美久久高跟鞋激| 美脚の诱脚舐め脚责91| www亚洲一区| www.色综合.com| 一区二区三区中文字幕电影| 欧美日韩一区二区欧美激情| 日产国产欧美视频一区精品| 精品欧美黑人一区二区三区| 国产99久久久国产精品潘金| 国产精品乱码一区二三区小蝌蚪| 97超碰欧美中文字幕| 亚洲国产日韩精品| 日韩精品一区二区三区四区视频| 国产精品一区二区你懂的| 国产精品久久久久久亚洲伦 | 精品捆绑美女sm三区| 国产成人精品aa毛片| 亚洲欧美视频一区| 日韩一卡二卡三卡四卡| 国产一区二区三区日韩| 亚洲视频一二三| 欧美精品一卡二卡| 国产风韵犹存在线视精品| 亚洲精选视频免费看| 欧美电影免费观看高清完整版在线| 国产91精品一区二区麻豆亚洲| 亚洲日本在线观看| 日韩一区二区免费高清| 成人午夜免费av| 日韩成人一级大片| 国产精品入口麻豆九色| 欧美精品久久久久久久久老牛影院| 国产在线精品免费| 亚洲一区二区三区三| 国产亚洲欧美中文| 欧美日韩精品一区二区天天拍小说| 国产美女久久久久| 亚洲成人精品一区| 中文字幕第一区综合| 欧美一区二区三区日韩| av午夜精品一区二区三区| 免费观看一级欧美片| 亚洲欧美怡红院| 精品1区2区在线观看| 欧美在线不卡视频| 国产91精品露脸国语对白| 亚洲大片一区二区三区| 国产精品色婷婷久久58| 日韩手机在线导航| 色噜噜久久综合| 成人免费视频网站在线观看| 蜜臀av性久久久久蜜臀av麻豆| 亚洲精品国产a久久久久久|