关于Libcurl双向认证请求https

之前通过libcurl开发只是做http请求,这次公司项目需要请求https,所以就研究了一下,其实用libcurl做http请求是非常简单的,所有底层实现都被封装到了libcurl里面(默认编译的libcurl是没有附加SSL的,也就是说默认的libcurl是不带https功能的,因此需要自己重新编译,这里是一个libcurl支持https,可以直接用),具体关于https的实现如下:

int CHttpClient::sendRequest(std::string strRequestType,
    std::string strUrl,
    std::string& strReport,
    std::string& strRetHeader,
    std::vector<std::string> vecHeader,
    std::string strParam/* ="" */,
    std::string strCookie/* ="" */,
    std::string strCaPath/* ="" */,
    int nTimeOut/* =0 */)
{
    CURL* curl;
    curl = curl_easy_init();
    curl_easy_setopt(curl, CURLOPT_URL, strUrl.c_str());

    if (strRequestType.compare("post") == 0 || strRequestType.compare("POST") == 0)
    {
        curl_easy_setopt(curl, CURLOPT_POST, 1);
        curl_easy_setopt(curl, CURLOPT_POSTFIELDSIZE, strlen(strParam.c_str()));//post内容长度
        curl_easy_setopt(curl, CURLOPT_POSTFIELDS, strParam.c_str());
    }
    else
    {
        curl_easy_setopt(curl, CURLOPT_POST, 0);//get请求
    }

    //设置http头
    curl_slist* headers = NULL;
    for (int i = 0; i < vecHeader.size(); i++)
    {
        if (!vecHeader.at(i).empty())
        {
            headers = curl_slist_append(headers, vecHeader.at(i).c_str());
        }
    }
    if (headers != NULL)
    {
        curl_easy_setopt(curl, CURLOPT_HTTPHEADER, headers);
    }

    curl_easy_setopt(curl, CURLOPT_SSLVERSION, 1);

    //判断是否有证书
    if (strCaPath.empty())
    {
        curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER, false);
        curl_easy_setopt(curl, CURLOPT_SSL_VERIFYHOST, false);
    }
    else
    {
        curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER, true);
        curl_easy_setopt(curl, CURLOPT_SSL_VERIFYHOST, true);
        curl_easy_setopt(curl, CURLOPT_CAINFO, "C:/ssl/cacert.pem");


        curl_easy_setopt(curl, CURLOPT_SSLCERT, "C:/ssl/client.pem");
        curl_easy_setopt(curl, CURLOPT_SSLCERTPASSWD, "11111111");
        curl_easy_setopt(curl, CURLOPT_SSLCERTTYPE, "PEM");
        curl_easy_setopt(curl, CURLOPT_SSLKEY, "C:/ssl/clientkey.pem");
        curl_easy_setopt(curl, CURLOPT_SSLKEYPASSWD, "11111111");
        curl_easy_setopt(curl, CURLOPT_SSLKEYTYPE, "PEM");
    }

    //Web服务器一般会重定向链接,比如访问http:/xxx/x1.do自动转到http:/xxx/x2.do  
    //所以一定要设置CURLOPT_FOLLOWLOCATION为1,否则重定向后的数据不会返回。  
    //curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION,1); 

    curl_easy_setopt(curl, CURLOPT_VERBOSE, 1); //可以看到调试信息
    curl_easy_setopt(curl, CURLOPT_HEADERFUNCTION, _CURL_::write_data);
    curl_easy_setopt(curl, CURLOPT_WRITEHEADER, &strRetHeader);
    curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, _CURL_::write_data);
    curl_easy_setopt(curl, CURLOPT_WRITEDATA, &strReport);
    if (nTimeOut > 0)
    {
        curl_easy_setopt(curl, CURLOPT_CONNECTTIMEOUT, nTimeOut);
        curl_easy_setopt(curl, CURLOPT_TIMEOUT, nTimeOut);
    }


    if (!strCookie.empty())
    {
        curl_easy_setopt(curl, CURLOPT_COOKIEFILE, strCookie.c_str());
    }

    CURLcode code = curl_easy_perform(curl);

    if (code != CURLE_OK)

    {

        printf("curl_wasy_perform error = %s", curl_easy_strerror(code));
    }
    if (headers != NULL)
    {
        curl_slist_free_all(headers);
    }
    curl_easy_cleanup(curl);
    return code;
}

  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
libcurl支持https双向认证。在使用libcurl进行https连接时,可以使用以下参数进行配置: 1. CURLOPT_SSLCERTTYPE: 设置证书的格式,支持PEM和DER格式。 2. CURLOPT_SSLCERT: 设置客户端证书的文件名,加密传输下默认格式是P12,其它方式下是PEM。建议使用相对路径来避免混淆。 3. CURLOPT_SSLKEY: 设置私钥文件的文件名,默认格式是PEM。可以通过CURLOPT_SSLKEYTYPE来修改私钥格式。 4. CURLOPT_KEYPASSWD: 当使用私钥文件时,可能需要设置密码。加载证书时不需要密码,但加载私钥时需要。 5. CURLOPT_CAINFO: 设置根证书,用于验证对端证书的有效性。一般是由证书颁发机构(CA)颁发的证书。 6. CURLOPT_SSL_VERIFYPEER: 决定是否验证对方证书的有效性。当进行TLS或SSL连接时,服务器会发送证书以证明身份,CURL会验证证书的真实性。此验证基于数字签名链,以您提供的证书颁发机构(CA)的证书为基础。 双向认证需要配置客户端证书和私钥,并设置CURLOPT_SSLCERT和CURLOPT_SSLKEY参数。 参考文献: https://blog.csdn.net/chary8088/article/details/22950843 https://blog.csdn.net/wu110112/article/details/72898630 Makefile中的参数说明<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [在windows平台用libcurl双向认证](https://blog.csdn.net/thanklife/article/details/79848165)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [HTTPS认证四:使用开源libcurl进行SSL双向认证](https://blog.csdn.net/egbert123/article/details/103832664)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

RuningPigNO1

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值