asio 使用 openssl 示例
#include <boost/asio.hpp>
#include <boost/asio/ssl.hpp>
#include <boost/algorithm/string.hpp>
#include <boost/lexical_cast.hpp>
#define OPENSSL_NO_DEPRECATED
#include <openssl/ssl.h>
#include <wincrypt.h>
#pragma comment(lib, "Crypt32.lib")
#include <iostream>
#include <fstream>
#include <string_view>
void fail(const char* what, const boost::system::error_code& ec) {
std::cout << what << ": " << ec.message() << std::endl;
}
namespace asio = boost::asio;
using tcp = asio::ip::tcp;
int add_ca(asio::ssl::context& ssl_ctx, boost::system::error_code& ec)
{
BIO* bio = BIO_new_fp(stdout, BIO_NOCLOSE);
if (!bio) {
return -1;
}
auto cert_store = CertOpenSystemStore(NULL, L"ROOT");
if (!cert_store) {
return -1;
}
const unsigned char* encoded_cert = nullptr;
int i = 0;
for (PCCERT_CONTEXT cert = nullptr; cert = CertEnumCertificatesInStore(cert_store, cert);) {
X509* x = d2i_X509(NULL, (const unsigned char**)&cert->pbCertEncoded, cert->cbCertEncoded);
if (x) {
BIO* bio_mem = BIO_new(BIO_s_mem());
PEM_write_bio_X509(bio_mem, x);
const char* data = nullptr;
auto len = BIO_get_mem_data(bio_mem, &data);
ssl_ctx.add_certificate_authority(asio::buffer(data, len), ec);
BIO_free(bio_mem);
if (ec) {
return -1;
}
}
++i;
}
BIO_printf(bio, "cert sum: %d\n", i);
CertCloseStore(cert_store, CERT_CLOSE_STORE_FORCE_FLAG);
return 0;
}
int main()
{
boost::system::error_code ec;
asio::io_context io_ctx;
tcp::resolver resolver(io_ctx);
auto results = resolver.resolve("www.baidu.com", "https", ec);
if (ec) {
fail("resolver.resolve", ec);
return -1;
}
asio::ssl::context ssl_ctx(asio::ssl::context::method::sslv23_client);
add_ca(ssl_ctx, ec);
if (ec) {
fail("add_ca", ec);
return -1;
}
asio::ssl::stream<tcp::socket> s(io_ctx, ssl_ctx);
s.set_verify_mode(asio::ssl::verify_peer | asio::ssl::verify_client_once);
asio::connect(s.lowest_layer(), results, ec);
if (ec) {
fail("asio::connect", ec);
return -1;
}
s.handshake(s.client, ec);
if (ec) {
fail("s.handshake", ec);
return -1;
}
const char* req = "GET / HTTP/1.1\r\nHost: www.baidu.com\r\nAccept: text/html\r\n\r\n";
asio::write(s, asio::buffer(req, std::strlen(req)), ec);
if (ec) {
fail("asio::write", ec);
return -1;
}
// Header
asio::streambuf streambuf;
std::size_t content_length = 0;
constexpr std::string_view delimiter = "\r\n";
constexpr std::string_view header_name = "Content-Length";
while (true) {
std::size_t len = asio::read_until(s, streambuf, delimiter, ec);
if (ec) {
fail("asio::read_until", ec);
return -1;
}
std::string_view header(asio::buffer_cast<const char*>(streambuf.data()), len - delimiter.size());
std::cout << header << std::endl;
if (!header.empty()) {
if (boost::algorithm::istarts_with(header, header_name)) {
bool has_optional_space = header[header_name.size() + 1] == ' ';
std::string_view header_value(header.cbegin() + header_name.size() + 1 + has_optional_space, header.cend());
content_length = boost::lexical_cast<std::size_t>(header_value);
}
}
streambuf.consume(len);
if (header.empty()) {
break;
}
}
// Body
std::cout << "content_length: " << content_length << std::endl;
std::size_t len = asio::read(s, streambuf.prepare(content_length - streambuf.size()), ec);
if (ec) {
fail("asio::read", ec);
return -1;
}
streambuf.commit(len);
std::string_view body(asio::buffer_cast<const char*>(streambuf.data()), streambuf.size());
std::system("chcp 65001");
std::cout << body;
streambuf.consume(streambuf.size());
s.shutdown(ec);
if (ec) {
fail("s.shutdown", ec);
return -1;
}
s.lowest_layer().shutdown(tcp::socket::shutdown_both, ec);
if (ec) {
fail("s.lowest_layer().shutdown", ec);
return -1;
}
return 0;
}
asio 使用 openssl 示例的更多相关文章
- asio 广播代码示例
代码网络收集 修改了一个编译的小问题 客户端 // Client.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include < ...
- 一个简单的 openssl 示例
////生成一个私钥////$key=openssl_pkey_new();openssl_pkey_export($key,$out);//等于下面写入的内容////将私钥写入一个文件////ope ...
- Muduo 网络编程示例之零:前言
陈硕 (giantchen_AT_gmail)Blog.csdn.net/Solstice Muduo 全系列文章列表: http://blog.csdn.net/Solstice/category/ ...
- asio kcp源码分析
asio kcp代码走读 (1)kcp_client_wrap类 a 提供方法接口如下: send_msg kcp_client_.send_msg(msg); stop //等待工作线程退出 set ...
- wazuh官方安装指南(中文译版本)
安装Wazuh服务器 Wazuh服务器可以安装在任何类型的Unix操作系统上.最常见安装在Linux上.如果可以为您的系统提供自动化脚本,则安装过程会更容易,但是,从源码构建和安装也非常简单. 通 ...
- CentOS6.7上安装nginx1.8.0
主题: CentOS6.7上安装nginx1.8.0 环境准备: 1.gcc-c++ 示例:yum install gcc-c++ 安装:gcc-c++ gcc-c++编译工具 2.PCRE(Perl ...
- OpenSSL密码算法库: MD5示例小程序
OpenSSL http://www.openssl.org/ OpenSSL整个软件包大概可以分成三个主要的功能部分:密码算法库.SSL协议库以及应用程序.OpenSSL 的密码算法库包含多种加密算 ...
- openssl AES加密算法API的使用示例
openssl为用户提供了丰富的指令,同时也提供了供编程调用的API,本文以使用128位aes算法的ecb模式进行加密和解密验证,如下所示 第一种方法,直接使用aes算法提供的api进行调用,代码如下 ...
- OpenSSl 加密解密 示例(终于有编程实践了)
OPenSSl的加密主要有三个重要的函数.看懂下面的代码就基本上知道该如何使用openssL来加密了. 不过注意,要先将libssl.so.1.0和libcrypto.so.1.0文件复制到执行的文件 ...
- VC环境下编译OpenSSL(仅仅是个示例,网上还有许多相关文章)
VC环境OpenSSL安装以及编程过程 SSL就是Secure Sockets Layer,是一种安全套接字协议,详情请参考链接中的介绍. 配置过程中需要生成一些mak文件,这些生成代码用perl脚本 ...
随机推荐
- 后端程序员必会的前端知识-05:React
五. React 1. React 基础 react 是前端三大框架之一 没有 vue 的基础更好,因为两者思想不太一样,不能用 vue 的习惯学习 react 需要有 js 基础,视频 19-58 ...
- LIS和LCS算法分析
LIS(最长上升子序列) 常规的解法就是动态规划. mx[ j ]表示长度为j的上升子序列最小的值a[i]; dp[ i ]表示前i个数的最长上升子序列长度多少. 1 for(int i=1;i< ...
- 企业u盘禁止访问如何解锁
如果您遇到了U盘禁止访问的问题,可能是由于系统设置.安全策略或第三方工具导致的.以下是一些可能的解锁方法,具体的操作可能因具体情况而异: 管理员权限: 确保您有足够的管理员权限来解锁U盘.有时,系统管 ...
- C#与数据库访问技术之ExecuteNonQuery方法
ExecuteNonQuery方法主要用来更新数据. 通常使用它来执行Update.Insert和Delete语句. 该方法返回值意义如下: 对于Update.Insert和Delete语句,返回值为 ...
- vulnhub - tornado - wp
coverY: 0 tornado 信息收集 目标开放了80,22端口. 访问80网页,是默认页面: 目录枚举 用dirsearch没有什么发现,换gobuster发现了一个bluesky目录.访问如 ...
- 隐匿自己的c2服务器(一)
隐匿自己的c2服务器(一) 目录 隐匿自己的c2服务器(一) 服务器设置 安装java环境 启动设置 开启禁ping 微信机器人推送上线信息 ️端口特征修改 证书特征修改 流量特征修改 利用cdn加 ...
- ASR项目实战-交付过程中遇到的内核崩溃问题
当前参与交付的语音识别产品服务,算法模块基于经典的Kaldi,算法中的一部分运行在GPU之上. 算法团队采用的是声学模型+语言模型的1-pass方案.这个方案的特点在于,语言模型数据文件(HCLG文件 ...
- Python——第二章:查找和判断
查找.find() s = "你好啊. 我叫周润发" ret = s.find("周润发") # 返回是7,代表该字符串出现在7号位置,从0开始计数 print ...
- CentOS 7.3 操作系统 详解安装手册
CentOS 7.3 操作系统 安装手册 在安装ESPC前(绿盟WAF.IPS等外置日志中心),需要确保已经在计算机中正确安装CentOS 7.3 x86_64(内核版本为3.10.0-514.el7 ...
- 利用腾讯快捷登录协议截取 QQ ClientKey / QQKey 实战课程
本文主要通过利用腾讯网页快捷登录协议来模拟访问并截取已登录 QQ 客户端的Token.Uin.ClientKey.Skey.P_skey等. Step 1. https://ssl.xui.ptlog ...