下面这段代码用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';

解决方案 »

  1.   

    先解码,解码成源数据,再拷贝你往字符串里赋值汉字做法是错误的,虽然结果是对的。
    你应该:
    char str[5]={0};
    strcat(str, "再来");
    URL解码你在网上可搜到解码工具,如:http://tool.chinaz.com/Tools/URLEncode.aspx
    算法需要自找
      

  2.   

    网上找的,你试下:
    //-------------------------------------
    //       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);
    }
      

  3.   

    “url 传输 再来 的编码是 %26%2320877%3B%26%2326469%3B”
    UTF8 编码
      

  4.   

    你的数据解码后是:&#20877;&#26469;
    20877是 再 的Unicode编码
    26469是 来 的Unicode编码VC做这个有点麻烦,需要自己写程序转
      

  5.   


    %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";
    程序执行后显示不是  中中中中 而是乱码
      

  6.   

    非托管c++没有提供现成的函数,.net下有现成的功能,htmldecode(string)
    不过你要自己写也不难
    %xx代表一个字 
    %xx%yy xx代表高16位,yy低16位,两两拼接,不过要符合html编码所有要求的话,要考虑的事情比较多了
      

  7.   

    URL里的"再来"应该是%E5%86%8D%E6%9D%A5吧
      

  8.   

    如果网页采用 GET 方式,汉字的编码,用不同的浏览器编码后不一样 
    如果网页采用 POST 方式,转换后的编码是一样的
      

  9.   

    http://blog.csdn.net/visualeleven/article/details/8121932
    URLEncoding()
      

  10.   

    谢谢大家,此问题已解,
    需要把URL编码转换为UTF8编码就可以了.