<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>
"); //-->

博客專(zhuān)欄

EEPW首頁(yè) > 博客 > X509證書(shū)驗證-部分驗證

X509證書(shū)驗證-部分驗證

發(fā)布人:電子禪石 時(shí)間:2024-04-08 來(lái)源:工程師 發(fā)布文章

openssl verify -partial_chain -CAfile CA.pem CERTIFICATE.pem  

可以實(shí)現只驗證一級。不用驗證到根證書(shū)。

 X509_VERIFY_PARAM_set_flags(vpm, X509_V_FLAG_PARTIAL_CHAIN);


int x509_verify_chain(char * ca_cert_buf, char *user_cert_buf)
{
    cjwt_code_t rv         = CJWTE_SIGNATURE_VALIDATION_FAILED;
    int ret = 0;
    BIO *ca_certbio         = NULL;//Gerry
    BIO *certbio         = NULL;//Gerry
    X509  *cert         = NULL;
    X509  *ca_cert         = NULL;
    ca_certbio = BIO_new_mem_buf(ca_cert_buf, strlen(ca_cert_buf));
    if (!ca_certbio) {
        printf("FUN %s LINE %d\n", __FUNCTION__ , __LINE__);
        return CJWTE_OUT_OF_MEMORY;
    }
    ca_cert = PEM_read_bio_X509(ca_certbio,&ca_cert,NULL,NULL);
    BIO_free(ca_certbio);
    if (!ca_certbio) {
        printf("FUN %s LINE %d\n", __FUNCTION__, __LINE__);
        return CJWTE_SIGNATURE_INVALID_KEY;
    }

    certbio = BIO_new_mem_buf(user_cert_buf, strlen(user_cert_buf));
    if (!certbio) {
        printf("FUN %s LINE %d\n", __FUNCTION__ , __LINE__);
        return CJWTE_OUT_OF_MEMORY;
    }

    cert = PEM_read_bio_X509(certbio,&cert,NULL,NULL);
    BIO_free(certbio);
    if (!certbio) {
        printf("FUN %s LINE %d\n", __FUNCTION__, __LINE__);
        return CJWTE_SIGNATURE_INVALID_KEY;
    }
    X509_STORE *store;
    X509_STORE_CTX *ctx;
    store = X509_STORE_new();
    X509_STORE_set_verify_cb(store, verify_cb);
    X509_STORE_add_cert(store, ca_cert);
    X509_STORE_set_flags(store, X509_V_FLAG_PARTIAL_CHAIN);//);
    ctx = X509_STORE_CTX_new();
    X509_STORE_CTX_init(ctx, store, cert, NULL);
   
    ret = X509_verify_cert(ctx);
   
    if(ctx != NULL) X509_STORE_CTX_free(ctx);
    if(store != NULL) X509_STORE_free(store);
    if(cert != NULL) X509_free(cert);
    if(ca_cert != NULL) X509_free(ca_cert);

    return ret;
}


*博客內容為網(wǎng)友個(gè)人發(fā)布,僅代表博主個(gè)人觀(guān)點(diǎn),如有侵權請聯(lián)系工作人員刪除。



關(guān)鍵詞: openssl

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>