服务器自签名证书过期可以,Boost SSL验证过期和自签名证书

我正在使用Boost的asio通过HTTPS连接到网站.我希望这只有在证书有效,没有过期,没有自签名等情况下才能成功.不幸的是,似乎无论如何总是有效.这是我的代码:

try

{

asio::io_service ioService;

asio::ssl::context sslContext(asio::ssl::context::sslv3_client);

sslContext.load_verify_file("cacert.pem");

asio::ip::tcp::resolver resolver(ioService);

asio::ip::tcp::resolver::query query("self-signed.badssl.com", "443");

asio::ip::tcp::resolver::iterator endpointIterator = resolver.resolve(query);

boost::asio::ssl::stream<:asio::ip::tcp::socket> socket(ioService, sslContext);

ioService.run();

// Enable SSL peer verification.

socket.set_verify_mode(asio::ssl::verify_peer | asio::ssl::verify_fail_if_no_peer_cert);

asio::connect(socket.lowest_layer(), endpointIterator);

socket.handshake(asio::ssl::stream_base::client);

boost::asio::streambuf request;

std::ostream requestStream(&request);

requestStream << "GET / HTTP/1.0\r\n";

requestStream << "Host: self-signed.badssl.com\r\n";

requestStream << "Accept: */*\r\n";

requestStream << "Connection: close\r\n\r\n";

asio::write(socket, request);

等等.如果我使用set_verify_callback()并false从回调中返回,连接确实会失败,但preverified似乎总是如此,即使对于https://self-signed.badssl.com/也是如此.当然那不对?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值