#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 示例的更多相关文章

  1. asio 广播代码示例

    代码网络收集 修改了一个编译的小问题 客户端 // Client.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include < ...

  2. 一个简单的 openssl 示例

    ////生成一个私钥////$key=openssl_pkey_new();openssl_pkey_export($key,$out);//等于下面写入的内容////将私钥写入一个文件////ope ...

  3. Muduo 网络编程示例之零:前言

    陈硕 (giantchen_AT_gmail)Blog.csdn.net/Solstice Muduo 全系列文章列表: http://blog.csdn.net/Solstice/category/ ...

  4. asio kcp源码分析

    asio kcp代码走读 (1)kcp_client_wrap类 a 提供方法接口如下: send_msg kcp_client_.send_msg(msg); stop //等待工作线程退出 set ...

  5. wazuh官方安装指南(中文译版本)

      安装Wazuh服务器 Wazuh服务器可以安装在任何类型的Unix操作系统上.最常见安装在Linux上.如果可以为您的系统提供自动化脚本,则安装过程会更容易,但是,从源码构建和安装也非常简单. 通 ...

  6. CentOS6.7上安装nginx1.8.0

    主题: CentOS6.7上安装nginx1.8.0 环境准备: 1.gcc-c++ 示例:yum install gcc-c++ 安装:gcc-c++ gcc-c++编译工具 2.PCRE(Perl ...

  7. OpenSSL密码算法库: MD5示例小程序

    OpenSSL http://www.openssl.org/ OpenSSL整个软件包大概可以分成三个主要的功能部分:密码算法库.SSL协议库以及应用程序.OpenSSL 的密码算法库包含多种加密算 ...

  8. openssl AES加密算法API的使用示例

    openssl为用户提供了丰富的指令,同时也提供了供编程调用的API,本文以使用128位aes算法的ecb模式进行加密和解密验证,如下所示 第一种方法,直接使用aes算法提供的api进行调用,代码如下 ...

  9. OpenSSl 加密解密 示例(终于有编程实践了)

    OPenSSl的加密主要有三个重要的函数.看懂下面的代码就基本上知道该如何使用openssL来加密了. 不过注意,要先将libssl.so.1.0和libcrypto.so.1.0文件复制到执行的文件 ...

  10. VC环境下编译OpenSSL(仅仅是个示例,网上还有许多相关文章)

    VC环境OpenSSL安装以及编程过程 SSL就是Secure Sockets Layer,是一种安全套接字协议,详情请参考链接中的介绍. 配置过程中需要生成一些mak文件,这些生成代码用perl脚本 ...

随机推荐

  1. 后端程序员必会的前端知识-05:React

    五. React 1. React 基础 react 是前端三大框架之一 没有 vue 的基础更好,因为两者思想不太一样,不能用 vue 的习惯学习 react 需要有 js 基础,视频 19-58 ...

  2. LIS和LCS算法分析

    LIS(最长上升子序列) 常规的解法就是动态规划. mx[ j ]表示长度为j的上升子序列最小的值a[i]; dp[ i ]表示前i个数的最长上升子序列长度多少. 1 for(int i=1;i< ...

  3. 企业u盘禁止访问如何解锁

    如果您遇到了U盘禁止访问的问题,可能是由于系统设置.安全策略或第三方工具导致的.以下是一些可能的解锁方法,具体的操作可能因具体情况而异: 管理员权限: 确保您有足够的管理员权限来解锁U盘.有时,系统管 ...

  4. C#与数据库访问技术之ExecuteNonQuery方法

    ExecuteNonQuery方法主要用来更新数据. 通常使用它来执行Update.Insert和Delete语句. 该方法返回值意义如下: 对于Update.Insert和Delete语句,返回值为 ...

  5. vulnhub - tornado - wp

    coverY: 0 tornado 信息收集 目标开放了80,22端口. 访问80网页,是默认页面: 目录枚举 用dirsearch没有什么发现,换gobuster发现了一个bluesky目录.访问如 ...

  6. 隐匿自己的c2服务器(一)

    隐匿自己的c2服务器(一) 目录 隐匿自己的c2服务器(一) 服务器设置 安装java环境 启动设置 开启禁ping 微信机器人推送上线信息 ️‍端口特征修改 证书特征修改 流量特征修改 利用cdn加 ...

  7. ASR项目实战-交付过程中遇到的内核崩溃问题

    当前参与交付的语音识别产品服务,算法模块基于经典的Kaldi,算法中的一部分运行在GPU之上. 算法团队采用的是声学模型+语言模型的1-pass方案.这个方案的特点在于,语言模型数据文件(HCLG文件 ...

  8. Python——第二章:查找和判断

    查找.find() s = "你好啊. 我叫周润发" ret = s.find("周润发") # 返回是7,代表该字符串出现在7号位置,从0开始计数 print ...

  9. CentOS 7.3 操作系统 详解安装手册

    CentOS 7.3 操作系统 安装手册 在安装ESPC前(绿盟WAF.IPS等外置日志中心),需要确保已经在计算机中正确安装CentOS 7.3 x86_64(内核版本为3.10.0-514.el7 ...

  10. 利用腾讯快捷登录协议截取 QQ ClientKey / QQKey 实战课程

    本文主要通过利用腾讯网页快捷登录协议来模拟访问并截取已登录 QQ 客户端的Token.Uin.ClientKey.Skey.P_skey等. Step 1. https://ssl.xui.ptlog ...