v0.10 cppnetlib tidak secara langsung mendukung sertifikasi klien. Karena Anda menggunakan cppnetleb, Anda dapat menggunakan boost asio dengan boost 1.49
Berikut adalah contoh kode yang melakukan sebagian besar pekerjaan asio https://github.com/alexandruc/SimpleHttpsClient/blob/master/https_client.cpp
Kode itu sangat mirip dengan http://www.boost.org/doc/libs/1_49_0/doc/html/boost_asio/example/ssl/client.cpp
Saya menempatkan keduanya jika tautannya putus. Itu menangani koneksi https untuk melakukan sertifikasi klien, Anda perlu menambahkan baris berikut ke fungsi utama sebelum membuat klien:
std::string tempString = "test.pem"; //this is a pem file that contains a private key and a certificate.
boost::asio::ssl::context ctx(boost::asio::ssl::context::sslv23_client);
ctx.set_options(boost::asio::ssl::context::default_workarounds
| boost::asio::ssl::context::no_sslv2
| boost::asio::ssl::context::no_sslv3);
ctx.set_default_verify_paths();
ctx.use_certificate_file(tempFileStr.c_str(), boost::asio::ssl::context_base::pem);
ctx.use_private_key_file(tempFileStr.c_str(), boost::asio::ssl::context_base::pem);
Namun dalam contoh ini Anda tidak memiliki file PEM melainkan file p12, (format pkcs12). openssl dapat digunakan untuk mendekripsi dan membuat file pem yang diinginkan. Saya mengadaptasi kode di bawah ini dari Cara memuat file PKCS#12 di OpenSSL secara terprogram? Sayangnya versi boost ini tidak mendukung sertifikat di memori sehingga harus ditulis, dienkripsi ke file. Saya meletakkan ini di direktori sementara, dan mungkin pada akhirnya akan dihapus.
std::string _certFile = "C:\\cert\\mycert.p12";
std::string password = "_certPassword";
boost::filesystem::path tempFile = boost::filesystem::temp_directory_path() / "temp.pem";
std::string tempFileStr = tempFile.generic_string();
std::cout<<"Using temp file " << tempFileStr<<std::endl;
try
{
//read in the pksc12 file, decode it and write a PEM file
FILE *fp;
EVP_PKEY *pkey;
X509 *cert;
STACK_OF(X509) *ca = NULL;
PKCS12 *p12;
int i;
OpenSSL_add_all_algorithms();
ERR_load_crypto_strings();
if (!(fp = fopen(_certFile.c_str(), "rb"))) {
fprintf(stderr, "Error opening file %s\n", _certFile);
return false;
}
p12 = d2i_PKCS12_fp(fp, NULL);
fclose (fp);
if (!p12) {
fprintf(stderr, "Error reading PKCS#12 file\n");
ERR_print_errors_fp(stderr);
return false;
}
if (!PKCS12_parse(p12, _certpPassword.c_str(), &pkey, &cert, &ca)) {
fprintf(stderr, "Error parsing PKCS#12 file\n");
ERR_print_errors_fp(stderr);
return false;
}
PKCS12_free(p12);
if (!(fp = fopen(tempFileStr.c_str(), "w"))) {
fprintf(stderr, "Error opening file %s\n", tempFileStr.c_str());
return false;
}
if (pkey) {
fprintf(fp, "***Private Key***\n");
PEM_write_PrivateKey(fp, pkey, NULL, NULL, 0, NULL, NULL);
}
if (cert) {
fprintf(fp, "***User Certificate***\n");
PEM_write_X509(fp, cert);
}
if (ca && sk_X509_num(ca)) {
fprintf(fp, "***Other Certificates***\n");
for (i = 0; i < sk_X509_num(ca); i++)
{
PEM_write_X509(fp, sk_X509_value(ca, i));
}
}
sk_X509_pop_free(ca, X509_free);
X509_free(cert);
EVP_PKEY_free(pkey);
fclose(fp);
}
catch (std::exception &e) {
retVal = false;
std::cout <<"Error parsing/decrypting pkcs12 file into PEM or writing temporary pem file" << e.what() << std::endl;
}
Berikut adalah penyertaan yang saya gunakan
//for ssl connection
#include <boost/asio.hpp>
#include <boost/asio/ssl.hpp>
#include <boost/asio/ssl/context_base.hpp>
//for parsing key file
#include <openssl/pkcs12.h>
person
Jim
schedule
03.04.2017