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

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

?? x509cert.java

?? 一個java開發的非常全面的關于證書發放
?? JAVA
?? 第 1 頁 / 共 2 頁
字號:
/*
  Name:         X509Cert.java
  Licensing:    LGPL

  API:          Sun (http://java.sun.com) JCE 1.2.2 API (cleanroom implementation by Bouncy Castle)
  Provider:     Bouncy Castle (http://www.bouncycastle.org)

  Disclaimer:

  COVERED CODE IS PROVIDED UNDER THIS LICENSE ON AN "AS IS" BASIS, WITHOUT WARRANTY OF ANY KIND,
  EITHER EXPRESSED OR IMPLIED, INCLUDING, WITHOUT LIMITATION, WARRANTIES THAT THE COVERED CODE
  IS FREE OF DEFECTS, MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE OR NON-INFRINGING. THE ENTIRE
  RISK AS TO THE QUALITY AND PERFORMANCE OF THE COVERED CODE IS WITH YOU. SHOULD ANY COVERED CODE
  PROVE DEFECTIVE IN ANY RESPECT, YOU (NOT THE INITIAL DEVELOPER OR ANY OTHER CONTRIBUTOR)
  ASSUME THE COST OF ANY NECESSARY SERVICING, REPAIR OR CORRECTION. THIS DISCLAIMER OF WARRANTY
  CONSTITUTES AN ESSENTIAL PART OF THIS LICENSE. NO USE OF ANY COVERED CODE IS AUTHORIZED
  HEREUNDER EXCEPT UNDER THIS DISCLAIMER.

  (C) Copyright 2003 Gert Van Ham
*/

package net.sourceforge.jcetaglib.lib;

import net.sourceforge.jcetaglib.exceptions.CryptoException;
import net.sourceforge.jcetaglib.tools.FileTools;
import net.sourceforge.jcetaglib.tools.KeyTools;
import org.bouncycastle.asn1.*;
import org.bouncycastle.asn1.misc.MiscObjectIdentifiers;
import org.bouncycastle.asn1.misc.NetscapeCertType;
import org.bouncycastle.asn1.x509.*;
import org.bouncycastle.jce.PKCS10CertificationRequest;
import org.bouncycastle.jce.X509Principal;
import org.bouncycastle.jce.X509V2CRLGenerator;
import org.bouncycastle.jce.X509V3CertificateGenerator;
import org.bouncycastle.jce.netscape.NetscapeCertRequest;
import org.bouncycastle.jce.provider.BouncyCastleProvider;
import org.bouncycastle.util.encoders.Base64;

import java.io.ByteArrayInputStream;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.math.BigInteger;
import java.security.*;
import java.security.cert.Certificate;
import java.security.cert.*;
import java.util.Date;


/**
 * Create/Read/Manipulate X.509 certificates
 *
 * @author Gert Van Ham
 * @author hamgert@users.sourceforge.net
 * @author http://jcetaglib.sourceforge.net
 * @version $Id: X509Cert.java,v 1.3 2004/04/15 07:28:25 hamgert Exp $
 */
public class X509Cert {

    private static final String NS_CA = "ca";
    private static final String NS_SERVER = "server";
    private static final String NS_CLIENT = "client";
    private static final String NS_ALL = "all";

    /**
     * Generate key pair (public & private key)
     *
     * @param keypairalgorithm keypair algorithm (e.g. "RSA")
     * @param keylength key length (e.g. 1024)
     * @param seed seed for SecureRandom (optional)
     * @return generated keypair
     * @throws NoSuchAlgorithmException unknown algorithm
     * @throws NoSuchProviderException unknown provider
     * @throws CryptoException cryptographic errors
     */
    public static KeyPair generateKeyPair(String keypairalgorithm
                                          , int keylength
                                          , byte[] seed) throws NoSuchAlgorithmException, NoSuchProviderException, CryptoException {

        Security.addProvider(new BouncyCastleProvider());

        KeyPairGenerator g = KeyPairGenerator.getInstance(keypairalgorithm, "BC");

        SecureRandom sr = Seed.getSecureRandom(seed);

        g.initialize(keylength, sr);
        return g.generateKeyPair();
    }

    /**
     * Creates a self-signed certificate
     *
     * @param privatekey the private key
     * @param publickey the public key
     * @param signaturealgorithm signature algorithm (e.g. "MD5WithRSAEncryption")
     * @param validity defines how long this certificate is valid (in days)
     * @param subjectdn the subject's distinguised name
     * @param isca true if this certificate can be used for a Certificate Authority, false if not
     * @param netscapeextensions adds netscape certificate extensions ("ca", "server", "client", "all")
     * @return X.509 certificate
     * @throws CertificateException certificate errors
     */
    public static X509Certificate selfsign(PrivateKey privatekey
                                           , PublicKey publickey
                                           , String signaturealgorithm
                                           , long validity
                                           , String subjectdn
                                           , boolean isca
                                           , String netscapeextensions) throws CertificateException {
        try {
            // Add Bouncy Castle provider
            Security.addProvider(new BouncyCastleProvider());

            Date firstDate = new Date();
            // Set back startdate ten minutes to avoid some problems with wrongly set clocks.
            firstDate.setTime(firstDate.getTime() - 10 * 60 * 1000);
            Date lastDate = new Date();
            // validity in days = validity*24*60*60*1000 milliseconds
            lastDate.setTime(lastDate.getTime() + (validity * (24 * 60 * 60 * 1000)));

            X509V3CertificateGenerator v3CertGen = new X509V3CertificateGenerator();

            // Serialnumber is random bits, where random generator is initialized with Date.getTime()
            byte[] serno = new byte[8];
            SecureRandom random = SecureRandom.getInstance("SHA1PRNG");
            random.setSeed((new Date().getTime()));
            random.nextBytes(serno);

            BigInteger sn = new java.math.BigInteger(serno).abs();

            // Add certificate basic elements
            v3CertGen.setSerialNumber(sn);
            v3CertGen.setIssuerDN(new X509Principal(subjectdn));
            v3CertGen.setNotBefore(firstDate);
            v3CertGen.setNotAfter(lastDate);
            v3CertGen.setSubjectDN(new X509Principal(subjectdn));
            v3CertGen.setPublicKey(publickey);
            v3CertGen.setSignatureAlgorithm(signaturealgorithm);

            // Add certificate extensions
            v3CertGen.addExtension(X509Extensions.SubjectKeyIdentifier,
                    false,
                    CertTools.createSubjectKeyId(publickey));

            v3CertGen.addExtension(X509Extensions.BasicConstraints,
                    false,
                    new BasicConstraints(isca));

            // Add Netscape extensions
            if (NS_CA.equalsIgnoreCase(netscapeextensions)) {
                v3CertGen.addExtension(MiscObjectIdentifiers.netscapeCertType,
                        false,
                        new NetscapeCertType(NetscapeCertType.sslCA | NetscapeCertType.smimeCA | NetscapeCertType.objectSigningCA));
            } else if (NS_SERVER.equalsIgnoreCase(netscapeextensions)) {
                v3CertGen.addExtension(MiscObjectIdentifiers.netscapeCertType,
                        false,
                        new NetscapeCertType(NetscapeCertType.sslServer));
            } else if (NS_CLIENT.equalsIgnoreCase(netscapeextensions)) {
                v3CertGen.addExtension(MiscObjectIdentifiers.netscapeCertType,
                        false,
                        new NetscapeCertType(NetscapeCertType.sslClient | NetscapeCertType.smime | NetscapeCertType.objectSigning));
            } else if (NS_ALL.equalsIgnoreCase(netscapeextensions)) {
                v3CertGen.addExtension(MiscObjectIdentifiers.netscapeCertType,
                        false,
                        new NetscapeCertType(NetscapeCertType.sslClient | NetscapeCertType.sslServer | NetscapeCertType.smime | NetscapeCertType.objectSigning | NetscapeCertType.sslCA | NetscapeCertType.smimeCA | NetscapeCertType.objectSigningCA));
            }

            // generate the certificate
            X509Certificate cert = v3CertGen.generateX509Certificate(privatekey);

            // check if certificate is valid
            cert.checkValidity(new Date());
            // verify certificate with public key
            cert.verify(publickey);

            return cert;
        } catch (Exception e) {
            e.printStackTrace();
            throw new CertificateException(e.getMessage());
        }
    }

    /**
     * Create a signed certificate
     *
     * @param publickey the public key
     * @param issuerprivatekey the private key of the CA (issuer)
     * @param issuercertificate the certificate of the CA (issuer)
     * @param signaturealgorithm signature algorithm (e.g. "MD5WithRSAEncryption")
     * @param validity defines how long this certificate is valid (in days)
     * @param subjectdn the subject's distinguised name
     * @param isca true if this certificate can be used for a Certificate Authority, false if not
     * @param crldisturi the CRL distribution URI
     * @param netscapeextensions adds netscape certificate extensions ("ca", "server", "client", "all")
     * @return X.509 certificate
     * @throws CertificateException
     */
    public static X509Certificate sign(PublicKey publickey
                                       , PrivateKey issuerprivatekey
                                       , X509Certificate issuercertificate
                                       , String signaturealgorithm
                                       , long validity
                                       , String subjectdn
                                       , boolean isca
                                       , String crldisturi
                                       , String netscapeextensions) throws CertificateException {
        try {
            // Add Bouncy Castle provider
            Security.addProvider(new BouncyCastleProvider());

            Date firstDate = new Date();
            // Set back startdate ten minutes to avoid some problems with wrongly set clocks.
            firstDate.setTime(firstDate.getTime() - 10 * 60 * 1000);
            Date lastDate = new Date();
            // validity in days = validity*24*60*60*1000 milliseconds
            lastDate.setTime(lastDate.getTime() + (validity * (24 * 60 * 60 * 1000)));

            X509V3CertificateGenerator v3CertGen = new X509V3CertificateGenerator();

            // Serialnumber is random bits, where random generator is initialized with Date.getTime()
            byte[] serno = new byte[8];
            SecureRandom random = SecureRandom.getInstance("SHA1PRNG");
            random.setSeed((new Date().getTime()));
            random.nextBytes(serno);

            BigInteger sn = new java.math.BigInteger(serno).abs();
            String issuerDN = issuercertificate.getSubjectDN().toString();

            // Add certificate basic elements
            v3CertGen.setSerialNumber(sn);
            v3CertGen.setIssuerDN(new X509Principal(issuerDN));
            v3CertGen.setNotBefore(firstDate);
            v3CertGen.setNotAfter(lastDate);
            v3CertGen.setSubjectDN(new X509Principal(subjectdn));
            v3CertGen.setPublicKey(publickey);
            v3CertGen.setSignatureAlgorithm(signaturealgorithm);

            // Add certificate extensions
            v3CertGen.addExtension(X509Extensions.SubjectKeyIdentifier,
                    false,
                    CertTools.createSubjectKeyId(publickey));

            v3CertGen.addExtension(X509Extensions.AuthorityKeyIdentifier,
                    false,
                    CertTools.createAuthorityKeyId(issuercertificate.getPublicKey()));

            v3CertGen.addExtension(X509Extensions.BasicConstraints,
                    false,
                    new BasicConstraints(isca));

            // Add CRL distribution URI
            if (crldisturi != null && !crldisturi.equalsIgnoreCase("")) {
                GeneralName gn = new GeneralName(new DERIA5String(crldisturi), 6);
                DERSequence seq = new DERSequence(gn);
                GeneralNames gns = new GeneralNames(seq);
                DistributionPointName dpn = new DistributionPointName(0, gns);
                DistributionPoint distp = new DistributionPoint(dpn, null, null);
                v3CertGen.addExtension(X509Extensions.CRLDistributionPoints.getId(), false, distp);
            }

            // Add Netscape extensions
            if (NS_CA.equalsIgnoreCase(netscapeextensions)) {
                v3CertGen.addExtension(MiscObjectIdentifiers.netscapeCertType,
                        false,
                        new NetscapeCertType(NetscapeCertType.sslCA | NetscapeCertType.smimeCA | NetscapeCertType.objectSigningCA));
            } else if (NS_SERVER.equalsIgnoreCase(netscapeextensions)) {
                v3CertGen.addExtension(MiscObjectIdentifiers.netscapeCertType,
                        false,
                        new NetscapeCertType(NetscapeCertType.sslServer));
            } else if (NS_CLIENT.equalsIgnoreCase(netscapeextensions)) {
                v3CertGen.addExtension(MiscObjectIdentifiers.netscapeCertType,
                        false,
                        new NetscapeCertType(NetscapeCertType.sslClient | NetscapeCertType.smime | NetscapeCertType.objectSigning));
            } else if (NS_ALL.equalsIgnoreCase(netscapeextensions)) {
                v3CertGen.addExtension(MiscObjectIdentifiers.netscapeCertType,
                        false,
                        new NetscapeCertType(NetscapeCertType.sslClient | NetscapeCertType.sslServer | NetscapeCertType.smime | NetscapeCertType.objectSigning | NetscapeCertType.sslCA | NetscapeCertType.smimeCA | NetscapeCertType.objectSigningCA));
            }

            // generate the certificate
            X509Certificate cert = v3CertGen.generateX509Certificate(issuerprivatekey);

            // check if certificate is valid
            cert.checkValidity(new Date());
            // verify certificate with public key
            cert.verify(issuercertificate.getPublicKey());

            return cert;
        } catch (Exception e) {
            e.printStackTrace();
            throw new CertificateException(e.getMessage());
        }
    }

    /**
     * Create a CRL (Certification Revokation List)
     *
     * @param certserialnumbers array of certificate serial numbers that are revoked
     * @param crlnumber the CRL number
     * @param crlperiod how long this CRL is valid (in hours)
     * @param signaturealgorithm signature algorithm (e.g. "MD5WithRSAEncryption")
     * @param cacert the CA's certificate
     * @param caprivkey the CA's private key (to sign the CRL)
     * @return CRL
     * @throws CertificateException
     */
    public static X509CRL CreateCRL(BigInteger[] certserialnumbers
                                    , int crlnumber
                                    , long crlperiod
                                    , String signaturealgorithm
                                    , X509Certificate cacert
                                    , PrivateKey caprivkey) throws CertificateException {
        X509CRL crl = null;
        try {
            // Add Bouncy Castle provider
            Security.addProvider(new BouncyCastleProvider());

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品国产伦理网| 亚洲综合丝袜美腿| 中文字幕视频一区| 亚洲成a人v欧美综合天堂下载| 久久97超碰色| 日本韩国欧美三级| 日本一区二区三级电影在线观看 | 欧美一区二区三区日韩| 国产精品水嫩水嫩| 美腿丝袜亚洲一区| 精品视频一区三区九区| 国产精品入口麻豆九色| 免费在线看成人av| 欧美性猛交xxxxxx富婆| 国产精品久99| 懂色av一区二区三区蜜臀| 精品人伦一区二区色婷婷| 丝袜美腿高跟呻吟高潮一区| 99久久夜色精品国产网站| 欧美精品一区二区三区在线播放| 亚洲成人一区在线| 一本久久综合亚洲鲁鲁五月天 | 国产在线乱码一区二区三区| 欧美在线观看一二区| 亚洲老妇xxxxxx| 91在线码无精品| 亚洲欧美日韩综合aⅴ视频| 成人av网在线| 亚洲四区在线观看| 色哟哟欧美精品| 一区二区三区日韩欧美精品| 97久久久精品综合88久久| 国产精品久久久久婷婷二区次| 国产乱子伦视频一区二区三区| 欧美日韩国产高清一区二区| 亚洲成av人片在线观看| 欧美日韩亚洲综合一区二区三区| 亚洲九九爱视频| 欧美专区日韩专区| 日韩成人免费在线| 91精品综合久久久久久| 蜜臀91精品一区二区三区| 日韩欧美视频一区| 国产精品自在欧美一区| 国产精品美女久久久久久久网站| 成人高清在线视频| 亚洲综合清纯丝袜自拍| 3751色影院一区二区三区| 男女男精品网站| 国产婷婷精品av在线| www.亚洲免费av| 亚洲一线二线三线视频| 69堂精品视频| 国产在线视视频有精品| 国产精品护士白丝一区av| 91黄色免费看| 美女视频黄免费的久久| 久久精品夜色噜噜亚洲a∨| 欧美高清精品3d| 日韩和欧美一区二区三区| 91精品国产综合久久久久久久久久| 日本在线观看不卡视频| 国产色一区二区| 欧美午夜寂寞影院| 美国毛片一区二区三区| 亚洲欧洲一区二区在线播放| 欧美三级日本三级少妇99| 国产精品乡下勾搭老头1| 亚洲另类在线一区| 亚洲精品在线网站| 在线亚洲免费视频| 国产一区视频网站| 中文字幕综合网| 精品国产乱码久久久久久久 | 亚洲天堂2014| 欧美一级二级在线观看| 国产成人亚洲精品青草天美| 亚洲国产视频在线| 亚洲国产精品激情在线观看| 88在线观看91蜜桃国自产| 粉嫩av亚洲一区二区图片| 日日夜夜精品视频免费| 国产精品家庭影院| 26uuu色噜噜精品一区| 欧美亚洲综合久久| 成人毛片老司机大片| 久久精品国产精品亚洲红杏| 亚洲欧洲精品成人久久奇米网| 日韩女优视频免费观看| 精品视频一区二区不卡| 成人动漫视频在线| 久久成人免费网| 午夜电影一区二区| 亚洲三级久久久| 欧美经典一区二区| 久久亚洲影视婷婷| 日韩情涩欧美日韩视频| 精品视频在线免费观看| 欧美专区日韩专区| jizzjizzjizz欧美| 国产高清成人在线| 国产精品中文有码| 久草在线在线精品观看| 日本成人在线网站| 天天综合色天天| 亚洲综合在线第一页| 亚洲三级在线观看| 亚洲欧美日韩在线| 亚洲欧美视频在线观看| 亚洲男人天堂av网| 亚洲欧洲精品一区二区三区不卡 | 欧美一区二区三区在线视频| 欧美色欧美亚洲另类二区| 91视视频在线观看入口直接观看www| 激情图区综合网| 久99久精品视频免费观看| 麻豆成人在线观看| 国产中文一区二区三区| 国产一区二区三区四区五区美女| 精品一区二区三区免费毛片爱| 蜜桃91丨九色丨蝌蚪91桃色| 五月天激情综合网| 日韩和欧美一区二区| 日本在线观看不卡视频| 老司机免费视频一区二区三区| 久久99国产精品久久| 国产精品一级在线| 波多野结衣在线一区| 欧美变态tickle挠乳网站| 8v天堂国产在线一区二区| 日韩一区二区在线观看视频播放| 欧美一区二区网站| 久久麻豆一区二区| 中文字幕欧美三区| 国产精品国产三级国产三级人妇| 国产精品网站在线| 亚洲一区二区三区免费视频| 日韩成人精品视频| 国产成人在线观看| 色狠狠一区二区三区香蕉| 91精品国产综合久久小美女| 久久亚区不卡日本| 《视频一区视频二区| 亚洲gay无套男同| 国产精品一区在线观看乱码| 99视频精品免费视频| 欧美色欧美亚洲另类二区| 欧美精品一区二区久久婷婷| 国产精品欧美一区二区三区| 亚洲国产视频直播| 国产精品自拍在线| 欧美日韩高清影院| 日本一区二区三区在线观看| 亚洲国产精品人人做人人爽| 国产在线不卡一区| 欧美性做爰猛烈叫床潮| 久久综合久色欧美综合狠狠| 一区二区三区色| 国产麻豆精品在线观看| 欧美日韩黄色一区二区| 国产亚洲人成网站| 亚州成人在线电影| caoporn国产精品| 日韩精品一区二区三区中文不卡 | 亚洲一区二区三区在线播放| 国产一区二区三区四| 精品视频色一区| 国产精品国产三级国产| 美国十次综合导航| 欧美亚洲禁片免费| 亚洲色图丝袜美腿| 极品少妇xxxx偷拍精品少妇| 欧美日韩亚洲综合在线| 亚洲视频狠狠干| 成人免费福利片| 久久午夜羞羞影院免费观看| 五月综合激情婷婷六月色窝| 99久久免费视频.com| 国产视频亚洲色图| 国产综合色精品一区二区三区| 欧美日产国产精品| 亚洲免费电影在线| www.亚洲激情.com| 中文字幕不卡在线观看| 精品一区二区三区不卡| 欧美高清性hdvideosex| 亚洲午夜国产一区99re久久| 91一区一区三区| 一色桃子久久精品亚洲| 国产精品亚洲а∨天堂免在线| 精品国产一区二区亚洲人成毛片| 石原莉奈在线亚洲二区| 欧美高清性hdvideosex| 日韩中文字幕一区二区三区| 欧美日韩aaa| 免费高清不卡av| 日韩欧美亚洲国产另类| 麻豆精品新av中文字幕| 精品久久人人做人人爰| 久久激情五月激情|