mirror of
https://gitee.com/TarsCloud/TarsCpp.git
synced 2025-01-05 17:42:24 +08:00
The newest update.
tc_cgi.h & tc_cas_queue.h
This commit is contained in:
parent
b76a763b2b
commit
91aee8ad75
@ -14,15 +14,15 @@ namespace tars
|
|||||||
/////////////////////////////////////////////////
|
/////////////////////////////////////////////////
|
||||||
/**
|
/**
|
||||||
* @file tc_cas_queue.h
|
* @file tc_cas_queue.h
|
||||||
* @brief No Lock Threads
|
* @brief Lock-Free Thread
|
||||||
* @brief 线程无锁
|
* @brief 线程无锁
|
||||||
*
|
*
|
||||||
*
|
|
||||||
* @author ruanshudong@qq.com
|
* @author ruanshudong@qq.com
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/////////////////////////////////////////////////
|
/////////////////////////////////////////////////
|
||||||
/**
|
/**
|
||||||
|
* @brief Thread Safe Queue
|
||||||
* @brief 线程安全队列
|
* @brief 线程安全队列
|
||||||
*/
|
*/
|
||||||
template<typename T, typename D = deque<T> >
|
template<typename T, typename D = deque<T> >
|
||||||
@ -36,22 +36,21 @@ public:
|
|||||||
typedef D queue_type;
|
typedef D queue_type;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Get data from the head, if there's no data, throw exception.
|
* @brief Getting data from the head without data throwing exception
|
||||||
* @brief 从头部获取数据, 没有数据抛异常
|
* @brief 从头部获取数据, 没有数据抛出异常
|
||||||
*
|
*
|
||||||
* @param t
|
* @param t
|
||||||
*
|
* @return bool: true, get data ; false, no data
|
||||||
* @return bool:true-> get data successfully, false-> no data
|
|
||||||
* @return bool: true, 获取了数据, false, 无数据
|
* @return bool: true, 获取了数据, false, 无数据
|
||||||
*/
|
*/
|
||||||
T front();
|
T front();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @brief Get data from the head
|
||||||
* @brief 从头部获取数据
|
* @brief 从头部获取数据
|
||||||
*
|
*
|
||||||
* @param t
|
* @param t
|
||||||
*
|
* @return bool: true, get data ; false, no data
|
||||||
* @return bool:true-> get data successfully, false-> no data
|
|
||||||
* @return bool: true, 获取了数据, false, 无数据
|
* @return bool: true, 获取了数据, false, 无数据
|
||||||
*/
|
*/
|
||||||
bool pop_front(T& t);
|
bool pop_front(T& t);
|
||||||
@ -60,13 +59,13 @@ public:
|
|||||||
* @brief Get data from the head
|
* @brief Get data from the head
|
||||||
* @brief 从头部获取数据
|
* @brief 从头部获取数据
|
||||||
*
|
*
|
||||||
* @return bool:true-> get data successfully, false-> no data
|
* @return bool: true, get data ; false, no data
|
||||||
* @return bool: true, 获取了数据, false, 无数据
|
* @return bool: true, 获取了数据, false, 无数据
|
||||||
*/
|
*/
|
||||||
bool pop_front();
|
bool pop_front();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Set data at the bottom of the queue
|
* @brief Put data to the back end of the queue.
|
||||||
* @brief 放数据到队列后端.
|
* @brief 放数据到队列后端.
|
||||||
*
|
*
|
||||||
* @param t
|
* @param t
|
||||||
@ -74,7 +73,7 @@ public:
|
|||||||
void push_back(const T& t);
|
void push_back(const T& t);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief
|
* @brief Put data to the back end of the queue.
|
||||||
* @brief 放数据到队列后端.
|
* @brief 放数据到队列后端.
|
||||||
*
|
*
|
||||||
* @param vt
|
* @param vt
|
||||||
@ -82,6 +81,7 @@ public:
|
|||||||
void push_back(const queue_type &qt);
|
void push_back(const queue_type &qt);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @brief Put data to the front end of the queue.
|
||||||
* @brief 放数据到队列前端.
|
* @brief 放数据到队列前端.
|
||||||
*
|
*
|
||||||
* @param t
|
* @param t
|
||||||
@ -89,6 +89,7 @@ public:
|
|||||||
void push_front(const T& t);
|
void push_front(const T& t);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @brief Put data to the front end of the queue.
|
||||||
* @brief 放数据到队列前端.
|
* @brief 放数据到队列前端.
|
||||||
*
|
*
|
||||||
* @param vt
|
* @param vt
|
||||||
@ -96,29 +97,35 @@ public:
|
|||||||
void push_front(const queue_type &qt);
|
void push_front(const queue_type &qt);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @brief Exchange Data
|
||||||
* @brief 交换数据
|
* @brief 交换数据
|
||||||
*
|
*
|
||||||
* @param q
|
* @param q
|
||||||
|
* @return bool: true, data returned ; false, no data returned
|
||||||
* @return 有数据返回true, 无数据返回false
|
* @return 有数据返回true, 无数据返回false
|
||||||
*/
|
*/
|
||||||
bool swap(queue_type &q);
|
bool swap(queue_type &q);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @brief Size of the Queue
|
||||||
* @brief 队列大小.
|
* @brief 队列大小.
|
||||||
*
|
*
|
||||||
|
* @return size_t the size of the queue
|
||||||
* @return size_t 队列大小
|
* @return size_t 队列大小
|
||||||
*/
|
*/
|
||||||
size_t size() const;
|
size_t size() const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @brief Clear Up the Queue
|
||||||
* @brief 清空队列
|
* @brief 清空队列
|
||||||
*/
|
*/
|
||||||
void clear();
|
void clear();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 是否数据为空.
|
* @brief 是否数据为空.
|
||||||
*
|
* @brief Determine whether the data is null or not.
|
||||||
* @return bool 为空返回true,否则返回false
|
* @return bool 为空返回true,否则返回false
|
||||||
|
* @return bool: true, is null ; false, not null
|
||||||
*/
|
*/
|
||||||
bool empty() const;
|
bool empty() const;
|
||||||
|
|
||||||
@ -131,15 +138,17 @@ protected:
|
|||||||
protected:
|
protected:
|
||||||
/**
|
/**
|
||||||
* 队列
|
* 队列
|
||||||
|
* Queue
|
||||||
*/
|
*/
|
||||||
queue_type _queue;
|
queue_type _queue;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 队列长度
|
* 队列长度
|
||||||
|
* The length of a queue
|
||||||
*/
|
*/
|
||||||
size_t _size;
|
size_t _size;
|
||||||
|
|
||||||
//锁
|
//锁Lock
|
||||||
TC_SpinLock _mutex;
|
TC_SpinLock _mutex;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -29,6 +29,8 @@ namespace tars
|
|||||||
/**
|
/**
|
||||||
* @file tc_cgi.h
|
* @file tc_cgi.h
|
||||||
* @brief CGI处理类
|
* @brief CGI处理类
|
||||||
|
* @brief CGI Processing Class
|
||||||
|
|
||||||
*/
|
*/
|
||||||
/////////////////////////////////////////////////
|
/////////////////////////////////////////////////
|
||||||
class TC_Cgi;
|
class TC_Cgi;
|
||||||
@ -37,6 +39,7 @@ class TC_HttpRequest;
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 配置文件异常类
|
* @brief 配置文件异常类
|
||||||
|
* @brief Profile Exception Class
|
||||||
*/
|
*/
|
||||||
struct TC_Cgi_Exception : public TC_Exception
|
struct TC_Cgi_Exception : public TC_Exception
|
||||||
{
|
{
|
||||||
@ -48,11 +51,14 @@ struct TC_Cgi_Exception : public TC_Exception
|
|||||||
/**
|
/**
|
||||||
* @brief 全局的友元函数,定义该函数,
|
* @brief 全局的友元函数,定义该函数,
|
||||||
* 则可以用TC_Common::tostr对 vector<TC_Cgi_Upload>进行输出操作
|
* 则可以用TC_Common::tostr对 vector<TC_Cgi_Upload>进行输出操作
|
||||||
|
* @brief Global Friend.
|
||||||
|
* By defining this function, you can use TC_Common::tostr to output vector<TC_Cgi_Upload>
|
||||||
*/
|
*/
|
||||||
ostream &operator<<(ostream &os, const TC_Cgi_Upload &tcCgiUpload);
|
ostream &operator<<(ostream &os, const TC_Cgi_Upload &tcCgiUpload);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief cgi上传文件操作,通过该类获取cgi上传的文件信息
|
* @brief cgi上传文件操作,通过该类获取cgi上传的文件信息
|
||||||
|
* @brief CGI Uploaded File Operation, you can get cgi uploaded file info from this class.
|
||||||
*/
|
*/
|
||||||
class TC_Cgi_Upload
|
class TC_Cgi_Upload
|
||||||
{
|
{
|
||||||
@ -61,6 +67,7 @@ public:
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 构造函数
|
* @brief 构造函数
|
||||||
|
* @brief Constructor
|
||||||
*/
|
*/
|
||||||
TC_Cgi_Upload()
|
TC_Cgi_Upload()
|
||||||
:_sFileName("")
|
:_sFileName("")
|
||||||
@ -73,26 +80,30 @@ public:
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 拷贝构造函数.
|
* @brief 拷贝构造函数.
|
||||||
|
* @brief Copy Constructor
|
||||||
*/
|
*/
|
||||||
|
|
||||||
TC_Cgi_Upload(const TC_Cgi_Upload &tcCgiUpload);
|
TC_Cgi_Upload(const TC_Cgi_Upload &tcCgiUpload);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 赋值构造函数
|
* @brief 赋值构造函数
|
||||||
|
* @brief Assignment Constructor
|
||||||
*/
|
*/
|
||||||
TC_Cgi_Upload & operator=(const TC_Cgi_Upload &tcCgiUpload);
|
TC_Cgi_Upload & operator=(const TC_Cgi_Upload &tcCgiUpload);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 获取上传的信息.
|
* @brief 获取上传的信息.
|
||||||
*
|
* @brief Get Uploaded Info
|
||||||
* return 上传文件的信息
|
* @return 上传文件的信息
|
||||||
|
* @return Uploaded File Info
|
||||||
*/
|
*/
|
||||||
string tostr() const;
|
string tostr() const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 获取客户端IE INPUT上传控件的名称.
|
* @brief 获取客户端IE INPUT上传控件的名称.
|
||||||
*
|
* @brief Get the Client IE ; Input the name of the upload control
|
||||||
* return INPUT上传控件名称
|
* @return INPUT上传控件名称
|
||||||
|
* @return INPUT the name of the upload control
|
||||||
*/
|
*/
|
||||||
string getFormFileName() const
|
string getFormFileName() const
|
||||||
{
|
{
|
||||||
@ -101,8 +112,9 @@ public:
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 返回INPUT控件用户输入的名称,及客户端真实的文件名称.
|
* @brief 返回INPUT控件用户输入的名称,及客户端真实的文件名称.
|
||||||
*
|
* @brief Return the name from the imput control and the real file name from the Client.
|
||||||
* return 客户端真实的文件名称
|
* @return 客户端真实的文件名称
|
||||||
|
* @return the real file name from the Client
|
||||||
*/
|
*/
|
||||||
string retRealFileName() const
|
string retRealFileName() const
|
||||||
{
|
{
|
||||||
@ -111,8 +123,9 @@ public:
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 上传到服务器后,服务器端文件名称.
|
* @brief 上传到服务器后,服务器端文件名称.
|
||||||
*
|
* @brief The server file name after uploading to the server.
|
||||||
* return 服务器端文件名称
|
* @return 服务器端文件名称
|
||||||
|
* @return the file name from the Server.
|
||||||
*/
|
*/
|
||||||
string getSeverFileName() const
|
string getSeverFileName() const
|
||||||
{
|
{
|
||||||
@ -121,8 +134,9 @@ public:
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 获取上传的文件大小.
|
* @brief 获取上传的文件大小.
|
||||||
*
|
* @brief Get the size of the uploaded file.
|
||||||
* return size_t类型,上传的文件大小
|
* @return size_t类型,上传的文件大小
|
||||||
|
* @return size_t : the size of the uploaded file
|
||||||
*/
|
*/
|
||||||
size_t getFileSize() const
|
size_t getFileSize() const
|
||||||
{
|
{
|
||||||
@ -131,8 +145,9 @@ public:
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 上传的文件是否超过大小.
|
* @brief 上传的文件是否超过大小.
|
||||||
*
|
* @brief Determine whether the size of the uploaded file is oversize or not.
|
||||||
* return 超过大小返回true,否则返回false
|
* @return 超过大小返回true,否则返回false
|
||||||
|
* @return bool: oversize, true ; not oversize, false
|
||||||
*/
|
*/
|
||||||
bool isOverSize() const
|
bool isOverSize() const
|
||||||
{
|
{
|
||||||
@ -143,26 +158,31 @@ protected:
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* 上传文件,浏览器file控件名称
|
* 上传文件,浏览器file控件名称
|
||||||
|
* Upload files,the name of the file control on the browser.
|
||||||
*/
|
*/
|
||||||
string _sFileName;
|
string _sFileName;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 上传文件真实名称,客户端的文件名称
|
* 上传文件真实名称,客户端的文件名称
|
||||||
|
* the real name of the uploaded file, the name of the file on the Client.
|
||||||
*/
|
*/
|
||||||
string _sRealFileName;
|
string _sRealFileName;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 上传文件服务器端名称
|
* 上传文件服务器端名称
|
||||||
|
* the name of the server which uploaded the file
|
||||||
*/
|
*/
|
||||||
string _sServerFileName;
|
string _sServerFileName;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 上传文件大小,字节数
|
* 上传文件大小,字节数
|
||||||
|
* the size of the uploaded file, Bytes
|
||||||
*/
|
*/
|
||||||
size_t _iSize;
|
size_t _iSize;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 上传文件是否超过大小
|
* 上传文件是否超过大小
|
||||||
|
* whether the uploaded file is oversize or not
|
||||||
*/
|
*/
|
||||||
bool _bOverSize;
|
bool _bOverSize;
|
||||||
|
|
||||||
@ -171,25 +191,29 @@ protected:
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief cgi操作相关类.
|
* @brief cgi操作相关类.
|
||||||
|
* @brief CGI Operation Related Classes
|
||||||
*
|
*
|
||||||
* 主要操作包括:
|
* 主要操作包括:
|
||||||
*
|
* Main includes:
|
||||||
* 1 支持参数解析
|
* 1 支持参数解析
|
||||||
*
|
* 1 Support parameter resolution
|
||||||
* 2 支持cookies解析
|
* 2 支持cookies解析
|
||||||
*
|
* 2 Support cookies resolution
|
||||||
* 3 支持文件上传,设置上传文件的最大个数,文件的最大大小
|
* 3 支持文件上传,设置上传文件的最大个数,文件的最大大小
|
||||||
*
|
* 3 Support file uploading, setting the max number of uploaded files and the max size of a file.
|
||||||
* 4 上传文件时, 需要检查文件是否超过最大大小
|
* 4 上传文件时, 需要检查文件是否超过最大大小
|
||||||
*
|
* 4 When uploading files, you need to check whether the files are oversize or not.
|
||||||
* 5 上传文件时, 需要检查上传文件个数是否限制
|
* 5 上传文件时, 需要检查上传文件个数是否限制
|
||||||
*
|
* 5 When uploading files, you need to check
|
||||||
|
* whether the number of the uploaded files is limited.
|
||||||
* 说明:多个文件同时上传时,浏览器的file控件必须取不同name,否则将无法正确的上传文件
|
* 说明:多个文件同时上传时,浏览器的file控件必须取不同name,否则将无法正确的上传文件
|
||||||
*
|
* Notes : When multiple files are uploaded at the same time,
|
||||||
|
* the browser's file control must take a different name,
|
||||||
|
* otherwise the file will not be uploaded correctly.
|
||||||
* 注意:调用parseCgi解析标准输入,
|
* 注意:调用parseCgi解析标准输入,
|
||||||
*
|
* Atttention : When calling parseCgi to parse the standard input,
|
||||||
* 如果有文件上传需要调用setUpload, 并且需要在parseCgi之前调用
|
* 如果有文件上传需要调用setUpload, 并且需要在parseCgi之前调用
|
||||||
*
|
* setUpload, which is called by the uploaded files, needs to be called before parseCgi.
|
||||||
*/
|
*/
|
||||||
class TC_Cgi
|
class TC_Cgi
|
||||||
{
|
{
|
||||||
@ -197,16 +221,19 @@ public:
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief TC_Cgi构造函数
|
* @brief TC_Cgi构造函数
|
||||||
|
* @brief TC_Cgi Constructor
|
||||||
*/
|
*/
|
||||||
TC_Cgi();
|
TC_Cgi();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 析构函数
|
* @brief 析构函数
|
||||||
|
* @brief Destructor
|
||||||
*/
|
*/
|
||||||
virtual ~TC_Cgi();
|
virtual ~TC_Cgi();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 定义环境变量
|
* @brief 定义环境变量
|
||||||
|
* @brief Define the environment variables
|
||||||
*/
|
*/
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
@ -233,43 +260,59 @@ public:
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 设置上传文件.
|
* @brief 设置上传文件.
|
||||||
|
* @brief Set the uploaded file.
|
||||||
*
|
*
|
||||||
* @param sUploadFilePrefix, 文件前缀(包含路径), 如果有文件上传,则文件保存在以该前缀为名称的路径下
|
* @param sUploadFilePrefix, 文件前缀(包含路径), 如果有文件上传,则文件保存在以该前缀为名称的路径下
|
||||||
* 如果有多个文件上传,则文件名称以次在后面加"_序号"
|
* 如果有多个文件上传,则文件名称以次在后面加"_序号"
|
||||||
|
* The file prefix (includes its path). If a file is uploaded, the file is saved in the path with the prefix as the name.
|
||||||
|
* If more than one file is uploaded, then the file name will be followed by "_ No."
|
||||||
|
*
|
||||||
* @param iMaxUploadFiles 最多上传文件个数,<0:没有限制
|
* @param iMaxUploadFiles 最多上传文件个数,<0:没有限制
|
||||||
|
* Maximum number of uploaded files, if iMaxUploadFiles < 0 : no limit
|
||||||
|
*
|
||||||
* @param iUploadMaxSize 每个文件上传的最大大小(字节)
|
* @param iUploadMaxSize 每个文件上传的最大大小(字节)
|
||||||
|
* Maximum size uploaded per file (Bytes)
|
||||||
*/
|
*/
|
||||||
void setUpload(const string &sUploadFilePrefix, int iMaxUploadFiles = 5, size_t iUploadMaxSize = 1024*1024*10, size_t iMaxContentLength = 1024*1024*10);
|
void setUpload(const string &sUploadFilePrefix, int iMaxUploadFiles = 5, size_t iUploadMaxSize = 1024*1024*10, size_t iMaxContentLength = 1024*1024*10);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 从标准输入解析cgi.
|
* @brief 从标准输入解析cgi.
|
||||||
|
* @brief Analyze CGI from standard input
|
||||||
*/
|
*/
|
||||||
void parseCgi();
|
void parseCgi();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 直接从http请求解析.
|
* @brief 直接从http请求解析.
|
||||||
|
* @brief Request parsing directly from http.
|
||||||
*
|
*
|
||||||
* @param request http请求
|
* @param request http请求
|
||||||
|
* @param request http request
|
||||||
*/
|
*/
|
||||||
void parseCgi(const TC_HttpRequest &request);
|
void parseCgi(const TC_HttpRequest &request);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 获取cgi的url参数multimap.
|
* @brief 获取cgi的url参数multimap.
|
||||||
|
* @brief Get the URL parameter of CGI : Multimap
|
||||||
*
|
*
|
||||||
* @return multimap<string, string> cgi的url参数
|
* @return multimap<string, string> cgi的url参数
|
||||||
|
* @return multimap<string, string> the URL parameter of CGI
|
||||||
*/
|
*/
|
||||||
const multimap<string, string> &getParamMap() const;
|
const multimap<string, string> &getParamMap() const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 获取cgi环境变量map.
|
* @brief 获取cgi环境变量map.
|
||||||
|
* @brief Get CGI environment variable: Map
|
||||||
*
|
*
|
||||||
* @return map<string,string> cgi的环境变量
|
* @return map<string,string> cgi的环境变量
|
||||||
|
* @return map<string,string> the environment variable of CGI
|
||||||
*/
|
*/
|
||||||
map<string, string> getEnvMap() const { return _env; }
|
map<string, string> getEnvMap() const { return _env; }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 获取cgi的参数map, 将multimap转换成map返回
|
* @brief 获取cgi的参数map, 将multimap转换成map返回
|
||||||
* , 对于一个参数名称对应多个参数值的情况, 只取其中一个值.
|
* , 对于一个参数名称对应多个参数值的情况, 只取其中一个值.
|
||||||
|
* @brief Get the CGI parameter, map, and convert Multimap to Map as return.
|
||||||
|
* If a parameter name corresponds to more than one parameter value, only one value is taken.
|
||||||
*
|
*
|
||||||
* @return map<string, string>
|
* @return map<string, string>
|
||||||
*/
|
*/
|
||||||
@ -277,6 +320,7 @@ public:
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 获取cookies的参数map.
|
* @brief 获取cookies的参数map.
|
||||||
|
* @brief Get cookies' parameter : map
|
||||||
*
|
*
|
||||||
* @return map<string, string>
|
* @return map<string, string>
|
||||||
*/
|
*/
|
||||||
@ -284,165 +328,203 @@ public:
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 获取cgi的某个参数.
|
* @brief 获取cgi的某个参数.
|
||||||
|
* @brief Get a certain parameter from CGI
|
||||||
*
|
*
|
||||||
* @param sName 参数名称
|
* @param sName 参数名称 parameter name
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
string &operator[](const string &sName);
|
string &operator[](const string &sName);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 获取cgi的某个参数.
|
* @brief 获取cgi的某个参数.
|
||||||
|
* @brief Get a certain parameter from CGI
|
||||||
*
|
*
|
||||||
* @param sName 参数名称
|
* @param sName 参数名称 parameter name
|
||||||
* @return 参数的值
|
* @return 参数的值 the value of the parameter
|
||||||
*/
|
*/
|
||||||
string getValue(const string& sName) const;
|
string getValue(const string& sName) const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 获取某一名称的参数的多个值.
|
* @brief 获取某一名称的参数的多个值.
|
||||||
|
* @brief Get multiple values of a parameter with a name.
|
||||||
*
|
*
|
||||||
* 用于解析checkbox这类控件的值( 一个参数名,多个参数值)
|
* 用于解析checkbox这类控件的值( 一个参数名,多个参数值)
|
||||||
* @param sName 参数名称
|
* This is used to parse the value of a control such as a checkbox (one parameter name, multiple parameter values)
|
||||||
* @param vtValue 该名称的参数值组成的vector
|
* @param sName 参数名称 / the parameter name
|
||||||
|
* @param vtValue 该名称的参数值组成的vector / vector composed of the parameter value of the name
|
||||||
* @return vector<string>, 该名称的参数值组成的vector
|
* @return vector<string>, 该名称的参数值组成的vector
|
||||||
|
* @return vector<string> vector composed of the parameter value of the name
|
||||||
*/
|
*/
|
||||||
const vector<string> &getMultiValue(const string& sName, vector<string> &vtValue) const;
|
const vector<string> &getMultiValue(const string& sName, vector<string> &vtValue) const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 获取cookie值.
|
* @brief 获取cookie值.
|
||||||
|
* @brief Get the cookie value.
|
||||||
*
|
*
|
||||||
* @param sName cookie名称
|
* @param sName cookie名称 / the name of the cookie
|
||||||
* @return string类型的cookie值
|
* @return string类型的cookie值 / Cookie value of type string
|
||||||
*/
|
*/
|
||||||
string getCookie(const string& sName) const;
|
string getCookie(const string& sName) const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 设置cookie值.
|
* @brief 设置cookie值.
|
||||||
|
* @brief Set cookie value.
|
||||||
*
|
*
|
||||||
* @param sName cookie名称
|
* @param sName cookie名称 / cookie name
|
||||||
* @param sValue cookie值
|
* @param sValue cookie值 / cookie value
|
||||||
* @param sExpires 过期日期
|
* @param sExpires 过期日期 / the expire date
|
||||||
* @param sPath cookie有效路径
|
* @param sPath cookie有效路径 / cookie valid path
|
||||||
* @param sDomain cookie有效域
|
* @param sDomain cookie有效域 / cookie valid domain
|
||||||
* @param bSecure 是否安全(ssl时有效)
|
* @param bSecure 是否安全(ssl时有效) / Whether it is secure (valid in SSL)
|
||||||
* @return 返回字符串,代表cookie值
|
* @return 返回字符串,代表cookie值 / returns a string which representing the cookie value
|
||||||
*/
|
*/
|
||||||
string setCookie(const string &sName, const string &sValue, const string &sExpires="", const string &sPath="/", const string &sDomain = "", bool bSecure = false);
|
string setCookie(const string &sName, const string &sValue, const string &sExpires="", const string &sPath="/", const string &sDomain = "", bool bSecure = false);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 参数链表是否为空.
|
* @brief 参数链表是否为空.
|
||||||
|
* @brief Whether the parameter list is empty.
|
||||||
*
|
*
|
||||||
* @return 参数链表为空返回true,否则返回false
|
* @return 参数链表为空返回true,否则返回false
|
||||||
|
* @return bool : true, the parameter list is empty ; false, the parameter list is not empty
|
||||||
*/
|
*/
|
||||||
bool isParamEmpty() const;
|
bool isParamEmpty() const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 参数是否存在.
|
* @brief 参数是否存在.
|
||||||
|
* Wether the parameter exists or not.
|
||||||
*
|
*
|
||||||
* @param sName 参数名称
|
* @param sName 参数名称 / the parameter name
|
||||||
* @return 存在返回true,否则返回false
|
* @return 存在返回true,否则返回false / if exists retrun true, else return false.
|
||||||
*/
|
*/
|
||||||
bool isParamExist(const string& sName) const;
|
bool isParamExist(const string& sName) const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 上传文件是否超过大小,多个文件上传时,
|
* @brief 上传文件是否超过大小,多个文件上传时,
|
||||||
* 只要有一个文件超过大小,则超过
|
* 只要有一个文件超过大小,则超过
|
||||||
|
* Wheter the size of the uploaded file is scale out.
|
||||||
|
* When uploading multiple files, it is scale out as long as there's one file exceeds the size.
|
||||||
* @return 按照以上标准超过大小的返回true,否则返回false
|
* @return 按照以上标准超过大小的返回true,否则返回false
|
||||||
|
* According to the standard above, if it is oversize, return true, else return false.
|
||||||
*/
|
*/
|
||||||
bool isUploadOverSize() const;
|
bool isUploadOverSize() const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 上传文件是否超过大小,多个文件上传时,
|
* @brief 上传文件是否超过大小,多个文件上传时,
|
||||||
* 只要有一个文件超过大小,则超过
|
* 只要有一个文件超过大小,则超过
|
||||||
|
* Wheter the size of the uploaded file is scale out.
|
||||||
|
* When uploading multiple files, it is scale out as long as there's one file exceeds the size.
|
||||||
* @param vtUploads 返回超过大小的文件名称(浏览器file控件的名称)
|
* @param vtUploads 返回超过大小的文件名称(浏览器file控件的名称)
|
||||||
|
* Returns the name of a file larger than the size (the name of the browser file control)
|
||||||
* @return 按照以上标准超过大小的返回true,否则返回false
|
* @return 按照以上标准超过大小的返回true,否则返回false
|
||||||
|
* According to the standard above, if it is oversize, return true, else return fals.
|
||||||
*/
|
*/
|
||||||
bool isUploadOverSize(vector<TC_Cgi_Upload> &vtUploads) const;
|
bool isUploadOverSize(vector<TC_Cgi_Upload> &vtUploads) const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 是否超过上传文件个数.
|
* @brief 是否超过上传文件个数.
|
||||||
|
* Wheter the number of uploaded files exceeds.
|
||||||
*
|
*
|
||||||
* @return 超过上传个数返回true,否则返回false
|
* @return 超过上传个数返回true,否则返回false
|
||||||
|
* bool : true, the number of the uploaded files exceeds ; false, else
|
||||||
*/
|
*/
|
||||||
bool isOverUploadFiles() const { return _bOverUploadFiles; }
|
bool isOverUploadFiles() const { return _bOverUploadFiles; }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 获取上传文件个数.
|
* @brief 获取上传文件个数.
|
||||||
|
* Get the number of uploaded files
|
||||||
*
|
*
|
||||||
* @return size_t上传文件的个数
|
* @return size_t上传文件的个数
|
||||||
|
* size_t the number of uploaded files
|
||||||
*/
|
*/
|
||||||
size_t getUploadFilesCount() const;
|
size_t getUploadFilesCount() const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 获取上传文件的相关信息
|
* @brief 获取上传文件的相关信息
|
||||||
|
* Get the related info about the uploaded files
|
||||||
*
|
*
|
||||||
* @return map<string,TC_Cgi_Upload>结构中,
|
* @return map<string,TC_Cgi_Upload>结构中,
|
||||||
* 保存文件名和文件相关信息的map
|
* 保存文件名和文件相关信息的map
|
||||||
|
* In the structure map<string,TC_Cgi_Upload>,
|
||||||
|
* the map which stored the file name and the file's related information.
|
||||||
*/
|
*/
|
||||||
const map<string, TC_Cgi_Upload> &getUploadFilesMap() const;
|
const map<string, TC_Cgi_Upload> &getUploadFilesMap() const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 获取环境变量.
|
* @brief 获取环境变量.
|
||||||
|
* Get the environment variables
|
||||||
*
|
*
|
||||||
* @param iEnv 枚举变量
|
* @param iEnv 枚举变量 / Enumerating variables
|
||||||
* @return 环境变量
|
* @return 环境变量 / Environment variables
|
||||||
*/
|
*/
|
||||||
string getCgiEnv(int iEnv);
|
string getCgiEnv(int iEnv);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 获取环境变量.
|
* @brief 获取环境变量.
|
||||||
|
* Get the environment variables
|
||||||
*
|
*
|
||||||
* @param sEnv 环境变量名称
|
* @param sEnv 环境变量名称 / the environment variable name
|
||||||
* @return 环境变量的值
|
* @return 环境变量的值 / the envitonment variable name
|
||||||
*/
|
*/
|
||||||
string getCgiEnv(const string& sEnv);
|
string getCgiEnv(const string& sEnv);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 设置环境变量.
|
* @brief 设置环境变量.
|
||||||
|
* Set environment variales
|
||||||
*
|
*
|
||||||
* @param sName 环境变量名称
|
* @param sName 环境变量名称 / environment variable name
|
||||||
* @param sValue 环境变量的值
|
* @param sValue 环境变量的值 / environment variable value
|
||||||
*/
|
*/
|
||||||
void setCgiEnv(const string &sName, const string &sValue);
|
void setCgiEnv(const string &sName, const string &sValue);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 返回html头,content-type .
|
* @brief 返回html头,content-type .
|
||||||
|
* Return HTML header, content type
|
||||||
*
|
*
|
||||||
* @param sHeader 缺省值为"text/html"
|
* @param sHeader 缺省值为"text/html"
|
||||||
|
* The default value is "text / HTML"
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static string htmlHeader(const string &sHeader = "text/html");
|
static string htmlHeader(const string &sHeader = "text/html");
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief http请求的url解码, %后面的换成字符.
|
* @brief http请求的url解码, %后面的换成字符.
|
||||||
|
* The URL of the HTTP request is decoded and the one after% is replaced with a character.
|
||||||
*
|
*
|
||||||
* @param sUrl http请求url
|
* @param sUrl http请求url / HTTP request URL
|
||||||
* @return 解码后的字符串
|
* @return 解码后的字符串 / the encoded string
|
||||||
*/
|
*/
|
||||||
static string decodeURL(const string &sUrl);
|
static string decodeURL(const string &sUrl);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 对url进行编码, 非数字和字母用%XX代替.
|
* @brief 对url进行编码, 非数字和字母用%XX代替.
|
||||||
|
* Encode the URL with% XX instead of numbers and letters.
|
||||||
*
|
*
|
||||||
* @param sUrl http请求url
|
* @param sUrl http请求url / HTTP request URL
|
||||||
* @return 编码后的url
|
* @return 编码后的url / the encoded string
|
||||||
*/
|
*/
|
||||||
static string encodeURL(const string &sUrl);
|
static string encodeURL(const string &sUrl);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 对源字符串进行HTML编码(<>"&)
|
* @brief 对源字符串进行HTML编码(<>"&)
|
||||||
|
* HTML encoding of the source string (< > "& ').
|
||||||
*
|
*
|
||||||
|
* the source string
|
||||||
* @param src 源字符串
|
* @param src 源字符串
|
||||||
|
*
|
||||||
|
* Whether encoding the 'space' (space, \t, \r\n, \n)
|
||||||
* @param blankEncode 是否对空格也编码(空格, \t, \r\n, \n)
|
* @param blankEncode 是否对空格也编码(空格, \t, \r\n, \n)
|
||||||
|
*
|
||||||
|
* HTML encoded string
|
||||||
* @return HTML编码后的字符串
|
* @return HTML编码后的字符串
|
||||||
*/
|
*/
|
||||||
static string encodeHTML(const string &src, bool blankEncode = false);
|
static string encodeHTML(const string &src, bool blankEncode = false);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 对源字符串进行XML编码(<>"&').
|
* @brief 对源字符串进行XML编码(<>"&').
|
||||||
*
|
* XML encoding of the source string (< > "& ').
|
||||||
* @param src 源字符串
|
* @param src 源字符串 / Source string
|
||||||
* @return XML编码后的字符串
|
* @return XML编码后的字符串 / XML encoded string
|
||||||
*/
|
*/
|
||||||
static string encodeXML(const string &src);
|
static string encodeXML(const string &src);
|
||||||
|
|
||||||
@ -450,13 +532,14 @@ protected:
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 申明,但是不定义,保证这个函数不会被使用
|
* @brief 申明,但是不定义,保证这个函数不会被使用
|
||||||
|
* Declare, but do not define, to ensure that this function will not be used.
|
||||||
*/
|
*/
|
||||||
TC_Cgi &operator=(const TC_Cgi &tcCgi);
|
TC_Cgi &operator=(const TC_Cgi &tcCgi);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief GET method.
|
* @brief GET method.
|
||||||
*
|
*
|
||||||
* @param sBuffer GET的QueryString
|
* @param sBuffer GET的QueryString / the QueryString of GET
|
||||||
* return
|
* return
|
||||||
*/
|
*/
|
||||||
void getGET(string &sBuffer);
|
void getGET(string &sBuffer);
|
||||||
@ -464,60 +547,65 @@ protected:
|
|||||||
/**
|
/**
|
||||||
* @brief POST method.
|
* @brief POST method.
|
||||||
*
|
*
|
||||||
* @param sBuffer POST的QueryString
|
* @param sBuffer POST的QueryString / the QueryString of POST
|
||||||
* return
|
* return
|
||||||
*/
|
*/
|
||||||
void getPOST(string &sBuffer);
|
void getPOST(string &sBuffer);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 解析文件上传.
|
* @brief 解析文件上传.
|
||||||
|
* Parsing file upload
|
||||||
*
|
*
|
||||||
* @param mmpParams [out]输出参数multimap
|
* @param mmpParams [out]输出参数multimap / output multimap
|
||||||
* return
|
* return
|
||||||
*/
|
*/
|
||||||
void parseUpload(multimap<string, string> &mmpParams);
|
void parseUpload(multimap<string, string> &mmpParams);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 解析form数据
|
* @brief 解析form数据
|
||||||
|
* Parsing form data
|
||||||
*/
|
*/
|
||||||
void parseFormData(multimap<string, string> &mmpParams, const string &sBoundary);
|
void parseFormData(multimap<string, string> &mmpParams, const string &sBoundary);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 忽略空行
|
* @brief 忽略空行
|
||||||
|
* Ignore empty lines
|
||||||
*/
|
*/
|
||||||
void ignoreLine();
|
void ignoreLine();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 写文件.
|
* @brief 写文件.
|
||||||
*
|
* Write File
|
||||||
* @param sFileName 文件名称
|
* @param sFileName 文件名称 / file name
|
||||||
* @param sBuffer 要写入的内容
|
* @param sBuffer 要写入的内容 / contents needs to be wrote.
|
||||||
*/
|
*/
|
||||||
bool writeFile(FILE*fp, const string &sFileName, const string &sBuffer, size_t &iTotalWrite);
|
bool writeFile(FILE*fp, const string &sFileName, const string &sBuffer, size_t &iTotalWrite);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 非上传模式下解析.
|
* @brief 非上传模式下解析.
|
||||||
*
|
* Analysis in non upload mode
|
||||||
* @param mmpParams [out]输出参数multimap
|
* @param mmpParams [out]输出参数multimap / output multimap
|
||||||
* @param sBuffer [in]输入QueryString
|
* @param sBuffer [in]输入QueryString / output QueryString
|
||||||
* return
|
* return
|
||||||
*/
|
*/
|
||||||
void parseNormal(multimap<string, string> &mmpParams, const string& sBuffer);
|
void parseNormal(multimap<string, string> &mmpParams, const string& sBuffer);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 解析cookies.
|
* @brief 解析cookies.
|
||||||
|
* Parsing cookies
|
||||||
*
|
*
|
||||||
* @param mpCooies [out]输出cookiesmap
|
* @param mpCooies [out]输出cookiesmap / output mpCookies
|
||||||
* @param sBuffer [in]输入Cookies字符串
|
* @param sBuffer [in]输入Cookies字符串/ input string Cookies
|
||||||
* return
|
* return
|
||||||
*/
|
*/
|
||||||
void parseCookies(map<string, string> &mpCooies, const string& sBuffer);
|
void parseCookies(map<string, string> &mpCooies, const string& sBuffer);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 控制解析cgi input的基本流程.
|
* @brief 控制解析cgi input的基本流程.
|
||||||
|
* Control the basic process of parsing CGI input
|
||||||
*
|
*
|
||||||
* @param mmpParams [out]输出参数 multimap
|
* @param mmpParams [out]输出参数 multimap / output multimap
|
||||||
* @param mpCooies [out]输出cookies
|
* @param mpCooies [out]输出cookies / output multimap
|
||||||
* return
|
* return
|
||||||
*/
|
*/
|
||||||
void readCgiInput(multimap<string, string> &mmpParams, map<string, string> &mpCooies);
|
void readCgiInput(multimap<string, string> &mmpParams, map<string, string> &mpCooies);
|
||||||
@ -531,21 +619,25 @@ protected:
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* 流
|
* 流
|
||||||
|
* Stream
|
||||||
*/
|
*/
|
||||||
istringstream _iss;
|
istringstream _iss;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 读入
|
* 读入
|
||||||
|
* Read in
|
||||||
*/
|
*/
|
||||||
istream *_is;
|
istream *_is;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 环境变量
|
* 环境变量
|
||||||
|
* environmet variable
|
||||||
*/
|
*/
|
||||||
map<string, string> _env;
|
map<string, string> _env;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* cgi参数
|
* cgi参数
|
||||||
|
* CGI parameter
|
||||||
*/
|
*/
|
||||||
multimap<string, string> _mmpParams;
|
multimap<string, string> _mmpParams;
|
||||||
|
|
||||||
@ -556,36 +648,43 @@ protected:
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* 上传文件名称前缀
|
* 上传文件名称前缀
|
||||||
|
* Upload file name prefix
|
||||||
*/
|
*/
|
||||||
string _sUploadFilePrefix;
|
string _sUploadFilePrefix;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 上传文件的最大个数,<0:无限制
|
* 上传文件的最大个数,<0:无限制
|
||||||
|
* Maximum number of uploaded files, < 0: Unlimited
|
||||||
*/
|
*/
|
||||||
int _iMaxUploadFiles;
|
int _iMaxUploadFiles;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 上传文件的最大大小
|
* 上传文件的最大大小
|
||||||
|
* Maximum size of uploaded file
|
||||||
*/
|
*/
|
||||||
size_t _iUploadMaxSize;
|
size_t _iUploadMaxSize;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 是否超过上传文件个数
|
* 是否超过上传文件个数
|
||||||
|
* Whether the number of the uploaded file is exceeded.
|
||||||
*/
|
*/
|
||||||
bool _bOverUploadFiles;
|
bool _bOverUploadFiles;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 最大的content-length
|
* 最大的content-length
|
||||||
|
* the max content-length
|
||||||
*/
|
*/
|
||||||
size_t _iMaxContentLength;
|
size_t _iMaxContentLength;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 是否超过大小,有一个文件超过则超过
|
* 是否超过大小,有一个文件超过则超过
|
||||||
|
* Determine whether the file is oversize or not, as long as one file is oversize that _bUploadFileOverSize is ture
|
||||||
*/
|
*/
|
||||||
bool _bUploadFileOverSize;
|
bool _bUploadFileOverSize;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 上传文件相关信息保存在该map中
|
* 上传文件相关信息保存在该map中
|
||||||
|
* the related infomation about the uploaded files is stored in this map
|
||||||
*/
|
*/
|
||||||
map<string, TC_Cgi_Upload> _mpUpload;
|
map<string, TC_Cgi_Upload> _mpUpload;
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user