当前位置: 首页 > article >正文

Windows下libhv编译踩坑实录:如何正确开启WITH_OPENSSL支持HTTPS请求

Windows下libhv编译实战从零构建支持HTTPS的跨平台网络库最近在开发一个需要处理HTTPS请求的C项目时我选择了libhv作为网络库。libhv是一个轻量级、跨平台的C网络库但在Windows环境下编译支持HTTPS功能的版本时遇到了不少坑。本文将详细记录整个编译过程特别是如何正确开启WITH_OPENSSL支持希望能帮助遇到同样问题的开发者少走弯路。1. 环境准备与工具安装在开始编译libhv之前我们需要准备好必要的开发环境和工具链。Windows下的C开发环境配置往往比Linux更复杂这也是很多开发者容易踩坑的地方。1.1 安装Visual Studiolibhv在Windows下的编译需要Visual Studio的C工具链。推荐安装Visual Studio 2019或2022社区版安装时务必勾选使用C的桌面开发工作负载1. 下载Visual Studio安装程序 2. 选择使用C的桌面开发 3. 确保勾选MSVC v142或v143工具集 4. 安装Windows 10/11 SDK1.2 安装CMakelibhv使用CMake作为构建系统我们需要安装最新版本的CMakechoco install cmake --installargs ADD_CMAKE_TO_PATHSystem或者从官网下载安装包手动安装。安装完成后验证CMake是否可用cmake --version1.3 安装OpenSSL这是支持HTTPS功能的关键步骤。Windows下推荐使用Win32OpenSSL访问Win32OpenSSL官网下载适合你系统的版本32位或64位运行安装程序记住安装路径默认是C:\Program Files\OpenSSL-Win64安装完成后将OpenSSL的bin目录添加到系统PATH环境变量setx PATH %PATH%;C:\Program Files\OpenSSL-Win64\bin2. 获取libhv源码与初步配置2.1 克隆libhv仓库建议直接从官方仓库克隆最新代码git clone https://github.com/ithewei/libhv.git cd libhv2.2 创建构建目录在libhv根目录下创建build目录这是CMake推荐的做法mkdir build cd build3. 配置OpenSSL支持3.1 修改CMakeLists.txt打开libhv根目录下的CMakeLists.txt文件找到以下关键配置项# 第27行附近 option(WITH_OPENSSL Enable OpenSSL support OFF) # 改为ON将WITH_OPENSSL选项从OFF改为ON这是启用HTTPS支持的关键开关。3.2 配置OpenSSL路径在CMakeLists.txt中找到OpenSSL相关配置部分约73-74行确保路径正确# OpenSSL set(OPENSSL_ROOT_DIR C:/Program Files/OpenSSL-Win64) set(OPENSSL_INCLUDE_DIR ${OPENSSL_ROOT_DIR}/include) set(OPENSSL_LIBRARIES ${OPENSSL_ROOT_DIR}/lib/libcrypto.lib ${OPENSSL_ROOT_DIR}/lib/libssl.lib)如果你将OpenSSL安装在其他位置需要相应修改这些路径。3.3 组织第三方库libhv需要一个3rd目录来存放第三方库的头文件和库文件在libhv根目录下创建3rd文件夹在3rd下创建include和lib子目录将OpenSSL的include目录内容复制到3rd/include将OpenSSL的lib目录中的.lib文件复制到3rd/lib4. 编译libhv4.1 生成Visual Studio解决方案在build目录下运行CMake生成VS解决方案cmake .. -G Visual Studio 16 2019 -A x64注意根据你的VS版本调整Visual Studio 16 2019参数4.2 编译项目生成解决方案后你可以打开生成的libhv.sln在Visual Studio中编译或者使用命令行编译cmake --build . --config Release4.3 验证编译结果编译成功后你会在build目录下找到hv.dll- 动态链接库hv.lib- 导入库include/hv/*.h- 头文件5. 使用libhv进行HTTPS请求现在你已经有了支持HTTPS的libhv库下面展示如何使用它进行HTTPS请求和文件下载。5.1 简单GET请求示例#include hv/HttpClient.h int main() { hv::HttpClient client; auto resp client.get(https://example.com); if (resp nullptr) { printf(Request failed\n); return -1; } printf(Status: %d\n, resp-status_code); printf(Body: %s\n, resp-body.c_str()); return 0; }5.2 下载文件示例#include fstream #include hv/HttpClient.h bool downloadFile(const std::string url, const std::string savePath) { hv::HttpClient client; auto resp client.get(url); if (resp nullptr || resp-status_code ! HTTP_STATUS_OK) { return false; } std::ofstream file(savePath, std::ios::binary); if (!file.is_open()) { return false; } file.write(resp-body.data(), resp-body.size()); file.close(); return true; } int main() { if (downloadFile(https://example.com/image.jpg, image.jpg)) { printf(Download succeeded\n); } else { printf(Download failed\n); } return 0; }6. 常见问题与解决方案6.1 OpenSSL库找不到错误现象Could NOT find OpenSSL (missing: OPENSSL_LIBRARIES OPENSSL_INCLUDE_DIR)解决方案确认OpenSSL安装路径正确检查CMakeLists.txt中的OpenSSL路径配置确保系统PATH包含OpenSSL的bin目录6.2 链接错误错误现象LNK2019: unresolved external symbol SSL_xxx referenced in function yyy解决方案确认WITH_OPENSSL选项已开启检查OpenSSL库文件是否正确链接确保编译时链接了libssl.lib和libcrypto.lib6.3 证书验证失败错误现象 HTTPS请求失败证书验证错误解决方案确保系统有最新的根证书或者临时禁用证书验证仅限测试环境hv::HttpClient client; client.withTLS().insecure(); // 禁用证书验证7. 性能优化与高级用法7.1 连接池管理libhv内置了连接池合理配置可以显著提升性能hv::HttpClient client; client.setThreadPoolSize(4); // 设置线程池大小 client.setTimeout(10); // 设置超时(秒)7.2 异步请求对于高性能应用可以使用异步接口client.getAsync(https://example.com, [](const hv::HttpResponsePtr resp) { if (resp) { // 处理响应 } });7.3 自定义请求头hv::HttpRequest req; req.method HTTP_GET; req.url https://example.com; req.headers[User-Agent] MyApp/1.0; req.headers[Authorization] Bearer xxxxx; auto resp client.send(req);在实际项目中我发现libhv的异步接口配合连接池管理能够轻松应对高并发的HTTPS请求场景。特别是在爬虫和API调用等应用中合理配置的超时和重试机制可以大大提高程序的稳定性。

相关文章:

Windows下libhv编译踩坑实录:如何正确开启WITH_OPENSSL支持HTTPS请求

Windows下libhv编译实战:从零构建支持HTTPS的跨平台网络库 最近在开发一个需要处理HTTPS请求的C项目时,我选择了libhv作为网络库。libhv是一个轻量级、跨平台的C网络库,但在Windows环境下编译支持HTTPS功能的版本时,遇到了不少坑…...

PaddleHub色情检测模型实战:从安装到文本过滤(2.0环境)

1. 环境准备与安装指南 在开始使用PaddleHub色情检测模型之前,我们需要先搭建好开发环境。这里推荐使用Python 3.6版本,因为PaddlePaddle 2.0对Python 3.6有更好的支持。我实际测试过在Windows 10和Ubuntu 18.04系统上的安装过程,下面把详细步…...

Dramatron AI剧本生成器:从创意到成品的完整创作指南

Dramatron AI剧本生成器:从创意到成品的完整创作指南 【免费下载链接】dramatron 项目地址: https://gitcode.com/gh_mirrors/dra/dramatron 在当今数字创作时代,AI辅助工具正在彻底改变创意工作流程。Dramatron作为DeepMind推出的开源AI剧本生成…...

Amesim中PID控制元件的参数整定与优化实践

1. PID控制基础与Amesim实现 第一次接触PID控制时,我被它的简洁和强大所震撼。就像开车时既要看速度表(比例控制),又要留意过去几分钟的平均速度(积分控制),还要预判速度变化趋势(微…...

保姆级教程:在MTK平台上手把手调试LK启动流程(附常见问题排查)

MTK平台LK启动流程深度调试指南:从环境搭建到实战排查 LK(Little Kernel)作为MTK平台启动流程中的关键环节,承担着硬件初始化、内核加载等核心任务。对于嵌入式开发者而言,掌握LK的调试技巧不仅能快速定位启动失败问题…...

Wan2.1-umt5模拟技术面试官:生成Java/Python等岗位的面试题与评价

Wan2.1-umt5模拟技术面试官:打造你的个人AI面试教练 面试准备,尤其是技术面试,对很多开发者来说都是一件既重要又头疼的事情。自己刷题感觉像在盲人摸象,找人模拟面试又需要协调时间,而且很难找到经验丰富的“考官”。…...

单片机硬件工程师能力成长五维模型与工程实践

1. 单片机硬件工程师的职业发展路径与能力构建体系单片机作为嵌入式系统的核心载体,其硬件设计能力直接决定电子产品的可靠性、量产可行性与长期维护性。在当前智能硬件爆发式增长的背景下,具备扎实硬件功底的单片机工程师正面临结构性供需失衡——企业对…...

如何在无root权限的服务器上搞定Maker基因组注释工具?Conda+Perl环境避坑指南

无root权限下部署Maker基因组注释工具:CondaPerl环境全攻略 引言 在生物信息学研究中,基因组注释是不可或缺的关键步骤。Maker作为一款强大的自动化注释工具,能够整合多种证据数据生成高质量的基因注释结果。然而,许多研究人员面临…...

【仅限头部AIGC团队内部流通】Dify Rerank性能调优Checklist v3.2(含12项GPU利用率>94%的微调参数组合)

第一章:Dify Rerank性能调优的核心目标与边界约束Dify Rerank模块作为检索增强生成(RAG)流水线中的关键排序组件,其性能直接影响最终回答的相关性、响应延迟与系统吞吐能力。调优的核心目标并非单纯追求最高精度或最低延迟&#x…...

ollama调用Phi-4-mini-reasoning实战案例:自动将自然语言题干转为形式化逻辑表达式

ollama调用Phi-4-mini-reasoning实战案例:自动将自然语言题干转为形式化逻辑表达式 你有没有遇到过这样的场景?面对一段复杂的逻辑描述,比如“如果今天下雨,我就不去跑步;除非我带了伞,否则下雨天我肯定不…...

二极管物理本质与工程应用全解析

1. 二极管的工程本质:从PN结物理特性到电路功能映射二极管绝非一个简单的“单向导电开关”。其核心价值在于PN结在正向偏置、反向偏置、反向击穿等不同工作区域所呈现的、高度可预测且可工程化利用的电学特性。理解这些特性的物理根源,是设计可靠电路的前…...

修复微信消息防撤回功能:从异常诊断到补丁部署的完整解决方案

修复微信消息防撤回功能:从异常诊断到补丁部署的完整解决方案 【免费下载链接】RevokeMsgPatcher :trollface: A hex editor for WeChat/QQ/TIM - PC版微信/QQ/TIM防撤回补丁(我已经看到了,撤回也没用了) 项目地址: https://git…...

从Node_ID到CBV:手把手教你配置Autosar网络管理参数(避坑指南)

从Node_ID到CBV:手把手教你配置Autosar网络管理参数(避坑指南) 在车载电子系统开发中,Autosar网络管理是确保ECU(电子控制单元)高效协同工作的关键模块。作为一线工程师,我们经常需要在Vector D…...

Anaconda环境管理:为cv_unet_image-colorization创建独立Python沙箱

Anaconda环境管理:为cv_unet_image-colorization创建独立Python沙箱 你是不是也遇到过这种情况?好不容易找到一个好用的AI模型,比如这个给黑白照片上色的cv_unet_image-colorization,兴致勃勃地准备跑起来试试,结果第…...

3种策略让html-to-docx实现HTML到Word转换的效率革命

3种策略让html-to-docx实现HTML到Word转换的效率革命 【免费下载链接】html-to-docx HTML to DOCX converter 项目地址: https://gitcode.com/gh_mirrors/ht/html-to-docx 在数字化办公的今天,文档格式转换已成为日常工作中不可或缺的环节。特别是HTML到Word…...

【ComfyUI】Qwen-Image-Edit-F2P环境问题全解:从Anaconda安装到依赖冲突

ComfyUI Qwen-Image-Edit-F2P环境问题全解:从Anaconda安装到依赖冲突 你是不是也遇到过这种情况?好不容易找到一个功能强大的AI图像编辑工具,比如这个Qwen-Image-Edit-F2P,兴致勃勃地准备在ComfyUI里大展身手,结果第一…...

AnimatedDrawings故障排除实战指南:从入门到精通的问题解决手册

AnimatedDrawings故障排除实战指南:从入门到精通的问题解决手册 【免费下载链接】AnimatedDrawings Code to accompany "A Method for Animating Childrens Drawings of the Human Figure" 项目地址: https://gitcode.com/GitHub_Trending/an/AnimatedD…...

PhysicsLabFirmware:面向物理教学的BLE嵌入式固件设计

1. PhysicsLabFirmware 项目概述PhysicsLabFirmware 是专为物理实验教学套件(Physics Lab Kit)设计的嵌入式固件系统,面向高校基础物理实验、中学STEM教育及工程实践课程场景。该固件运行于基于ARM Cortex-M0架构的Arduino MKR系列开发板&…...

Ubuntu 24.04服务器SSH配置全攻略:从安装到密钥登录(附安全建议)

Ubuntu 24.04服务器SSH配置全攻略:从安装到密钥登录(附安全建议) 远程管理Linux服务器时,SSH(Secure Shell)无疑是每位运维人员的必备工具。作为Ubuntu 24.04 LTS发布后的首个稳定版本,其在SSH服…...

3个步骤让你的Windows电脑也能像iPhone一样预览HEIC照片

3个步骤让你的Windows电脑也能像iPhone一样预览HEIC照片 【免费下载链接】windows-heic-thumbnails Enable Windows Explorer to display thumbnails for HEIC files 项目地址: https://gitcode.com/gh_mirrors/wi/windows-heic-thumbnails 你是不是经常遇到这样的尴尬时…...

BepInEx插件框架:新手问题全解析与实战解决方案

BepInEx插件框架:新手问题全解析与实战解决方案 【免费下载链接】BepInEx Unity / XNA game patcher and plugin framework 项目地址: https://gitcode.com/GitHub_Trending/be/BepInEx 一、游戏启动异常:四步定位与修复方案 问题定位 当BepInE…...

RPA文件高效提取实战指南:从零基础到专业应用

RPA文件高效提取实战指南:从零基础到专业应用 【免费下载链接】unrpa A program to extract files from the RPA archive format. 项目地址: https://gitcode.com/gh_mirrors/un/unrpa 解决资源提取难题:unrpa的核心价值解析 当你尝试打开RenPy游…...

Cogito-V1-Preview-Llama-3B创意编程:生成抽象艺术或算法的文字描述

Cogito-V1-Preview-Llama-3B创意编程:生成抽象艺术或算法的文字描述 最近在玩一个挺有意思的模型,叫Cogito-V1-Preview-Llama-3B。名字有点长,但功能很特别。它不是用来写代码或者回答问题的,而是专门干一件“翻译”的活儿——把…...

GTE-Pro语义检索惊艳效果展示:‘缺钱’命中‘资金链断裂’真实案例

GTE-Pro语义检索惊艳效果展示:‘缺钱’命中‘资金链断裂’真实案例 基于阿里达摩院 GTE-Large 的企业级语义检索引擎 1. 项目概述 GTE-Pro 是一套为企业打造的智能语义检索引擎,它彻底改变了传统的关键词搜索方式。想象一下,你不再需要记住文…...

运维实战:Lingbot深度模型服务的监控、日志与故障排查

运维实战:Lingbot深度模型服务的监控、日志与故障排查 部署一个像Lingbot-Depth-Pretrain-ViTL-14这样的深度模型服务,对很多团队来说只是第一步。模型跑起来了,但怎么知道它跑得好不好?半夜服务突然变慢甚至挂了,怎么…...

libsodium嵌入式移植实战:ESPHome安全工程指南

1. libsodium 在嵌入式系统中的工程化移植:以 ESPHome 为例的深度解析1.1 为什么嵌入式系统需要 libsodium?在资源受限的 MCU 平台上(如 ESP32、nRF52840、STM32H7),密码学功能长期面临三重矛盾:安全性要求…...

Canvas Quest API接口封装与调用指南:Python与Node。js客户端开发

Canvas Quest API接口封装与调用指南:Python与Node.js客户端开发 1. 快速了解Canvas Quest API Canvas Quest是一款强大的在线图像处理服务,通过API可以轻松实现各种图像编辑功能。无论你是想批量处理图片,还是需要在应用中集成图像处理能力…...

低轨卫星C语言功耗黑洞清单(含ARM Cortex-R5F异常向量表误配置导致的17mA暗电流案例)

第一章:低轨卫星C语言功耗的物理约束与系统级影响 低轨卫星(LEO)平台受限于严苛的能源预算、热管理边界和辐射环境,其嵌入式软件——尤其是以C语言编写的底层驱动与任务调度模块——并非仅受逻辑正确性约束,更直接受制…...

STEP3-VL-10B多模态推理教程:上传实验仪器照片→操作步骤语音指导生成

STEP3-VL-10B多模态推理教程:上传实验仪器照片→操作步骤语音指导生成 1. 引言:当AI看懂你的实验仪器 想象一下这个场景:你走进实验室,面对一台复杂的仪器,可能是质谱仪、离心机,或者一台你没用过的光谱分…...

AntiDupl图片去重工具:智能清理重复照片的高效解决方案

AntiDupl图片去重工具:智能清理重复照片的高效解决方案 【免费下载链接】AntiDupl A program to search similar and defect pictures on the disk 项目地址: https://gitcode.com/gh_mirrors/an/AntiDupl 你是否曾为电脑中堆积如山的重复照片而烦恼&#xf…...