C++处理URL的方法,项目有用到,过程记录如下

来源:互联网 发布:双拼域名.com 编辑:程序博客网 时间:2024/06/10 12:32
由于这块需要转换成unicode码,也就是将字符串传换成unicode码,因此需要对输入的字符串做处理,同时又分两种情况,中文 非中文的处理,要区别对待,首先要对输入的字符串进行识别:
int 是不是中文(char *str){char ch;while (1){ch = *str++;if (ch == 0){break;}if (ch&0x80){if (*str & 0x80){return true;}}else{return false;}}return 0;}




然后要进行相应转换

//--------------------------------------------------------------------- 
//函数:W2C
//功能:将16位wchar_t转换为 8位char[2]
//参数:w_cn为待转换的16位字符,c_cn[]为转换后的8位字符
//备注:wchar_t的高位字节应该存储在char数组的低位字节
//作者:xxxx
//---------------------------------------------------------------------

void W2C(wchar_t w_cn , char c_cn[]){c_cn[0] = w_cn >> 8 ;c_cn[1] = (char)w_cn ;}



然后主体转换代码:

//-------------------------------------------------------------------
//函数:ToHex
//功能:将16位字符串转换为十六进制字符串
//参数:待转换的字符串,字符串长度
//返回值:转换后的字符串
//作者:xxxx
//-------------------------------------------------------------------

CString ToHex(CString Data, long nDataLength){CString sResult;for (long nLoop=0; nLoop<nDataLength; nLoop++){wchar_t ch = Data.GetAt(nLoop);CHAR buff[MAX_PATH] = {0};LPCWSTR str = &ch;WideCharToMultiByte(CP_ACP, 0, (LPCWSTR)str, -1, buff, MAX_PATH, 0, 0);if (IncludeChinese(buff)){char c_cn[2]={'0'};W2C(ch,c_cn);static const char *hex = "0123456789ABCDEF";for(int i=0;i<2;i++){unsigned char chHexA = hex[((unsigned char)(c_cn[i]) >> 4) & 0x0f];unsigned char chHexB = hex[(unsigned char)(c_cn[i]) & 0x0f];sResult += (char)chHexA;sResult += (char)chHexB;}}else{sResult += ch;}}return sResult;}

到这里基本上结束了~也查看了一些资料,虽说这个功能简单,但是过程有点曲折。但总算完成了,留个纪念吧~希望对其他人有帮助~

0 0
原创粉丝点击