forked from acl-dev/acl
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathurl_coder.hpp
116 lines (97 loc) · 2.52 KB
/
url_coder.hpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
#pragma once
#include "acl_cpp/acl_cpp_define.hpp"
#include <vector>
namespace acl {
class string;
struct URL_NV
{
char* name;
char* value;
};
class ACL_CPP_API url_coder
{
public:
/**
* 构造函数
* @param nocase {bool} 当为 true 时表示参数名不区别大小写
*/
url_coder(bool nocase = true);
/**
* 构造函数,通过类实例对象构造
* @param coder {const url_coder&}
*/
url_coder(const url_coder& coder);
~url_coder();
/**
* 将存储于 params_ 数组中的数据进行 url 编码
* @param buf {string&} 存储编码后的结果
* @param clean {bool} 是否清空传入的 buf 缓冲区
*/
void encode(string& buf, bool clean = true) const;
/**
* 获得将数组对象转换为编码后的字符串对象
* @return {const string&}
*/
const string& to_string() const;
/**
* 解析以 URL 编码的字符串
* @param str {const char*} url 编码形式的字符串
*/
void decode(const char* str);
/**
* 采用 url 编码时,调用此函数添加变量
* @param name {const char*} 变量名
* @param value 变量值
* @param override {bool} 如果存在同名变量是否直接覆盖
* @return 返回 url_coder 对象的引用
*/
url_coder& set(const char* name, const char* value,
bool override = true);
url_coder& set(const char* name, int value, bool override = true);
url_coder& set(const char* name, bool override, const char* fmt, ...)
ACL_CPP_PRINTF(4, 5);
url_coder& set(const char* name, const char* fmt, va_list ap,
bool override = true);
/**
* 获得 URL 解码后 params_ 数组中某个变量名的值
* @param name {const char*} 变量名
* @return {const char*} 返回 NULL 表示不存在
*/
const char* get(const char* name) const;
/**
* 获得 URL 解码后 params_ 数组中某个变量名的值
* @param name {const char*} 变量名
* @return {const char*} 返回 NULL 表示不存在
*/
const char* operator[](const char* name) const;
/**
* URL 编码器对象的拷贝
* @param coder {const url_coder&} URL 源编码器对象
* @return {const url_coder&}
*/
const url_coder& operator =(const url_coder& coder);
/**
* 获得参数数组对象
* @return {std::vector<URL_NV*>&}
*/
const std::vector<URL_NV*>& get_params() const
{
return params_;
}
/**
* 从 params_ 参数数组中删除某个变量
* @param name {const char*} 变量名
* @return {bool} 返回 true 表示删除成功,否则表示不存在
*/
bool del(const char* name);
/**
* 重置解析器状态,清除内部缓存
*/
void reset();
private:
bool nocase_;
std::vector<URL_NV*> params_;
string* buf_;
void free_param(URL_NV*);
};
} // namespace acl end