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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? verifycertificate.java

?? 一個(gè)java開發(fā)的非常全面的關(guān)于證書發(fā)放
?? JAVA
字號(hào):
/*
  Name:         VerifyCertificate.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.
*/

package net.sourceforge.jcetaglib.taglib.x509;

import net.sourceforge.jcetaglib.lib.CertTools;
import net.sourceforge.jcetaglib.lib.Clean;
import net.sourceforge.jcetaglib.lib.X509Cert;
import net.sourceforge.jcetaglib.tools.FileTools;
import org.bouncycastle.jce.provider.BouncyCastleProvider;

import javax.servlet.jsp.JspException;
import javax.servlet.jsp.PageContext;
import javax.servlet.jsp.tagext.TagSupport;
import java.io.ByteArrayInputStream;
import java.io.InputStream;
import java.security.Security;
import java.security.cert.X509CRL;
import java.security.cert.X509Certificate;

/**
 * JSP tag for verifying X.509 certificates
 *
 * @jsp.tag
 * name="verifycertificate"
 * display-name="VerifyCertificate"
 * body-content="empty"
 * example="<jce:verifycertificate

 *		scope=\"page\"

 *		verifyinfo=\"stat\"

 *		crlfile=\"C:/keystores/crl.der\"

 *		storefile=\"C:/keystores/bob.p12\"

 *		storeentry=\"user\"

 *		storepassword=\"<%= new StringBuffer(\"password\") %>\"

 *		castorefile=\"C:/keystores/ca.p12\"

 *		castoreentry=\"ca\"

 *		castorepassword=\"<%= new StringBuffer(\"password\") %>\"/>"
 *
 * description="JSP tag for verifying X.509 certificates"
 *
 * @author Gert Van Ham
 * @author hamgert@users.sourceforge.net
 * @author http://jcetaglib.sourceforge.net
 * @version $Id: VerifyCertificate.java,v 1.5 2004/04/15 07:28:36 hamgert Exp $
 */

public class VerifyCertificate extends TagSupport {
    private static final String PAGE = "page";
    private static final String REQUEST = "request";
    private static final String SESSION = "session";
    private static final String APPLICATION = "application";

    private String crlfile;

    // return info
    private int scope = PageContext.PAGE_SCOPE;
    private String verifyinfo;

    /* Attributes for X.509 keystore */

    // P12 keystore...
    private String storefile;            // tag attribute
    private String storeentry;           // tag attribute
    private StringBuffer storepassword;  // tag attribute

    // ... OR PEM string
    private String pemstring;            // tag attribute

    // ... OR PEM file
    private String pemfile;              // tag attribute

    /* Attributes for X.509 CA keystore */

    // P12 keystore...
    private String castorefile;            // tag attribute
    private String castoreentry;           // tag attribute
    private StringBuffer castorepassword;  // tag attribute

    // ... OR PEM string
    private String capemstring;            // tag attribute

    // ... OR PEM file
    private String capemfile;              // tag attribute

    public static int getScope(String scope) {
        int ret = PageContext.PAGE_SCOPE; // default

        if (REQUEST.equalsIgnoreCase(scope))
            ret = PageContext.REQUEST_SCOPE;
        else if (SESSION.equalsIgnoreCase(scope))
            ret = PageContext.SESSION_SCOPE;
        else if (APPLICATION.equalsIgnoreCase(scope))
            ret = PageContext.APPLICATION_SCOPE;
        else if (PAGE.equalsIgnoreCase(scope))
            ret = PageContext.PAGE_SCOPE;

        return ret;
    } //getScope()

    public int doEndTag() throws JspException {
        // Add Bouncy Castle provider
        Security.addProvider(new BouncyCastleProvider());

        X509Certificate cert = null;
        X509Certificate cacert = null;
        X509CRL x509crl = null;

        InputStream pemstream = null;

        try {
            // Retrieve the certificate from one of the three possible keystores
            if (storefile == null || storefile == "") {
                if (pemfile == null || pemfile == "") {
                    // use PEM string
                    pemstream = new ByteArrayInputStream(pemstring.getBytes());
                    cert = CertTools.getCertfromPEM(pemstream);
                } else {
                    // use PEM store
                    cert = CertTools.getCertfromPEM(pemfile);
                }
            } else {
                // use PKCS #12 keystore
                cert = X509Cert.getCertificateFromP12(storefile, storeentry, storepassword);
            }

            // Retrieve the signing certificate from one of the three possible keystores
            if (castorefile == null || castorefile == "") {
                if (capemfile == null || capemfile == "") {
                    // use PEM string
                    pemstream = new ByteArrayInputStream(capemstring.getBytes());
                    cacert = CertTools.getCertfromPEM(pemstream);
                } else {
                    // use PEM store
                    cacert = CertTools.getCertfromPEM(capemfile);
                }
            } else {
                // use PKCS #12 keystore
                cacert = X509Cert.getCACertificateFromP12(castorefile, castoreentry, castorepassword);
            }

            // get CRL
            byte[] crl = FileTools.readFiletoBuffer(crlfile);
            x509crl = CertTools.getCRLfromByteArray(crl);

            pageContext.setAttribute(verifyinfo, X509Cert.verifyCertificate(cert, cacert, x509crl), scope);
        } catch (Exception e) {
            throw new JspException("JCE Exception: Could not verify certificate: " + e.toString(), e);
        }

        return EVAL_PAGE;
    } //doEndTag()

    public void release() {
        // Cleanup all sensitive information
        Clean.blank(storepassword);
        Clean.blank(castorepassword);

        super.release();
    } //release()

    /**
     * @jsp.attribute
     *     description="Scope of the return variables. Can be 'page', 'session', 'request' or 'application'. Default is 'page'"
     *     type="java.lang.String"
     *     required="false"
     *     rtexprvalue="false"
     */
    public void setScope(String scope) {
        this.scope = getScope(scope);
    }

    /**
     * @jsp.attribute
     *     description="The CRL filename"
     *     type="java.lang.String"
     *     required="false"
     *     rtexprvalue="true"
     */
    public void setCrlfile(String crlfile) {
        this.crlfile = crlfile;
    }

    /**
     * @jsp.attribute
     *     description="The PKCS#12 (P12) keystore where the certificate is stored"
     *     type="java.lang.String"
     *     required="false"
     *     rtexprvalue="true"
     */
    public void setStorefile(String storefile) {
        this.storefile = storefile;
    }

    /**
     * @jsp.attribute
     *     description="The PKCS#12 (P12) keystore entry name for this certificate"
     *     type="java.lang.String"
     *     required="false"
     *     rtexprvalue="true"
     */
    public void setStoreentry(String storeentry) {
        this.storeentry = storeentry;
    }

    /**
     * @jsp.attribute
     *     description="The PKCS#12 (P12) keystore password"
     *     type="java.lang.StringBuffer"
     *     required="false"
     *     rtexprvalue="true"
     */
    public void setStorepassword(StringBuffer storepassword) {
        this.storepassword = storepassword;
    }

    /**
     * @jsp.attribute
     *     description="The certificate as a PEM formatted file"
     *     type="java.lang.String"
     *     required="false"
     *     rtexprvalue="true"
     */
    public void setPemfile(String pemfile) {
        this.pemfile = pemfile;
    }

    /**
     * @jsp.attribute
     *     description="The certificate as a PEM formatted string"
     *     type="java.lang.String"
     *     required="false"
     *     rtexprvalue="true"
     */
    public void setPemstring(String pemstring) {
        this.pemstring = pemstring;
    }

    /**
     * @jsp.attribute
     *     description="The PKCS#12 (P12) keystore where the CA certificate is stored"
     *     type="java.lang.String"
     *     required="false"
     *     rtexprvalue="true"
     */
    public void setCastorefile(String castorefile) {
        this.castorefile = castorefile;
    }

    /**
     * @jsp.attribute
     *     description="The PKCS#12 (P12) CA keystore entry name for this certificate"
     *     type="java.lang.String"
     *     required="false"
     *     rtexprvalue="true"
     */
    public void setCastoreentry(String castoreentry) {
        this.castoreentry = castoreentry;
    }

    /**
     * @jsp.attribute
     *     description="The PKCS#12 (P12) CA keystore password"
     *     type="java.lang.StringBuffer"
     *     required="false"
     *     rtexprvalue="true"
     */
    public void setCastorepassword(StringBuffer castorepassword) {
        this.castorepassword = castorepassword;
    }

    /**
     * @jsp.attribute
     *     description="The CA certificate as a PEM formatted file"
     *     type="java.lang.String"
     *     required="false"
     *     rtexprvalue="true"
     */
    public void setCapemfile(String capemfile) {
        this.capemfile = capemfile;
    }

    /**
     * @jsp.attribute
     *     description="The CA certificate as a PEM formatted string"
     *     type="java.lang.String"
     *     required="false"
     *     rtexprvalue="true"
     */
    public void setCapemstring(String capemstring) {
        this.capemstring = capemstring;
    }

    /**
     * @jsp.attribute
     *     description="Return variable to store the certificate info:


     *       'REVOKED': this certificate has been revoked

     *       'EXPIRED': this certificate has expired

     *       'INVALID': this certificate is not valid or not signed by the correct CA

     *       'VERIFIED': this certificate is OK"
     *     type="java.lang.String"
     *     required="false"
     *     rtexprvalue="true"
     */
    public void setVerifyinfo(String verifyinfo) {
        this.verifyinfo = verifyinfo;
    }

    public String getVerifyinfo() {
        return verifyinfo;
    }
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
不卡的电影网站| 欧美日韩亚洲高清一区二区| 亚洲成人午夜电影| 国产亚洲欧美一级| 欧美久久久久久久久久| eeuss国产一区二区三区| 青草国产精品久久久久久| 亚洲精品你懂的| 久久麻豆一区二区| 日韩一区二区在线看片| 色狠狠色狠狠综合| 成人精品视频一区二区三区 | 一本久道久久综合中文字幕| 久久99精品久久久久| 亚洲一级二级三级| 亚洲色图在线播放| 国产精品丝袜久久久久久app| 日韩一区二区在线看片| 欧美三级在线播放| 色老汉一区二区三区| 成人国产精品视频| 国产成人日日夜夜| 国产精品一二三四五| 美女诱惑一区二区| 日韩1区2区3区| 五月天亚洲婷婷| 亚洲午夜精品在线| 亚洲亚洲精品在线观看| 亚洲欧美日韩中文字幕一区二区三区| 久久久www免费人成精品| 欧美一区二区网站| 91精品国产综合久久精品麻豆| 91福利区一区二区三区| 91麻豆视频网站| 91美女视频网站| 97精品电影院| 91黄色激情网站| 欧美亚洲一区二区在线| 欧洲在线/亚洲| 欧美亚洲国产一区二区三区va| 色综合久久66| 欧美系列在线观看| 欧美日韩一级片在线观看| 欧美日韩1234| 日韩西西人体444www| 日韩免费看网站| 精品电影一区二区| 久久久精品国产99久久精品芒果 | 久久久久国产精品人| 2020日本不卡一区二区视频| 久久天堂av综合合色蜜桃网| 久久久久国产一区二区三区四区 | 婷婷久久综合九色综合伊人色| 三级亚洲高清视频| 激情欧美一区二区| 成人午夜电影网站| 色呦呦一区二区三区| 欧美顶级少妇做爰| 精品1区2区在线观看| 国产精品久久久久久久久搜平片 | 亚洲精品国产一区二区三区四区在线| 欧美日韩国产高清一区二区 | 久久夜色精品国产噜噜av| 欧美一区二区免费视频| 日韩一区二区麻豆国产| 欧美成人一区二区三区片免费| 欧美成人a∨高清免费观看| 日韩欧美综合一区| 欧美成人猛片aaaaaaa| 成人动漫一区二区三区| 成人18视频日本| 色综合天天性综合| 欧美视频在线一区二区三区| 欧美熟乱第一页| 日韩一区二区免费在线电影| 久久午夜羞羞影院免费观看| 久久综合色8888| 精品少妇一区二区三区在线播放 | 91在线porny国产在线看| 一本一本大道香蕉久在线精品 | 欧美一卡在线观看| 91福利资源站| 91精品国产手机| 精品国产乱码久久久久久蜜臀| 久久日韩精品一区二区五区| 中文字幕免费一区| 亚洲免费电影在线| 免费高清在线一区| 国产福利精品一区二区| 久久99精品久久只有精品| 国产制服丝袜一区| 97se亚洲国产综合自在线| 欧美高清一级片在线| 精品国产不卡一区二区三区| 国产精品热久久久久夜色精品三区 | 国产精品欧美极品| 亚洲一区二区三区美女| 老司机午夜精品99久久| 国产精品系列在线观看| 色婷婷综合在线| 精品国产91亚洲一区二区三区婷婷| 国产精品色哟哟网站| 午夜精品福利一区二区蜜股av | 欧美日韩中文字幕一区| 久久人人97超碰com| 亚洲综合免费观看高清完整版| 久久国产视频网| 成人av在线资源网| 欧美专区日韩专区| 欧美成人精品1314www| 亚洲色图在线播放| 国产在线国偷精品产拍免费yy| 国产东北露脸精品视频| 88在线观看91蜜桃国自产| 国产精品看片你懂得| 免费成人结看片| 日本道色综合久久| 国产亲近乱来精品视频| 亚洲成人1区2区| 国产精品一区二区在线观看网站 | 国产精品久久久久三级| 日本91福利区| 91精品办公室少妇高潮对白| 国产无人区一区二区三区| 七七婷婷婷婷精品国产| 99精品热视频| 欧美区一区二区三区| 一区二区三区蜜桃网| 成人激情视频网站| 久久伊人中文字幕| 久久99久久99小草精品免视看| 欧美性感一区二区三区| 亚洲精品视频在线看| 精品一区二区三区欧美| 在线91免费看| 亚洲日本在线天堂| av不卡免费电影| 国产欧美在线观看一区| 韩国三级电影一区二区| 日韩精品一区二区在线观看| 亚洲午夜激情av| 欧美综合一区二区| 国产精品久久久久天堂| 美女视频网站久久| 欧美日韩国产高清一区二区三区 | 亚洲妇熟xx妇色黄| 欧美三级三级三级| 亚洲一区二区三区四区在线观看| 99久久婷婷国产精品综合| 欧美日韩国产一区| 亚洲精品久久久蜜桃| 91电影在线观看| 尤物av一区二区| 欧美日韩一区二区在线观看 | 久久国产人妖系列| 精品剧情在线观看| 亚洲欧洲色图综合| 欧洲av在线精品| 午夜精品福利久久久| 欧美一区二区精品久久911| 丝袜a∨在线一区二区三区不卡| 欧美日韩在线观看一区二区| 亚洲成a人在线观看| 欧美疯狂做受xxxx富婆| 亚洲五码中文字幕| 日韩视频在线一区二区| 国产成人自拍高清视频在线免费播放| 欧美大片在线观看| 国产精品888| 亚洲视频在线观看一区| 欧美三级韩国三级日本三斤| 一区二区三区免费看视频| 97国产一区二区| 一区二区三区在线不卡| 在线播放亚洲一区| 激情综合网最新| 精品少妇一区二区三区在线播放 | 久久久99久久精品欧美| 国产69精品久久久久毛片| 亚洲三级电影网站| 欧美日韩国产一区| 亚洲最大成人网4388xx| 一本一本久久a久久精品综合麻豆| 亚洲在线视频免费观看| 在线观看91精品国产麻豆| 国内精品免费在线观看| 久久久国产精品不卡| 色狠狠综合天天综合综合| 裸体歌舞表演一区二区| 久久精品视频免费| 91同城在线观看| 日本91福利区| 国产精品视频一区二区三区不卡| 91国产丝袜在线播放| 麻豆精品视频在线观看| 久久精品人人做人人爽人人| 丰满白嫩尤物一区二区| 五月天中文字幕一区二区| 国产日韩亚洲欧美综合| 欧美理论片在线|