vs2013 配置支持https的libcurl

简介: 需求:在vs2013上配置支持https协议的libcurl。 环境:win7(64位),vs2013   一、安装openssl: 需要先安装nasm和ActivePerl。 nasm需要手动配置环境变量。

 需求:在vs2013上配置支持https协议的libcurl

环境:win7(64)vs2013

 

一、安装openssl

需要先安装nasm和ActivePerl。

nasm需要手动配置环境变量。ActivePerl下载下来一路next安装就好了。

 

我安装openssl的时候是2018-08-03。不保证以后下面这个链接的方法依然有用。

我参考的是这个:https://blog.csdn.net/hpp24/article/details/54406424

亲测有用。只不过生成的include lib 等目录不对。居然在这目录C:\usr\local\ssl

需要注意的是,由于我的系统是64位的。我的vcvars32.bat在C:\Program Files (x86)\Microsoft Visual Studio 12.0\VC\bin这个目录中。

 

使用时需要指定头文件路径:

C:\usr\local\ssl\include

库的路径:

C:\usr\local\ssl\lib

同时要把libeay32.dllssleay32.dll拷贝到lib目录下。

 

使用时要把上面两个dll跟可执行文件放在一起。

#pragma comment(lib, "ssleay32.lib")

#pragma comment(lib, "libeay32.lib")

 

二、编译libcurl

直接去下载最新的。https://curl.haxx.se/download.html

我下载的是这个curl-7.61.0

解压,之后进入\curl-7.61.0\projects\Windows\VC12,打开curl-all.sln。里面有两个工程,

 

选择libcurl。配置选下面这个:

 

 配置属性-VC++目录-》包含目录  要指定openssl的头文件路径。

配置属性-VC++目录-》库目录 要指定openssl的库目录。

 

然后直接编译就好了。

curl-7.61.0\build\Win32\VC12\DLL Release - DLL OpenSSL

这个目录下会生成 libcurl.lib  libcurl.dll。这就大功告成了。

使用时的头文件路径是\curl-7.61.0\include

 

三、测试

可以参考这个:https://curl.haxx.se/libcurl/c/https.html

下面上我的代码:

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<curl/curl.h>
#include<iostream>

using namespace std;

#pragma comment(lib, "libcurl.lib")
#pragma comment(lib, "ssleay32.lib")
#pragma comment(lib, "libeay32.lib")

void test2()
{
    curl_global_init(CURL_GLOBAL_DEFAULT);

    CURL *curl;
    CURLcode res;
    curl = curl_easy_init();
    if (curl) 
    {
        /* First set the URL that is about to receive our POST. This URL can
        just as well be a https:// URL if that is what should receive the
        data. */
        curl_easy_setopt(curl, CURLOPT_URL, "https://www.baidu.com");

        curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER, 0L);//忽略证书检查
        curl_easy_setopt(curl, CURLOPT_SSL_VERIFYHOST, 0L);

        /* Now specify the POST data */
        curl_easy_setopt(curl, CURLOPT_POSTFIELDS, "name=daniel&project=curl");

        /* Perform the request, res will get the return code */
        res = curl_easy_perform(curl);
        if (res)
        {
            cout << "curl_easy_perform failed res = " << res << " ErrInfo:" << curl_easy_strerror(res) << endl;
        }
        else
        {
            cout << "curl_easy_perform success " << endl;
        }
        
        /* always cleanup */
        curl_easy_cleanup(curl);
    }
    curl_global_cleanup();
}

int main()
{
    test2();
    getchar();
    return 0;
}

 要配置curl的头文件路径和库路径,和openssl的库路径。

直接运行就好了。

 

四、总结

1)编译openssl比较费时间,这一步一定要做,不要想偷懒,按步骤一步一步来就好了。

2)运行curl测试程序时需要链接libcurlopenssl的那两个库。特别注意要把库放到程序运行目录中去。我最开始怀疑自己是不是没编译到包含openssllibcurl。一直在库目录上折腾,没有放到运行目录中去,折腾了将近一天。

3)查看自己编译的libcurl是否支持https,可以编译curl-all.sln中的curl项目,配置一样,要选openssl的。然后会编译出一个curl.exe。然后打开系统自带的cmd.exe,切换到生成curl.exe的目录,把两个openssl的库拷贝进来。执行红色框两个命令。出现下面的结果就表示你成功了。

 

 

目录
相关文章
|
2月前
|
网络协议 Java 应用服务中间件
tomcat配置域名及HTTPS
tomcat配置域名及HTTPS
|
1天前
|
安全 应用服务中间件 Shell
nginx配置https的ssl证书和域名
nginx配置https的ssl证书和域名
|
1月前
|
数据安全/隐私保护 Docker 容器
配置Harbor支持https功能实战篇
关于如何配置Harbor支持HTTPS功能的详细教程。
59 12
配置Harbor支持https功能实战篇
|
1月前
HAProxy的高级配置选项-配置haproxy支持https协议及服务器动态上下线
文章介绍了如何配置HAProxy以支持HTTPS协议和实现服务器的动态上下线。
90 8
HAProxy的高级配置选项-配置haproxy支持https协议及服务器动态上下线
|
1月前
|
分布式计算 Hadoop Devops
Hadoop集群配置https实战案例
本文提供了一个实战案例,详细介绍了如何在Hadoop集群中配置HTTPS,包括生成私钥和证书文件、配置keystore和truststore、修改hdfs-site.xml和ssl-client.xml文件,以及重启Hadoop集群的步骤,并提供了一些常见问题的故障排除方法。
52 3
Hadoop集群配置https实战案例
|
25天前
|
应用服务中间件 网络安全 Apache
HTTPS配置
HTTPS配置
90 11
|
1月前
|
Linux Docker Windows
Docker配置https证书案例
本文介绍了如何为Docker的Harbor服务配置HTTPS证书,包括安装Docker和Harbor、修改配置文件以使用证书、生成自签名证书、配置证书以及验证配置的步骤。
58 2
Docker配置https证书案例
|
28天前
|
监控 安全 应用服务中间件
如何配置HTTPS协议?
如何配置HTTPS协议?
43 4
|
2月前
|
Web App开发 存储
常见抓包工具配置抓取HTTPS
常见抓包工具配置抓取HTTPS
|
2月前
|
安全 Nacos 数据安全/隐私保护
【技术干货】破解Nacos安全隐患:连接用户名与密码明文传输!掌握HTTPS、JWT与OAuth2.0加密秘籍,打造坚不可摧的微服务注册与配置中心!从原理到实践,全方位解析如何构建安全防护体系,让您从此告别数据泄露风险!
【8月更文挑战第15天】Nacos是一款广受好评的微服务注册与配置中心,但其连接用户名和密码的明文传输成为安全隐患。本文探讨加密策略提升安全性。首先介绍明文传输风险,随后对比三种加密方案:HTTPS简化数据保护;JWT令牌减少凭证传输,适配分布式环境;OAuth2.0增强安全,支持多授权模式。每种方案各有千秋,开发者需根据具体需求选择最佳实践,确保服务安全稳定运行。
144 0