add session cache in HttpAppFramework

This commit is contained in:
an-tao 2018-05-09 18:11:56 +08:00
parent dacc5c555e
commit 13218ccee7
2 changed files with 24 additions and 24 deletions

View File

@ -28,11 +28,7 @@ set(CMAKE_MODULE_PATH ${CMAKE_SOURCE_DIR}/cmake_modules/)
find_package (jsoncpp REQUIRED) find_package (jsoncpp REQUIRED)
include_directories(${JSONCPP_INCLUDE_DIRS}) include_directories(${JSONCPP_INCLUDE_DIRS})
link_directories(${JSONCPP_LIBRARY_DIRS}) link_directories(${JSONCPP_LIBRARY_DIRS})
find_package (UUID) find_package (UUID REQUIRED)
if(UUID_FOUND)
add_definitions(-DUSE_UUID)
endif()
find_package(Boost) find_package(Boost)
if(Boost_FOUND) if(Boost_FOUND)

View File

@ -12,9 +12,8 @@
#include <sys/stat.h> #include <sys/stat.h>
#include <iostream> #include <iostream>
#include <fstream> #include <fstream>
#ifdef USE_UUID
#include <uuid/uuid.h> #include <uuid/uuid.h>
#endif
namespace drogon namespace drogon
{ {
@ -29,11 +28,15 @@ namespace drogon
uint16_t _port; uint16_t _port;
void onAsyncRequest(const HttpRequest& req,std::function<void (HttpResponse &)>callback); void onAsyncRequest(const HttpRequest& req,std::function<void (HttpResponse &)>callback);
void readSendFile(const std::string& filePath,const HttpRequest& req, HttpResponse* resp); void readSendFile(const std::string& filePath,const HttpRequest& req, HttpResponse* resp);
#ifdef USE_UUID
//if uuid package found,we can use a uuid string as session id; //if uuid package found,we can use a uuid string as session id;
//set _sessionTimeout=0 to disable location session control based on cookies; //set _sessionTimeout=0 to disable location session control based on cookies;
uint _sessionTimeout=0; uint _sessionTimeout=0;
#endif typedef std::shared_ptr<Session> SessionPtr;
std::unique_ptr<CacheMap<std::string,SessionPtr>> _sessionMapPtr;
bool _enableLastModify=true; bool _enableLastModify=true;
std::set<std::string> _fileTypeSet={"html","jpg"}; std::set<std::string> _fileTypeSet={"html","jpg"};
std::string _rootPath; std::string _rootPath;
@ -41,10 +44,10 @@ namespace drogon
//tool funcs //tool funcs
#ifdef USE_UUID
std::string getUuid(); std::string getUuid();
std::string stringToHex(unsigned char* ptr, long long length); std::string stringToHex(unsigned char* ptr, long long length);
#endif
}; };
} }
@ -63,6 +66,7 @@ void HttpAppFrameworkImpl::run()
trantor::EventLoop loop; trantor::EventLoop loop;
HttpServer httpServer(&loop,InetAddress(_ip,_port),""); HttpServer httpServer(&loop,InetAddress(_ip,_port),"");
httpServer.setHttpAsyncCallback(std::bind(&HttpAppFrameworkImpl::onAsyncRequest,this,_1,_2)); httpServer.setHttpAsyncCallback(std::bind(&HttpAppFrameworkImpl::onAsyncRequest,this,_1,_2));
_sessionMapPtr=std::unique_ptr<CacheMap<std::string,SessionPtr>>(new CacheMap<std::string,SessionPtr>(&loop,1,1200));
httpServer.start(); httpServer.start();
loop.loop(); loop.loop();
} }
@ -91,7 +95,7 @@ void HttpAppFrameworkImpl::onAsyncRequest(const HttpRequest& req,std::function<v
LOG_TRACE << "http path=" << req.path(); LOG_TRACE << "http path=" << req.path();
LOG_TRACE << "query: " << req.query() ; LOG_TRACE << "query: " << req.query() ;
#ifdef USE_UUID
std::string session_id=req.getCookie("JSESSIONID"); std::string session_id=req.getCookie("JSESSIONID");
bool needSetJsessionid=false; bool needSetJsessionid=false;
if(_sessionTimeout>0) if(_sessionTimeout>0)
@ -100,17 +104,17 @@ void HttpAppFrameworkImpl::onAsyncRequest(const HttpRequest& req,std::function<v
{ {
session_id=getUuid().c_str(); session_id=getUuid().c_str();
needSetJsessionid=true; needSetJsessionid=true;
//_sessionMap.insert(session_id,std::make_shared< Session >(),_sessionTimeout); _sessionMapPtr->insert(session_id,std::make_shared< Session >(),_sessionTimeout);
} }
else else
{ {
// if(_sessionMap.find(session_id)==false) if(_sessionMapPtr->find(session_id)==false)
// { {
// _sessionMap.insert(session_id,std::make_shared< Session >(),_sessionTimeout); _sessionMapPtr->insert(session_id,std::make_shared< Session >(),_sessionTimeout);
// } }
} }
} }
#endif
std::string path = req.path().c_str(); std::string path = req.path().c_str();
auto pos = path.rfind("."); auto pos = path.rfind(".");
if(pos != std::string::npos) { if(pos != std::string::npos) {
@ -120,10 +124,10 @@ void HttpAppFrameworkImpl::onAsyncRequest(const HttpRequest& req,std::function<v
LOG_INFO << "file query!"; LOG_INFO << "file query!";
std::string filePath = _rootPath + path; std::string filePath = _rootPath + path;
HttpResponse resp; HttpResponse resp;
#ifdef USE_UUID
if(needSetJsessionid) if(needSetJsessionid)
resp.addCookie("JSESSIONID",session_id); resp.addCookie("JSESSIONID",session_id);
#endif
// pick a Content-Type for the file // pick a Content-Type for the file
if(filetype=="html") resp.setContentTypeCode(CT_TEXT_HTML); if(filetype=="html") resp.setContentTypeCode(CT_TEXT_HTML);
else if(filetype=="js") resp.setContentTypeCode(CT_APPLICATION_X_JAVASCRIPT); else if(filetype=="js") resp.setContentTypeCode(CT_APPLICATION_X_JAVASCRIPT);
@ -198,10 +202,10 @@ void HttpAppFrameworkImpl::onAsyncRequest(const HttpRequest& req,std::function<v
resp.setStatusCode(HttpResponse::k404NotFound); resp.setStatusCode(HttpResponse::k404NotFound);
//resp.setCloseConnection(true); //resp.setCloseConnection(true);
#ifdef USE_UUID
if(needSetJsessionid) if(needSetJsessionid)
resp.addCookie("JSESSIONID",session_id); resp.addCookie("JSESSIONID",session_id);
#endif
callback(resp); callback(resp);
// } // }
@ -263,7 +267,7 @@ void HttpAppFrameworkImpl::readSendFile(const std::string& filePath,const HttpRe
resp->setBody(str); resp->setBody(str);
delete contents; delete contents;
} }
#ifdef USE_UUID
std::string HttpAppFrameworkImpl::getUuid() std::string HttpAppFrameworkImpl::getUuid()
{ {
uuid_t uu; uuid_t uu;
@ -296,7 +300,7 @@ std::string HttpAppFrameworkImpl::stringToHex(unsigned char* ptr, long long leng
} }
return idString; return idString;
} }
#endif