inline static unsigned char char_to_hex( unsigned char x )
{
return (unsigned char)(x > 9 ? x + 55: x + 48);
}
inline static int is_alpha_number_char( unsigned char c )
{
if ( (c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z') || (c >= '0' && c <= '9') )
return 1;
return 0;
}
inline static std::string DecodeUrl(const char *pURL)
{
std::string strDecode;
const char *p = pURL; // 用来循环
/*
临时保存szBuff编码的数据
例如: %1A%2B%3C
*/
char t = '\0';
while (*p != '\0')
{
if (*p == 0x25) // 0x25 = '%'
{
//以下是十六进制数中常出现的大写字母,小写字母,数字的判断
if (p[1] >= 'A' && p[1] <= 'Z') //大写字母
{
t = p[1] - 'A' + 10; //A = 10,下同
}
else if (p[1] >= 'a' && p[1] <= 'z') //小写字母
{
t = p[1] - 'a' + 10;
}
else if (p[1] >= '0' && p[1] <= '9') //数字
{
t = p[1] - '0';
}
t *= 16; // 将数放到十位上去
if (p[2] >= 'A' && p[2] <= 'Z') //大写字母
{
t += p[2] - 'A' + 10;
}
else if (p[2] >= 'a' && p[2] <= 'z') //小写字母
{
t += p[2] - 'a' + 10;
}
else if (p[2] >= '0' && p[2] <= '9') //数字
{
t += p[2] - '0';
}
//到此合成了一个十六进制数
strDecode += t;
p += 3;
}
else
{
//没有被url编码的数据
//'+'特殊处理.它相当于一个空格
if (*p != '+')
{
strDecode += *p;
}
else
{
strDecode += 0x20;
}
p++;
}
}
return strDecode;
}
static void UrlEncode(const unsigned char *src, int src_len, unsigned char *dest, int dest_len)
{
unsigned char ch;
int len = 0;
while (len < (dest_len - 4) && *src)
{
ch = (unsigned char)*src;
if (*src == ' ')
{
*dest++ = '+';
len++;
}
else if (is_alpha_number_char(ch) || strchr("=!~*'()", ch))
{
*dest++ = *src;
len++;
}
else
{
*dest++ = '%';
*dest++ = char_to_hex( (unsigned char)(ch >> 4) );
*dest++ = char_to_hex( (unsigned char)(ch % 16) );
len += 3;
}
++src;
}
*dest = 0;
}
编码是C风格,解码是C++风格,哈哈