色婷婷AⅤ一区二区三区|亚洲精品第一国产综合亚AV|久久精品官方网视频|日本28视频香蕉

          "); //-->

          博客專欄

          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)閉