对于url中的一些特殊字符会被转义以利传输, * 并且, 归档服务器上, php写入cookie中的值可能存在特殊字符, 需要转换
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 | /**
*@brief 对于url中的一些特殊字符会被转义以利传输,
* 并且, 归档服务器上, php写入cookie中的值可能存在特殊字符, 需要转换
*
*参考: http://www.blooberry.com/indexdot/html/topics/urlencoding.htm
* http://www.december.com/html/spec/esccodes.html
*
*@param[in,out] data 需要处理的数据, 处理完后, 这个数据会被修改为期待的数据
*@param[in] data_len data中的实际数据长度
*
*/
int escape_url_character(char *data, int data_len)
{
/* 下面只列出来了一些加密用到的字符, 而没有列出所有的字符, 主要是空格, /, +, = */
char *transfer_table[][2] = { {"+", "2B"}, {"[","5B"},{"]","5D"},{"`","60"},{";","3B"},{"/","2F"},{"?","3F"},{":","3A"},{"@","40"},{"=","3D"},{"&","26"},{"$","24"},{" ","20"},{"<","3C"},{">","3E"},{"#","23"},{"%","25"},{"{","7B"},{"}","7D"},{"|","7C"},{"\\","5C"},{"^","5E"},{"~","7E"}, {NULL, NULL} };
int i = 0, j;
char *buf = calloc(data_len + 1, sizeof(char));
while( i < data_len ){
if( '%' != data[i]){
strncat(buf, data+i, 1);
i++;
continue;
}
/* 查表 */
j = 0;
while( NULL != transfer_table[j][1] ){
if( 0 == strncasecmp(data+i+1, transfer_table[j][1], 2 )){
strncat(buf, transfer_table[j][0], 1);
i += 3;
break;
}
j++;
}
/* 对于表中不存在的字符不作处理, 但输出一条日志 */
if( NULL == transfer_table[j][1] ){
strncat(buf, data+i, 1);
printf("escape_url_character: unhandled sequence: %s\n", data+i);
i++;
}
}
memset(data, 0, data_len);
strcpy(data, buf);
free(buf);
return 0;
}
|
Tags: string