123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138 |
- #include <stdio.h>
- #include <curl/curl.h>
- int main(void)
- {
- int i;
- CURL *curl;
- CURLcode res;
- FILE *headerfile;
- const char *pPassphrase = NULL;
- static const char *pCertFile = "testcert.pem";
- static const char *pCACertFile="cacert.pem";
- const char *pKeyName;
- const char *pKeyType;
- const char *pEngine;
- #ifdef USE_ENGINE
- pKeyName = "rsa_test";
- pKeyType = "ENG";
- pEngine = "chil";
- #else
- pKeyName = "testkey.pem";
- pKeyType = "PEM";
- pEngine = NULL;
- #endif
- headerfile = fopen("dumpit", "w");
- curl_global_init(CURL_GLOBAL_DEFAULT);
- curl = curl_easy_init();
- if(curl) {
-
- curl_easy_setopt(curl, CURLOPT_URL, "HTTPS://your.favourite.ssl.site");
- curl_easy_setopt(curl, CURLOPT_HEADERDATA, headerfile);
- for(i = 0; i < 1; i++)
- {
- if (pEngine)
- {
- if (curl_easy_setopt(curl, CURLOPT_SSLENGINE,pEngine) != CURLE_OK)
- {
- fprintf(stderr,"can't set crypto engine\n");
- break;
- }
- if (curl_easy_setopt(curl, CURLOPT_SSLENGINE_DEFAULT,1L) != CURLE_OK)
- {
-
- fprintf(stderr,"can't set crypto engine as default\n");
- break;
- }
- }
-
-
- curl_easy_setopt(curl,CURLOPT_SSLCERTTYPE,"PEM");
-
- curl_easy_setopt(curl,CURLOPT_SSLCERT,pCertFile);
-
- if (pPassphrase)
- curl_easy_setopt(curl,CURLOPT_KEYPASSWD,pPassphrase);
-
- curl_easy_setopt(curl,CURLOPT_SSLKEYTYPE,pKeyType);
-
- curl_easy_setopt(curl,CURLOPT_SSLKEY,pKeyName);
-
- curl_easy_setopt(curl,CURLOPT_CAINFO,pCACertFile);
-
- curl_easy_setopt(curl,CURLOPT_SSL_VERIFYPEER,1L);
-
- res = curl_easy_perform(curl);
-
- if(res != CURLE_OK)
- fprintf(stderr, "curl_easy_perform() failed: %s\n",
- curl_easy_strerror(res));
-
- }
-
- curl_easy_cleanup(curl);
- }
- curl_global_cleanup();
- return 0;
- }
|