在线看毛片网站电影-亚洲国产欧美日韩精品一区二区三区,国产欧美乱夫不卡无乱码,国产精品欧美久久久天天影视,精品一区二区三区视频在线观看,亚洲国产精品人成乱码天天看,日韩久久久一区,91精品国产91免费

<menu id="6qfwx"><li id="6qfwx"></li></menu>
    1. <menu id="6qfwx"><dl id="6qfwx"></dl></menu>

      <label id="6qfwx"><ol id="6qfwx"></ol></label><menu id="6qfwx"></menu><object id="6qfwx"><strike id="6qfwx"><noscript id="6qfwx"></noscript></strike></object>
        1. <center id="6qfwx"><dl id="6qfwx"></dl></center>

            博客專欄

            EEPW首頁 > 博客 > X509證書驗證-部分驗證

            X509證書驗證-部分驗證

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

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

            可以實現(xiàn)只驗證一級。不用驗證到根證書。

             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;
            }


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



            關(guān)鍵詞: openssl

            技術(shù)專區(qū)

            關(guān)閉