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

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

?? ecnrsigner.java

?? 內容:基于jdk1.4的加密算法的具體實現
?? JAVA
字號:
package org.bouncycastle.crypto.signers;import java.math.BigInteger;import java.security.SecureRandom;import org.bouncycastle.crypto.AsymmetricCipherKeyPair;import org.bouncycastle.crypto.CipherParameters;import org.bouncycastle.crypto.DSA;import org.bouncycastle.crypto.DataLengthException;import org.bouncycastle.crypto.generators.ECKeyPairGenerator;import org.bouncycastle.crypto.params.ECKeyGenerationParameters;import org.bouncycastle.crypto.params.ECKeyParameters;import org.bouncycastle.crypto.params.ECPrivateKeyParameters;import org.bouncycastle.crypto.params.ECPublicKeyParameters;import org.bouncycastle.crypto.params.ParametersWithRandom;import org.bouncycastle.math.ec.ECConstants;import org.bouncycastle.math.ec.ECPoint;/** * EC-NR as described in IEEE 1363-2000 */public class ECNRSigner    implements DSA{    private boolean             forSigning;    private ECKeyParameters     key;    private SecureRandom        random;    public void init(        boolean          forSigning,         CipherParameters param)     {        this.forSigning = forSigning;                if (forSigning)        {            if (param instanceof ParametersWithRandom)            {                ParametersWithRandom    rParam = (ParametersWithRandom)param;                this.random = rParam.getRandom();                this.key = (ECPrivateKeyParameters)rParam.getParameters();            }            else            {                this.random = new SecureRandom();                this.key = (ECPrivateKeyParameters)param;            }        }        else        {            this.key = (ECPublicKeyParameters)param;        }    }    // Section 7.2.5 ECSP-NR, pg 34    /**     * generate a signature for the given message using the key we were     * initialised with.  Generally, the order of the curve should be at      * least as long as the hash of the message of interest, and with      * ECNR it *must* be at least as long.       *     * @param digest  the digest to be signed.     * @exception DataLengthException if the digest is longer than the key allows     */    public BigInteger[] generateSignature(        byte[] digest)    {        if (! this.forSigning)         {            // not properly initilaized... deal with it        }                BigInteger n = ((ECPrivateKeyParameters)this.key).getParameters().getN();        int nBitLength = n.bitLength();                BigInteger e = new BigInteger(1, digest);        int eBitLength = e.bitLength();                ECPrivateKeyParameters  privKey = (ECPrivateKeyParameters)key;                       if (eBitLength > nBitLength)         {            throw new DataLengthException("input too large for ECNR key.");        }        BigInteger r = null;        BigInteger s = null;        AsymmetricCipherKeyPair tempPair;        do // generate r        {            // generate another, but very temporary, key pair using             // the same EC parameters            ECKeyPairGenerator keyGen = new ECKeyPairGenerator();                        keyGen.init(new ECKeyGenerationParameters(privKey.getParameters(), this.random));                        tempPair = keyGen.generateKeyPair();            //    BigInteger Vx = tempPair.getPublic().getW().getAffineX();            ECPublicKeyParameters V = (ECPublicKeyParameters)tempPair.getPublic();        // get temp's public key            BigInteger Vx = V.getQ().getX().toBigInteger();        // get the point's x coordinate                        r = Vx.add(e).mod(n);        }        while (r.equals(ECConstants.ZERO));        // generate s        BigInteger x = privKey.getD();                // private key value        BigInteger u = ((ECPrivateKeyParameters)tempPair.getPrivate()).getD();    // temp's private key value        s = u.subtract(r.multiply(x)).mod(n);        BigInteger[]  res = new BigInteger[2];        res[0] = r;        res[1] = s;        return res;    }    // Section 7.2.6 ECVP-NR, pg 35    /**     * return true if the value r and s represent a signature for the      * message passed in. Generally, the order of the curve should be at      * least as long as the hash of the message of interest, and with      * ECNR, it *must* be at least as long.  But just in case the signer     * applied mod(n) to the longer digest, this implementation will     * apply mod(n) during verification.     *     * @param digest  the digest to be verified.     * @param r       the r value of the signature.     * @param s       the s value of the signature.     * @exception DataLengthException if the digest is longer than the key allows     */    public boolean verifySignature(        byte[]      digest,        BigInteger  r,        BigInteger  s)    {        if (this.forSigning)         {            // not properly initilaized... deal with it        }                ECPublicKeyParameters pubKey = (ECPublicKeyParameters)key;        BigInteger n = pubKey.getParameters().getN();        int nBitLength = n.bitLength();                BigInteger e = new BigInteger(1, digest);        int eBitLength = e.bitLength();                if (eBitLength > nBitLength)         {            throw new DataLengthException("input too large for ECNR key.");        }                // r in the range [1,n-1]        if (r.compareTo(ECConstants.ONE) < 0 || r.compareTo(n) >= 0)         {            return false;        }        // s in the range [0,n-1]           NB: ECNR spec says 0        if (s.compareTo(ECConstants.ZERO) < 0 || s.compareTo(n) >= 0)         {            return false;        }        // compute P = sG + rW        ECPoint G = pubKey.getParameters().getG();        ECPoint W = pubKey.getQ();        // calculate P using Bouncy math        ECPoint P = G.multiply(s).add(W.multiply(r));                BigInteger x = P.getX().toBigInteger();        BigInteger t = r.subtract(x).mod(n);                return t.equals(e);    }}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91啦中文在线观看| 国产麻豆日韩欧美久久| 国产午夜精品理论片a级大结局| 欧美精品久久久久久久多人混战| 色综合天天综合给合国产| 成人av在线资源网| 99久久久久久| 日本韩国欧美在线| 欧美午夜一区二区三区| 中文字幕av一区二区三区| 久久久精品国产99久久精品芒果| 欧美日韩高清一区二区不卡| 欧美不卡一区二区三区四区| 国产精品美女视频| 奇米影视在线99精品| 91丨porny丨最新| 欧美经典一区二区三区| 国产精品一区二区久久精品爱涩 | 欧美亚洲国产一卡| 国产.欧美.日韩| 99免费精品在线观看| 91极品视觉盛宴| 3d动漫精品啪啪1区2区免费| 国产 欧美在线| 日韩精品一区二区三区在线 | 欧美亚男人的天堂| 91精品国产美女浴室洗澡无遮挡| 日韩欧美激情在线| 欧美国产精品一区| 丝袜美腿亚洲色图| 国产成人免费在线视频| 在线免费观看日本一区| 日韩免费视频一区| 亚洲色图色小说| 久久精品国内一区二区三区| 成人激情视频网站| 欧美高清视频不卡网| 国产喂奶挤奶一区二区三区| 日韩美女视频19| 精品一区二区三区在线播放视频| 久久99深爱久久99精品| 日本在线不卡视频| 日韩高清一区在线| 国产精品一区二区你懂的| 91麻豆视频网站| 日韩欧美成人一区二区| 亚洲麻豆国产自偷在线| 国产一区免费电影| 欧美日韩综合色| 国产精品免费看片| 美女精品一区二区| 欧美性xxxxxxxx| 亚洲国产精品精华液ab| 久久国产三级精品| 欧美老人xxxx18| 一区二区三区国产| jiyouzz国产精品久久| 日韩三级在线免费观看| 亚洲最色的网站| 色呦呦网站一区| 中文字幕欧美一| 成人激情小说乱人伦| 久久综合色鬼综合色| 日韩成人一区二区| 在线观看一区日韩| 亚洲柠檬福利资源导航| 成人av免费网站| 国产欧美一区二区在线观看| 麻豆高清免费国产一区| 日韩情涩欧美日韩视频| 日韩精品三区四区| 欧美夫妻性生活| 日本在线不卡视频| 日韩视频一区二区三区在线播放| 天天影视涩香欲综合网| 欧美美女一区二区三区| 五月天亚洲婷婷| 欧美福利电影网| 老司机一区二区| 久久日韩粉嫩一区二区三区| 久久99久国产精品黄毛片色诱| 91精品国产丝袜白色高跟鞋| 久久aⅴ国产欧美74aaa| 亚洲精品一区二区三区四区高清| 久久99精品国产91久久来源| 91精品国产aⅴ一区二区| 全部av―极品视觉盛宴亚洲| 日韩一区二区精品葵司在线| 精品一区二区三区久久久| 精品国产一区二区国模嫣然| 国产麻豆成人传媒免费观看| 国产欧美日韩精品在线| 一本色道久久综合亚洲91| 亚洲一区二区三区小说| 日韩欧美精品在线| 成人一区二区三区视频在线观看| 亚洲视频免费观看| 欧美日韩在线免费视频| 国产91对白在线观看九色| 在线观看视频一区二区| 91麻豆精品国产91久久久久久久久 | 欧美乱妇20p| 理论片日本一区| 国产精品国产三级国产| 日本精品裸体写真集在线观看| 亚洲www啪成人一区二区麻豆| 日韩精品专区在线影院重磅| 成人av中文字幕| 日韩成人一级片| 国产精品久久久爽爽爽麻豆色哟哟| 91欧美一区二区| 久久精品国产澳门| 肉色丝袜一区二区| 久久亚洲捆绑美女| 粉嫩一区二区三区在线看| 丁香天五香天堂综合| 国产精品三级在线观看| 欧美日韩国产综合一区二区| 精品亚洲成a人| 亚洲免费在线播放| 久久综合色播五月| 色婷婷综合久久久| 国产乱国产乱300精品| 亚洲线精品一区二区三区| 国产清纯在线一区二区www| 欧美另类videos死尸| 91麻豆国产香蕉久久精品| 国产在线日韩欧美| 亚洲制服丝袜在线| 中文字幕一区二区三区不卡| 日韩一二三四区| 欧美日韩国产免费| av电影天堂一区二区在线观看| 久久99热这里只有精品| 亚洲国产成人tv| 亚洲精品自拍动漫在线| 欧美激情一二三区| 久久久久久久av麻豆果冻| 日韩三级免费观看| 欧美日韩国产一级片| 色婷婷激情一区二区三区| 成人avav影音| 成人免费视频一区二区| 国产成人综合自拍| 国产精品香蕉一区二区三区| 久久99精品久久久久久动态图| 日韩精品色哟哟| 视频一区欧美日韩| 日本中文字幕一区二区有限公司| 亚洲一区免费在线观看| 亚洲午夜日本在线观看| 尤物视频一区二区| 亚洲成人免费在线观看| 亚洲一区二区三区爽爽爽爽爽| 亚洲精品乱码久久久久久黑人| 日韩美女精品在线| 一区二区在线电影| 亚欧色一区w666天堂| 亚洲成a人v欧美综合天堂| 亚洲成人av在线电影| 日本成人中文字幕在线视频| 日韩不卡手机在线v区| 麻豆久久久久久| 国产自产v一区二区三区c| 国产成人在线视频免费播放| 成人污视频在线观看| 色婷婷综合五月| 欧美精品黑人性xxxx| 精品成人佐山爱一区二区| 久久综合狠狠综合久久综合88| 精品一区二区三区在线视频| 亚洲一区二区免费视频| 亚洲一区二区三区国产| 无码av中文一区二区三区桃花岛| 亚洲最新视频在线观看| 亚洲免费在线视频| 亚洲mv在线观看| 免费观看日韩av| 成人免费视频caoporn| 色狠狠综合天天综合综合| 欧美日韩中文字幕一区二区| 日韩一区二区不卡| 中文字幕免费在线观看视频一区| 亚洲欧洲精品一区二区精品久久久| 亚洲一区在线免费观看| 久久99九九99精品| 91免费看视频| 日韩欧美另类在线| 亚洲欧美自拍偷拍| 麻豆一区二区99久久久久| 成人永久看片免费视频天堂| 欧美三级欧美一级| 久久精品一二三| 91视视频在线直接观看在线看网页在线看| 欧美日韩精品免费| 欧美在线影院一区二区| 日韩视频一区二区| 亚洲免费观看高清完整版在线观看 | 精品一区二区三区视频在线观看| 大胆欧美人体老妇|