WINHTTP忽略HTTPS证书

2024-02-02 14:04
文章标签 https 证书 忽略 winhttp

本文主要是介绍WINHTTP忽略HTTPS证书,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

        • WINHTTP忽略HTTPS证书
        • WINHTTP使用TLS协议版本

WINHTTP忽略HTTPS证书
发布了Wininet库忽略Https证书文章之后有朋友问我如果使用WINHTTP发起忽略证书的方法,
下列粘出代码可以看到跟Wininet是一样的不在过多赘述,不懂的朋友可以看我发的链接说明。

C++发起Https请求

#include <Windows.h>
#include <Winhttp.h>
#include <stdio.h>#pragma comment(lib, "winhttp.lib")#define TRANSFER_SIZE 1024bool PerformHttpRequest() {HINTERNET hSession = WinHttpOpen(L"", WINHTTP_ACCESS_TYPE_DEFAULT_PROXY, WINHTTP_NO_PROXY_NAME, WINHTTP_NO_PROXY_BYPASS, 0);if (!hSession) {return false;}//lpszServerName 是IP或者域名LPCWSTR lpszServerName = L"192.168.99.99";//nServerPort 端口INTERNET_PORT nServerPort = 443;HINTERNET hConnect = WinHttpConnect(hSession, lpszServerName, nServerPort, 0);if (!hConnect) {WinHttpCloseHandle(hSession);return false;}HINTERNET hRequest = WinHttpOpenRequest(hConnect, L"GET", L"/Login", NULL, WINHTTP_NO_REFERER, WINHTTP_DEFAULT_ACCEPT_TYPES, WINHTTP_FLAG_SECURE);if (!hRequest) {WinHttpCloseHandle(hConnect);WinHttpCloseHandle(hSession);return false;}BOOL bResult = WinHttpSendRequest(hRequest, WINHTTP_NO_ADDITIONAL_HEADERS, 0, WINHTTP_NO_REQUEST_DATA, 0, 0, 0);if (!bResult && GetLastError() == ERROR_WINHTTP_SECURE_FAILURE) {//忽略所有异常Https CA证书问题// SECURITY_FLAG_IGNORE_ALL_CERT_ERRORS 也可以DWORD dwFlags =SECURITY_FLAG_IGNORE_UNKNOWN_CA |SECURITY_FLAG_IGNORE_CERT_WRONG_USAGE |SECURITY_FLAG_IGNORE_CERT_CN_INVALID |SECURITY_FLAG_IGNORE_CERT_DATE_INVALID;WinHttpSetOption(hRequest, WINHTTP_OPTION_SECURITY_FLAGS, &dwFlags, sizeof(dwFlags));bResult = WinHttpSendRequest(hRequest, WINHTTP_NO_ADDITIONAL_HEADERS, 0, WINHTTP_NO_REQUEST_DATA, 0, 0, 0);}if (!bResult) {WinHttpCloseHandle(hRequest);WinHttpCloseHandle(hConnect);WinHttpCloseHandle(hSession);return false;}bResult = WinHttpReceiveResponse(hRequest, NULL);if (!bResult) {WinHttpCloseHandle(hRequest);WinHttpCloseHandle(hConnect);WinHttpCloseHandle(hSession);return false;}wchar_t szBuff[TRANSFER_SIZE];DWORD dwReadSize;bResult = WinHttpQueryHeaders(hRequest, WINHTTP_QUERY_RAW_HEADERS_CRLF, WINHTTP_HEADER_NAME_BY_INDEX, szBuff, &dwReadSize, WINHTTP_NO_HEADER_INDEX);if (!bResult) {WinHttpCloseHandle(hRequest);WinHttpCloseHandle(hConnect);WinHttpCloseHandle(hSession);return false;}wprintf(L"%ws\n", szBuff);DWORD dwBytesAvailable;bResult = WinHttpQueryDataAvailable(hRequest, &dwBytesAvailable);if (!bResult) {WinHttpCloseHandle(hRequest);WinHttpCloseHandle(hConnect);WinHttpCloseHandle(hSession);return false;}if (dwBytesAvailable > TRANSFER_SIZE) {wprintf(L"Data too long %d /b\n", GetLastError(), dwBytesAvailable);WinHttpCloseHandle(hRequest);WinHttpCloseHandle(hConnect);WinHttpCloseHandle(hSession);return false;}DWORD dwBytesRead;ZeroMemory(szBuff, TRANSFER_SIZE);bResult = WinHttpReadData(hRequest, szBuff, dwBytesAvailable, &dwBytesRead);if (!bResult) {WinHttpCloseHandle(hRequest);WinHttpCloseHandle(hConnect);WinHttpCloseHandle(hSession);return false;}printf("%s\n", szBuff);WinHttpCloseHandle(hRequest);WinHttpCloseHandle(hConnect);WinHttpCloseHandle(hSession);return true;
}int main() {if (PerformHttpRequest()) {return 0;}else {return 1;}
}
WINHTTP使用TLS协议版本
详细很多朋友使用WINHTTP是为了在低版本系统运行比如WIN7或2008这些系统使用TLS 1.0/1.1
无法使用Wininet库的TLS 1.2因此使用WINHTTP下面粘出代码是低版本修改了TLS的库代码
#include <Windows.h>
#include <Winhttp.h>
#include <stdio.h>#pragma comment(lib, "winhttp.lib")#define TRANSFER_SIZE 1024bool PerformHttpRequest() {HINTERNET hSession = WinHttpOpen(L"", WINHTTP_ACCESS_TYPE_DEFAULT_PROXY, WINHTTP_NO_PROXY_NAME, WINHTTP_NO_PROXY_BYPASS, 0);if (!hSession) {return false;}// 设置要使用的协议 TLS 1.1,需要注意服务端也需要支持TLS 1.1否则无法使用DWORD dwFlags = WINHTTP_FLAG_SECURE_PROTOCOL_TLS1_1;if (!WinHttpSetOption(hSession, WINHTTP_OPTION_SECURE_PROTOCOLS, &dwFlags, sizeof(dwFlags))) {WinHttpCloseHandle(hSession);return false;}//lpszServerName 是IP或者域名LPCWSTR lpszServerName = L"192.168.99.99";//nServerPort 端口INTERNET_PORT nServerPort = 443;HINTERNET hConnect = WinHttpConnect(hSession, lpszServerName, nServerPort, 0);if (!hConnect) {WinHttpCloseHandle(hSession);return false;}HINTERNET hRequest = WinHttpOpenRequest(hConnect, L"GET", L"/Login", NULL, WINHTTP_NO_REFERER, WINHTTP_DEFAULT_ACCEPT_TYPES, WINHTTP_FLAG_SECURE);if (!hRequest) {WinHttpCloseHandle(hConnect);WinHttpCloseHandle(hSession);return false;}BOOL bResult = WinHttpSendRequest(hRequest, WINHTTP_NO_ADDITIONAL_HEADERS, 0, WINHTTP_NO_REQUEST_DATA, 0, 0, 0);if (!bResult && GetLastError() == ERROR_WINHTTP_SECURE_FAILURE) {//忽略所有异常Https CA证书问题// SECURITY_FLAG_IGNORE_ALL_CERT_ERRORS 也可以DWORD dwFlags =SECURITY_FLAG_IGNORE_UNKNOWN_CA |SECURITY_FLAG_IGNORE_CERT_WRONG_USAGE |SECURITY_FLAG_IGNORE_CERT_CN_INVALID |SECURITY_FLAG_IGNORE_CERT_DATE_INVALID;WinHttpSetOption(hRequest, WINHTTP_OPTION_SECURITY_FLAGS, &dwFlags, sizeof(dwFlags));bResult = WinHttpSendRequest(hRequest, WINHTTP_NO_ADDITIONAL_HEADERS, 0, WINHTTP_NO_REQUEST_DATA, 0, 0, 0);}if (!bResult) {WinHttpCloseHandle(hRequest);WinHttpCloseHandle(hConnect);WinHttpCloseHandle(hSession);return false;}bResult = WinHttpReceiveResponse(hRequest, NULL);if (!bResult) {WinHttpCloseHandle(hRequest);WinHttpCloseHandle(hConnect);WinHttpCloseHandle(hSession);return false;}wchar_t szBuff[TRANSFER_SIZE];DWORD dwReadSize;bResult = WinHttpQueryHeaders(hRequest, WINHTTP_QUERY_RAW_HEADERS_CRLF, WINHTTP_HEADER_NAME_BY_INDEX, szBuff, &dwReadSize, WINHTTP_NO_HEADER_INDEX);if (!bResult) {WinHttpCloseHandle(hRequest);WinHttpCloseHandle(hConnect);WinHttpCloseHandle(hSession);return false;}wprintf(L"%ws\n", szBuff);DWORD dwBytesAvailable;bResult = WinHttpQueryDataAvailable(hRequest, &dwBytesAvailable);if (!bResult) {WinHttpCloseHandle(hRequest);WinHttpCloseHandle(hConnect);WinHttpCloseHandle(hSession);return false;}if (dwBytesAvailable > TRANSFER_SIZE) {wprintf(L"Data too long %d /b\n", GetLastError(), dwBytesAvailable);WinHttpCloseHandle(hRequest);WinHttpCloseHandle(hConnect);WinHttpCloseHandle(hSession);return false;}DWORD dwBytesRead;ZeroMemory(szBuff, TRANSFER_SIZE);bResult = WinHttpReadData(hRequest, szBuff, dwBytesAvailable, &dwBytesRead);if (!bResult) {WinHttpCloseHandle(hRequest);WinHttpCloseHandle(hConnect);WinHttpCloseHandle(hSession);return false;}printf("%s\n", szBuff);WinHttpCloseHandle(hRequest);WinHttpCloseHandle(hConnect);WinHttpCloseHandle(hSession);return true;
}int main() {if (PerformHttpRequest()) {return 0;}else {return 1;}
}

这篇关于WINHTTP忽略HTTPS证书的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/670926

相关文章

Nginx更新SSL证书的实现步骤

《Nginx更新SSL证书的实现步骤》本文主要介绍了Nginx更新SSL证书的实现步骤,包括下载新证书、备份旧证书、配置新证书、验证配置及遇到问题时的解决方法,感兴趣的了解一下... 目录1 下载最新的SSL证书文件2 备份旧的SSL证书文件3 配置新证书4 验证配置5 遇到的http://www.cppc

Nginx之https证书配置实现

《Nginx之https证书配置实现》本文主要介绍了Nginx之https证书配置的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起... 目录背景介绍为什么不能部署在 IIS 或 NAT 设备上?具体实现证书获取nginx配置扩展结果验证

Python爬虫HTTPS使用requests,httpx,aiohttp实战中的证书异步等问题

《Python爬虫HTTPS使用requests,httpx,aiohttp实战中的证书异步等问题》在爬虫工程里,“HTTPS”是绕不开的话题,HTTPS为传输加密提供保护,同时也给爬虫带来证书校验、... 目录一、核心问题与优先级检查(先问三件事)二、基础示例:requests 与证书处理三、高并发选型:

Linux中的HTTPS协议原理分析

《Linux中的HTTPS协议原理分析》文章解释了HTTPS的必要性:HTTP明文传输易被篡改和劫持,HTTPS通过非对称加密协商对称密钥、CA证书认证和混合加密机制,有效防范中间人攻击,保障通信安全... 目录一、什么是加密和解密?二、为什么需要加密?三、常见的加密方式3.1 对称加密3.2非对称加密四、

在Spring Boot中实现HTTPS加密通信及常见问题排查

《在SpringBoot中实现HTTPS加密通信及常见问题排查》HTTPS是HTTP的安全版本,通过SSL/TLS协议为通讯提供加密、身份验证和数据完整性保护,下面通过本文给大家介绍在SpringB... 目录一、HTTPS核心原理1.加密流程概述2.加密技术组合二、证书体系详解1、证书类型对比2. 证书获

springboot项目如何开启https服务

《springboot项目如何开启https服务》:本文主要介绍springboot项目如何开启https服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录springboot项目开启https服务1. 生成SSL证书密钥库使用keytool生成自签名证书将

Python如何获取域名的SSL证书信息和到期时间

《Python如何获取域名的SSL证书信息和到期时间》在当今互联网时代,SSL证书的重要性不言而喻,它不仅为用户提供了安全的连接,还能提高网站的搜索引擎排名,那我们怎么才能通过Python获取域名的S... 目录了解SSL证书的基本概念使用python库来抓取SSL证书信息安装必要的库编写获取SSL证书信息

Python如何实现读取csv文件时忽略文件的编码格式

《Python如何实现读取csv文件时忽略文件的编码格式》我们再日常读取csv文件的时候经常会发现csv文件的格式有多种,所以这篇文章为大家介绍了Python如何实现读取csv文件时忽略文件的编码格式... 目录1、背景介绍2、库的安装3、核心代码4、完整代码1、背景介绍我们再日常读取csv文件的时候经常

nginx生成自签名SSL证书配置HTTPS的实现

《nginx生成自签名SSL证书配置HTTPS的实现》本文主要介绍在Nginx中生成自签名SSL证书并配置HTTPS,包括安装Nginx、创建证书、配置证书以及测试访问,具有一定的参考价值,感兴趣的可... 目录一、安装nginx二、创建证书三、配置证书并验证四、测试一、安装nginxnginx必须有"-

nginx部署https网站的实现步骤(亲测)

《nginx部署https网站的实现步骤(亲测)》本文详细介绍了使用Nginx在保持与http服务兼容的情况下部署HTTPS,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值... 目录步骤 1:安装 Nginx步骤 2:获取 SSL 证书步骤 3:手动配置 Nginx步骤 4:测