tc_parsepara.cpp 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284
  1. /**
  2. * Tencent is pleased to support the open source community by making Tars available.
  3. *
  4. * Copyright (C) 2016THL A29 Limited, a Tencent company. All rights reserved.
  5. *
  6. * Licensed under the BSD 3-Clause License (the "License"); you may not use this file except
  7. * in compliance with the License. You may obtain a copy of the License at
  8. *
  9. * https://opensource.org/licenses/BSD-3-Clause
  10. *
  11. * Unless required by applicable law or agreed to in writing, software distributed
  12. * under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
  13. * CONDITIONS OF ANY KIND, either express or implied. See the License for the
  14. * specific language governing permissions and limitations under the License.
  15. */
  16. #include "util/tc_parsepara.h"
  17. namespace tars
  18. {
  19. #define ENCODE_TABLE "=&%\r\n"
  20. TC_Parsepara::TC_Parsepara(const string &sParam)
  21. {
  22. load(sParam);
  23. }
  24. TC_Parsepara::TC_Parsepara(const map<string, string> &mpParam)
  25. {
  26. load(mpParam);
  27. }
  28. TC_Parsepara::TC_Parsepara(const TC_Parsepara &para)
  29. {
  30. _param = para._param;
  31. }
  32. TC_Parsepara &TC_Parsepara::operator=(const TC_Parsepara &para)
  33. {
  34. if(this != &para)
  35. {
  36. clear();
  37. _param = para._param;
  38. }
  39. return *this;
  40. }
  41. bool TC_Parsepara::operator==(const TC_Parsepara &para)
  42. {
  43. return _param == para._param;
  44. }
  45. const TC_Parsepara TC_Parsepara::operator+(const TC_Parsepara &para)
  46. {
  47. map<string, string> mpParam;
  48. mpParam = _param;
  49. mpParam.insert(para._param.begin(), para._param.end());
  50. return TC_Parsepara(mpParam);
  51. }
  52. TC_Parsepara& TC_Parsepara::operator+=(const TC_Parsepara &para)
  53. {
  54. _param.insert(para._param.begin(), para._param.end());
  55. return *this;
  56. }
  57. TC_Parsepara::~TC_Parsepara()
  58. {
  59. clear();
  60. }
  61. void TC_Parsepara::clear()
  62. {
  63. _param.clear();
  64. }
  65. string TC_Parsepara::encodeMap(const map<string, string> &mpParam) const
  66. {
  67. string sParsepara("");
  68. map<string, string>::const_iterator it = mpParam.begin();
  69. while(it != mpParam.end())
  70. {
  71. sParsepara += encodestr((*it).first) + "=" + encodestr((*it).second);
  72. it++;
  73. if(it != mpParam.end())
  74. {
  75. sParsepara += "&";
  76. }
  77. }
  78. return sParsepara;
  79. }
  80. void TC_Parsepara::decodeMap(const string &sParam, map<string, string> &mpParam) const
  81. {
  82. int iFlag = 0;
  83. char ch1 = '=';
  84. char ch2 = '&';
  85. string sName;
  86. string sValue;
  87. string sBuffer;
  88. if (sParam.length() == 0)
  89. {
  90. mpParam.clear();
  91. return ;
  92. }
  93. string::size_type pos = 0;
  94. while( pos <= sParam.length())
  95. {
  96. if(sParam[pos] == ch1) //中间分隔符,前面读入是name
  97. {
  98. sName = decodestr(sBuffer);
  99. sBuffer = "";
  100. iFlag = 1;
  101. }
  102. else if(sParam[pos] == ch2 || pos == sParam.length()) //结束符,读入的是值
  103. {
  104. sValue = decodestr(sBuffer);
  105. sBuffer = "";
  106. if(sName.length() > 0 && iFlag)
  107. {
  108. mpParam[sName] = decodestr(sValue);
  109. iFlag = 0;
  110. }
  111. }
  112. else
  113. {
  114. sBuffer += sParam[pos];
  115. }
  116. pos++;
  117. }
  118. }
  119. void TC_Parsepara::load(const string &sParam)
  120. {
  121. clear();
  122. decodeMap(sParam, _param);
  123. }
  124. void TC_Parsepara::load(const map<string, string> &mpParam)
  125. {
  126. _param = mpParam;
  127. }
  128. string TC_Parsepara::tostr() const
  129. {
  130. return encodeMap(_param);
  131. }
  132. string &TC_Parsepara::operator[](const string &sName)
  133. {
  134. return _param[sName];
  135. }
  136. string TC_Parsepara::getValue(const string &sName) const
  137. {
  138. string sValue;
  139. map<string, string>::const_iterator it;
  140. if((it = _param.find(sName)) != _param.end())
  141. {
  142. sValue = it->second;
  143. }
  144. return sValue;
  145. }
  146. void TC_Parsepara::setValue(const string &sName, const string &sValue)
  147. {
  148. _param[sName] = sValue;
  149. }
  150. map<string,string> &TC_Parsepara::toMap()
  151. {
  152. return _param;
  153. }
  154. const map<string,string> &TC_Parsepara::toMap() const
  155. {
  156. return _param;
  157. }
  158. void TC_Parsepara::traverse(TC_ParseparaTraverseFunc func,void *pParam)
  159. {
  160. map<string, string>::iterator it = _param.begin();
  161. map<string, string>::iterator itEnd = _param.end();
  162. while(it != itEnd)
  163. {
  164. func(it->first, it->second, pParam);
  165. ++it;
  166. }
  167. }
  168. char TC_Parsepara::x2c(const string &sWhat)
  169. {
  170. register char digit;
  171. if(sWhat.length() < 2)
  172. {
  173. return '\0';
  174. }
  175. digit = (sWhat[0] >= 'A' ? ((sWhat[0] & 0xdf) - 'A')+10 : (sWhat[0] - '0'));
  176. digit *= 16;
  177. digit += (sWhat[1] >= 'A' ? ((sWhat[1] & 0xdf) - 'A')+10 : (sWhat[1] - '0'));
  178. return(digit);
  179. }
  180. string TC_Parsepara::decodestr(const string &sParam)
  181. {
  182. string sBuffer("");
  183. string::size_type pos = 0;
  184. while( pos < sParam.length())
  185. {
  186. if(sParam[pos] == '%')
  187. {
  188. if (pos >= sParam.length() - 2)
  189. {
  190. break;
  191. }
  192. sBuffer += x2c(sParam.substr(pos + 1));
  193. pos += 3;
  194. }
  195. else
  196. {
  197. sBuffer += sParam[pos];
  198. pos++;
  199. }
  200. }
  201. return sBuffer;
  202. }
  203. string TC_Parsepara::encodestr(const string &sParam)
  204. {
  205. string sBuffer("");
  206. static char sHexTable[17] = "0123456789ABCDEF";
  207. string::size_type pos = 0;
  208. while( pos < sParam.length())
  209. {
  210. if(string(ENCODE_TABLE).find_first_of(sParam[pos]) != string::npos)
  211. {
  212. sBuffer += '%';
  213. sBuffer += sHexTable[(sParam[pos]>>4)&0x0f];
  214. sBuffer += sHexTable[sParam[pos]&0x0f];
  215. }
  216. else
  217. {
  218. sBuffer += sParam[pos];
  219. }
  220. pos++;
  221. }
  222. return sBuffer;
  223. }
  224. }