下面这段代码用vs2008编译,运行显示的结果是 再来.#include <stdio.h>
#include <stdlib.h>int main(void)
{
char str[3];
str[0]=-44;
str[1]=-39;
str[2]='\0'; printf("%s\n",str);
return 0;
}
url 传输 再来 的编码是 %26%2320877%3B%26%2326469%3B
请问 这个 %26%2320877%3B%26%2326469%3B 如何转换成
str[0]=-44;
str[1]=-39;
str[2]='\0';
#include <stdlib.h>int main(void)
{
char str[3];
str[0]=-44;
str[1]=-39;
str[2]='\0'; printf("%s\n",str);
return 0;
}
url 传输 再来 的编码是 %26%2320877%3B%26%2326469%3B
请问 这个 %26%2320877%3B%26%2326469%3B 如何转换成
str[0]=-44;
str[1]=-39;
str[2]='\0';
你应该:
char str[5]={0};
strcat(str, "再来");
URL解码你在网上可搜到解码工具,如:http://tool.chinaz.com/Tools/URLEncode.aspx
算法需要自找
//-------------------------------------
// URL 编码解码函数
// 陈子逸
//-------------------------------------
#include<stdlib.h>
#include<string.h>
//--------------------------------------
// 正常返回值 0-15,异常返回值 -1.
//--------------------------------------
inline char hextoi(char hexch)
{
if((hexch>='0')&&(hexch<='9'))
return hexch - '0';
else if((hexch>='A')&&(hexch<='F'))
return hexch - 'A' + 10;
else if((hexch>='a')&&(hexch<='f'))
return hexch - 'a' + 10;
else
return -1;
}
//-----------------------------------------------------
// 将 XX 形式的十六进制的数字(ASCII码)转换成字符
//-----------------------------------------------------
char x2c( const char* hex )
{
char digit;
digit = (hextoi(hex[0]));
digit = digit << 4;
digit = digit + hextoi(hex[1]);
return(digit);
}
//-----------------------------------------------------
// 按 URL 编码规则解码
// '+' 替换成 ' ' (空格)
//-----------------------------------------------------
char* plustospace( char* str )
{
int x;
if(str == NULL)
{
return NULL;
}
for( x=0; str[x] ;x++ )
{
if(str[x] == '+')
str[x] = ' ';
}
return( str );
}//-----------------------------------------------------
// 按 URL 编码规则解码
// %XX 转换成字符
// 然后将 + 替换成空格
//-----------------------------------------------------
char* unescape(char* s)
{
int x, y;
if(!s)
{
return NULL;
}int length = strlen(s) - 2;for( x = 0, y = 0; s[y]; ++x, ++y )
{
if( ( s[x] = s[y] ) == '%')
{
s[x] = x2c( &s[y+1] );
y += 2;
}
}
s[x] = '\0';
return plustospace(s);
}
//-------------------------------------------------
// URL 编码, buffer 的长度最好比
const char digit[20]="0123456789ABCDEF";
char* escape(char* buffer, int blen, const char* url)
{
if(!(url && buffer))
{
return NULL;
}
int i = 0;
while((*url)&&(i<blen-1))
{
if( ((*url >'a')&&(*url < 'z'))
|| ((*url >'A')&&(*url <'Z'))
|| ((*url >'0')&&(*url <'9'))
)
{
buffer[i] = *url;
i++;
}
else
{
if(i < blen - 3 )
{
buffer[i] = '%';
i++;
buffer[i] = digit[(*url >> 4) & 0x0f];
i++;
buffer[i] = digit[*url & 0x0f];
i++;
}
}
url ++;
}
buffer[i] = '\0';
return buffer;
}
///---- Test----------------
#include<stdio.h>
void main()
{
char szText[]="%B3%C2%BC%D2%B1%EB";
printf("%s\n",szText);
printf(unescape(szText));
char buffer[40];
escape(buffer,sizeof(buffer),szText);
printf("\n%s\n",buffer);
}
UTF8 编码
20877是 再 的Unicode编码
26469是 来 的Unicode编码VC做这个有点麻烦,需要自己写程序转
%E4%B8%AD%E4%B8%AD%E4%B8%AD%E4%B8%AD
以上是四个汉字 中中中中
char szText[]="%E4%B8%AD%E4%B8%AD%E4%B8%AD%E4%B8%AD";
程序执行后显示不是 中中中中 而是乱码
不过你要自己写也不难
%xx代表一个字
%xx%yy xx代表高16位,yy低16位,两两拼接,不过要符合html编码所有要求的话,要考虑的事情比较多了
如果网页采用 POST 方式,转换后的编码是一样的
URLEncoding()
需要把URL编码转换为UTF8编码就可以了.