5

当我运行这段代码时,我得到了错误信息:

  • 即将 connect() 到 10.12.190.155 端口 443 (#0)
  • 正在尝试 10.12.190.155... * 已连接
  • 连接到 10.12.190.155 (10.12.190.155) 端口 443 (#0)
  • 使用 certpath 初始化 NSS:sql:/etc/pki/nssdb
  • CAfile:/home/wh/work/sslkey/ca.crt CApath:无
  • 无法加载客户端密钥 -8178。
  • NSS 错误 -8178
  • 关闭连接 #0
  • 本地 SSL 证书问题

卷曲*卷曲;CURLcode 资源;

//static const char *pClientCert = "/home/wh/work/sslkey/user1.pem";

curl_global_init(CURL_GLOBAL_DEFAULT);
curl = curl_easy_init();

if(curl)
{
    curl_easy_setopt(curl, CURLOPT_HEADER, 1L);
    curl_easy_setopt(curl, CURLOPT_VERBOSE, 1L);
    curl_easy_setopt(curl, CURLOPT_URL, "https://10.12.190.155/");
    curl_easy_setopt(curl, CURLOPT_CAINFO, "/home/wh/work/sslkey/ca.crt");
    curl_easy_setopt(curl,CURLOPT_SSLCERT,"/home/wh/work/sslkey/user1.pem");
    res = curl_easy_perform(curl);
          /* Check for errors */
    if(res != CURLE_OK)
        fprintf(stderr, "curl_easy_perform() failed: %s\n",
            curl_easy_strerror(res));
    curl_easy_cleanup(curl);
}

curl_global_cleanup();
4

1 回答 1

0

您的代码中没有curl_easy_setopt(curl, CURLOPT_SSLKEY, "key_file_path");获取您的密钥。另外还不清楚您的 user1.pem 是否同时包含密钥和证书?

如果答案是否定的,则需要使用上述命令提供 key.pem 文件。如果您从 .p12 文件转换您的密钥,请同时检查问题。

阅读内容以正确编写代码。

于 2017-03-09T07:48:51.620 回答