int CcmppSocket::UCS2ToByte(char *src, int len)
{
int ret=len;
unsigned char uchTmp = 0;
unsigned char * pchTmp=(unsigned char *)new char[len+1];
memset(pchTmp,0,len+1);
memcpy(pchTmp,src,len);
//高低字节转换
for (int i=0; i<len/2; i++) {
uchTmp = pchTmp[i*2];// 低
pchTmp[i*2] = pchTmp[i*2 + 1]; // 低 = 高
pchTmp[i*2 + 1] = uchTmp;// 高 = 低
}
// 转换成MultiByte形式.
try
{
ret = WideCharToMultiByte(CP_ACP, WC_COMPOSITECHECK, (LPCWSTR)pchTmp, len/2, src, len, NULL, NULL);
}catch(...){}
src[ret]='\0';
delete []pchTmp;
return ret;
}
//当接收的全是中文时能转换,不会出现乱码,而当接收的有中文,英文,数字时就出现乱码,不能完全转换
请高手们赐教!!!!
CSDN里的stevecrisewu(月亮骑士) 告诉我:
用我的这个肯定没有问题int CSms::gsmDecodeUcs2(const unsigned char *pSrc, char *pDst, int nSrcLength)
{
int nDstLength; // UNICODE宽字符数目
WCHAR wchar[128]; // UNICODE串缓冲区
// 高低字节对调,拼成UNICODE
for(int i=0; i<nSrcLength/2; i++)
{
// 先高位字节
wchar[i] = *pSrc++ << 8;
// 后低位字节
wchar[i] |= *pSrc++;
}
// UNICODE串-->字符串
nDstLength = ::WideCharToMultiByte(CP_ACP, 0, wchar, nSrcLength/2, pDst, 160, NULL, NULL);
// 输出字符串加个结束符
pDst[nDstLength] = '\0';
// 返回目标字符串长度
return nDstLength;
}// UCS2编码
// pSrc: 源字符串指针
// pDst: 目标编码串指针
// nSrcLength: 源字符串长度
// 返回: 目标编码串长度
int CSms::gsmEncodeUcs2(const char *pSrc, unsigned char *pDst, int nSrcLength)
{
int nDstLength; // UNICODE宽字符数目
WCHAR wchar[128]; // UNICODE串缓冲区
// 字符串-->UNICODE串
nDstLength = ::MultiByteToWideChar(CP_ACP, 0, pSrc, nSrcLength, wchar, 128);
// 高低字节对调,输出
for(int i=0; i<nDstLength; i++)
{
// 先输出高位字节
*pDst++ = wchar[i] >> 8;
// 后输出低位字节
*pDst++ = wchar[i] & 0xff;
}
// 返回目标编码串长度
return nDstLength * 2;
}接收时候你要注意传递正确的数据长度,因为英文,数字转换到UCS2编码后会出现00,不能用strlen来判断字符串长度
我试了gsmDecodeUcs2(const unsigned char *pSrc, char *pDst, int nSrcLength)还是没用
是不是要先UCS2编码在UCS2解码
还是其它的方法
{
int ret=len;
unsigned char uchTmp = 0;
unsigned char * pchTmp=(unsigned char *)new char[len+1];
memset(pchTmp,0,len+1);
memcpy(pchTmp,src,len);
//高低字节转换
for (int i=0; i<len/2; i++) {
uchTmp = pchTmp[i*2];// 低
pchTmp[i*2] = pchTmp[i*2 + 1]; // 低 = 高
pchTmp[i*2 + 1] = uchTmp;// 高 = 低
}
// 转换成MultiByte形式.
try
{
ret = WideCharToMultiByte(CP_ACP, WC_COMPOSITECHECK, (LPCWSTR)pchTmp, len/2, src, len, NULL, NULL);
}catch(...){}
src[ret]='\0';
delete []pchTmp;
return ret;
}
//当接收的全是中文时能转换,不会出现乱码,而当接收的有中文,英文,数字时就出现乱码,不能完全转换
请高手们赐教!!!!
CSDN里的stevecrisewu(月亮骑士) 告诉我:
用我的这个肯定没有问题int CSms::gsmDecodeUcs2(const unsigned char *pSrc, char *pDst, int nSrcLength)
{
int nDstLength; // UNICODE宽字符数目
WCHAR wchar[128]; // UNICODE串缓冲区
// 高低字节对调,拼成UNICODE
for(int i=0; i<nSrcLength/2; i++)
{
// 先高位字节
wchar[i] = *pSrc++ << 8;
// 后低位字节
wchar[i] |= *pSrc++;
}
// UNICODE串-->字符串
nDstLength = ::WideCharToMultiByte(CP_ACP, 0, wchar, nSrcLength/2, pDst, 160, NULL, NULL);
// 输出字符串加个结束符
pDst[nDstLength] = '\0';
// 返回目标字符串长度
return nDstLength;
}// UCS2编码
// pSrc: 源字符串指针
// pDst: 目标编码串指针
// nSrcLength: 源字符串长度
// 返回: 目标编码串长度
int CSms::gsmEncodeUcs2(const char *pSrc, unsigned char *pDst, int nSrcLength)
{
int nDstLength; // UNICODE宽字符数目
WCHAR wchar[128]; // UNICODE串缓冲区
// 字符串-->UNICODE串
nDstLength = ::MultiByteToWideChar(CP_ACP, 0, pSrc, nSrcLength, wchar, 128);
// 高低字节对调,输出
for(int i=0; i<nDstLength; i++)
{
// 先输出高位字节
*pDst++ = wchar[i] >> 8;
// 后输出低位字节
*pDst++ = wchar[i] & 0xff;
}
// 返回目标编码串长度
return nDstLength * 2;
}接收时候你要注意传递正确的数据长度,因为英文,数字转换到UCS2编码后会出现00,不能用strlen来判断字符串长度
我试了gsmDecodeUcs2(const unsigned char *pSrc, char *pDst, int nSrcLength)还是没用
是不是要先UCS2编码在UCS2解码
还是其它的方法
1.DSC=8 才需要转换USC2码
2.DSC=0,4 等 全英文数字,要按ASCII码转换