acl/app/http_logger/logger_servlet.cpp

61 lines
1.1 KiB
C++
Raw Normal View History

2014-11-19 00:25:21 +08:00
#include "stdafx.h"
#include "logger_servlet.h"
logger_servlet::logger_servlet()
{
}
logger_servlet::~logger_servlet()
{
}
bool logger_servlet::doUnknown(acl::HttpServletRequest&,
acl::HttpServletResponse&)
{
return false;
}
bool logger_servlet::doGet(acl::HttpServletRequest& req,
acl::HttpServletResponse& res)
{
return doPost(req, res);
}
bool logger_servlet::doPost(acl::HttpServletRequest& req,
acl::HttpServletResponse&)
{
const char* uri = req.getRequestUri();
if (uri == NULL || *uri == 0)
{
logger_debug(DEBUG_HTTP, 1, "getRequestUri null");
return false;
}
const char* host = req.getRemoteHost();
if (host == NULL || *host == 0)
{
logger_debug(DEBUG_HTTP, 1, "no Host");
return false;
}
acl::string url;
url.format("http://%s/%s", host, uri);
logger("%s", url.c_str());
int n;
char buf[8192];
acl::http_client* conn = req.getClient();
while (true)
{
n = conn->read_body(buf, sizeof(buf));
if (n < 0)
return false;
else if (n == 0)
break;
}
return true;
}