acl/lib_acl_cpp/samples/ssl/https_client/https_client.cpp

171 lines
3.2 KiB
C++
Raw Normal View History

#include "stdafx.h"
2014-11-19 00:25:21 +08:00
#include <iostream>
#include "util.h"
#include "https_client.h"
#define DEBUG 100
https_client::https_client(const char* server_addr, const char* domain,
bool keep_alive, int count, int length)
: server_addr_(server_addr)
, domain_(domain)
, keep_alive_(keep_alive)
2022-08-26 17:51:41 +08:00
, accept_gzip_(true)
2014-11-19 00:25:21 +08:00
, count_(count)
, length_(length)
2022-08-26 17:51:41 +08:00
, show_body_(false)
2014-11-19 00:25:21 +08:00
, ssl_conf_(NULL)
{
2019-12-20 15:08:36 +08:00
(void) length_;
2014-11-19 00:25:21 +08:00
}
https_client::~https_client()
{
}
2022-08-26 17:51:41 +08:00
void https_client::set_show_body(bool yes)
{
show_body_ = yes;
}
2019-12-20 15:08:36 +08:00
void https_client::set_ssl_conf(acl::sslbase_conf *conf)
2014-11-19 00:25:21 +08:00
{
ssl_conf_ = conf;
}
2022-08-26 17:51:41 +08:00
void https_client::accept_gzip(bool yes)
{
accept_gzip_ = yes;
}
2014-11-19 00:25:21 +08:00
bool https_client::connect_server(acl::http_client& client)
{
logger_debug(DEBUG, 1, "begin connect server");
if (client.open(server_addr_.c_str(), 60, 60, true) == false)
{
logger_error("failed to connect server %s", server_addr_.c_str());
return false;
}
else
logger_debug(DEBUG, 1, "connect server ok");
if (ssl_conf_)
{
logger("begin open ssl");
2014-11-19 00:25:21 +08:00
2020-07-02 15:44:44 +08:00
acl::sslbase_io* ssl = ssl_conf_->create(false);
2022-08-26 17:51:41 +08:00
ssl->set_sni_host(domain_);
2014-11-19 00:25:21 +08:00
if (client.get_stream().setup_hook(ssl) == ssl)
{
logger_error("open ssl client error");
ssl->destroy();
return false;
}
else
logger("open ssl ok");
2014-11-19 00:25:21 +08:00
}
return true;
}
int https_client::http_request(int count)
{
acl::http_client* client = new acl::http_client;
if (connect_server(*client) == false)
{
delete client;
return 0;
}
acl::http_header header;
header.set_url("/")
2022-08-26 17:51:41 +08:00
.accept_gzip(accept_gzip_)
2014-11-19 00:25:21 +08:00
.add_entry("Accept-Languge", "zh-cn,en;q=0.5")
.set_host(domain_.c_str())
.set_keep_alive(keep_alive_);
char buf[8192];
int i = 0;
for (; i < count; i++)
{
if (client->write_head(header) == false)
{
logger_error("write header error");
delete client;
return i;
}
if (client->read_head() == false)
{
logger_error("read header error");
delete client;
return i;
}
while (true)
{
int ret = client->read_body(buf, sizeof(buf) - 1);
if (ret < 0)
{
logger_error("read body error");
delete client;
return i;
}
else if (ret == 0)
break;
2022-08-26 17:51:41 +08:00
if (show_body_)
{
buf[ret] = 0;
printf("[%s]\r\n", buf);
fflush(stdout);
}
2014-11-19 00:25:21 +08:00
}
if (!keep_alive_)
{
delete client;
client = new acl::http_client;
if (connect_server(*client) == false)
{
delete client;
return i;
}
}
else
client->reset();
if (i % 1000 == 0)
{
acl::string tmp;
tmp.format("total: %d, curr: %d", count, i);
ACL_METER_TIME(tmp.c_str());
}
printf("--------------------------------------------\r\n");
2014-11-19 00:25:21 +08:00
}
delete client;
return i;
}
void* https_client::run()
{
struct timeval begin;
gettimeofday(&begin, NULL);
int n = http_request(count_);
if (n != count_)
printf(">>>>SOME TASK NOT COMPLETE!<<<<<\r\n");
struct timeval end;
gettimeofday(&end, NULL);
double spent = util::stamp_sub(&end, &begin);
printf("total: %d, spent: %.2f, speed: %.2f\r\n",
count_, spent, (n * 1000) / (spent > 1 ? spent : 1));
return NULL;
}