现在的位置: 首页 > 综合 > 正文

今天为了解决编码的问题,整理了一些代码放到这里!

2012年09月14日 ⁄ 综合 ⁄ 共 1679字 ⁄ 字号 评论关闭
我在开放中经常会遇到编码的问题,今天我碰到的就是在英文操作系统下显示乱码的问题,让我头疼了大半天,我在这里整理出来这些代码,希望对你有用,哈哈!上一篇我转了一篇编码的基础知识有兴趣可以看看!

判断是否是GB2132:
int nWSize = MultiByteToWideChar(936,MB_ERR_INVALID_CHARS,strInfo,-1,NULL,0);
        int error = GetLastError();
        if (error == ERROR_NO_UNICODE_TRANSLATION)
        {
            TGLOGFILE(("no GB2312"), (""));
        }
判断是否是UTF8,只要把936用CP_UTF8代替即可.

//转换任何字符集之间的代码,使用方法:
eg: UTF8转到GB2312    CString sResult = Convert(strUtf8, CP_UTF8, 936);

CString Convert(CString str, int sourceCodepage, int targetCodepage)
{
    int len=str.GetLength();

    int unicodeLen=MultiByteToWideChar(sourceCodepage,0,str,-1,NULL,0);

    wchar_t* pUnicode;
    pUnicode=new wchar_t[unicodeLen+1];

    memset(pUnicode,0,(unicodeLen+1)*sizeof(wchar_t));

    MultiByteToWideChar(sourceCodepage,0,str,-1,(LPWSTR)pUnicode,unicodeLen);

    BYTE * pTargetData = NULL;
    int targetLen=WideCharToMultiByte(targetCodepage,0,(LPWSTR)pUnicode,-1,(char *)pTargetData,0,NULL,NULL);

    pTargetData=new BYTE[targetLen+1];
    memset(pTargetData,0,targetLen+1);

    WideCharToMultiByte(targetCodepage,0,(LPWSTR)pUnicode,-1,(char *)pTargetData,targetLen,NULL,NULL);

    CString rt;
    rt.Format("%s",pTargetData);

    delete []pUnicode;
    delete []pTargetData;
    return rt;

}

该方法是固化的一个UTF8toGB2312的一个函数:
CString ConvertUTF8toGB2312(const char *pData, size_t size)
{

    size_t n = MultiByteToWideChar(CP_UTF8, 0, pData, (int)size, NULL, 0);
    WCHAR   *   pChar   =   new   WCHAR[n+1];

    n = MultiByteToWideChar(CP_UTF8, 0, pData, (int)size, pChar, n);
    pChar[n]=0;

    n = WideCharToMultiByte(936, 0, pChar, -1, 0, 0, 0, 0);
    char *p = new char[n+1];

    n = WideCharToMultiByte(936, 0, pChar, -1, p, (int)n, 0, 0);
    CString result(p);

    delete []pChar;
    delete []p;
    return  result;
}

我们需要不断积累和总结,我会把碰到的头疼问题放到这里,希望我不会再问同样问题头疼!

作者:wangweixing2000

抱歉!评论已关闭.