VS2008中Unicode编码转UTF-8编码

今天在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>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数据的解析

链接:https://mp.csdn.net/postedit/88785532

你可能感兴趣的:(Unicode编码转utf8,C++)