版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/hfuu1504011020/article/details/88785448
今天在pc客户端传数据(Json格式)给服务端时,在存储到数据库(Mysql)时总是出现乱码现象,使用的是http协议,以及json的解码(后一篇说明),这里我们先说下转码
在vs2008中编码方式有Unicode编码和多字节两种,由于我这里使用的是Unicode编码方式,而在后一篇中在对http的编程中就已经处理了多字节下转utf8格式,直接忽略本节使用即可。
涉及到的几个函数如下
std::string UrlUTF8(char * str);(输入服务端URL地址)
{ void GB2312ToUTF_8(string& pOut,char *pText, int pLen);
void Gb2312ToUnicode(WCHAR* pOut,char *gbBuffer);
void UnicodeToUTF_8(char* pOut,WCHAR* pText); }//转码函数
std::string CHttpClient::UrlUTF8( char * str )
{
string tt;
string dd;
GB2312ToUTF_8(tt,str,strlen(str));
int len=tt.length();
for (int i=0;i<len;i++)
{
if(isalnum((BYTE)tt.at(i))) //判断字符中是否有数组或者英文
{
char tempbuff[2]={0};
sprintf_s(tempbuff,"%c",(BYTE)tt.at(i)); dd.append(tempbuff);
}
else if (isspace((BYTE)tt.at(i)))
{
dd.append("+");
} else
{
char tempbuff[4];
sprintf_s(tempbuff,"%%%X%X",((BYTE)tt.at(i)) >>4,((BYTE)tt.at(i)) %16); dd.append(tempbuff);
}
} return dd;
}
void CHttpClient::GB2312ToUTF_8( string& pOut,char *pText, int pLen )
{
char buf[4];
memset(buf,0,4);
pOut.clear();
int i = 0;
while(i < pLen)
{
//如果是英文直接复制就可以
if( pText[i] >= 0)
{
char asciistr[2]={0};
asciistr[0] = (pText[i++]);
pOut.append(asciistr);
}
else
{
WCHAR pbuffer;
Gb2312ToUnicode(&pbuffer,pText+i);
UnicodeToUTF_8(buf,&pbuffer);
pOut.append(buf);
i += 2;
}
}
return;
}
void CHttpClient::Gb2312ToUnicode( WCHAR* pOut,char *gbBuffer )
{
::MultiByteToWideChar(CP_ACP,MB_PRECOMPOSED,gbBuffer,2,pOut,1);
return;
}
void CHttpClient::UnicodeToUTF_8( char* pOut,WCHAR* pText )
{
// 注意 WCHAR高低字的顺序,低字节在前,高字节在后
char* pchar = (char *)pText; pOut[0] = (0xE0 | ((pchar[1] & 0xF0) >> 4));
pOut[1] = (0x80 | ((pchar[1] & 0x0F) << 2)) + ((pchar[0] & 0xC0) >> 6); pOut[2] = (0x80 | (pchar[0] & 0x3F));
return;
}
基本解释上面也都有了,有兴趣的同学可以学习下,若只是用它,粘贴复制即可用,考虑到这里是使用了http协议下Unicode转utf8的转码,本质来说也没多大区别,只是需要url地址,后面使用自己整合下即可。
后一篇:C++实现http客户端连接服务端及客户端json数据的解析