html自动判断编码,vc++抓取网页内容(自动判断网页编码防止乱码)

//要引入下面头文件

#include 

CString GetUrlText(CString url){

CInternetSession mySession("aaa",0);//如果不指定aaa(随便的一个字符串)的话debug模式下会报错

CHttpFile* htmlFile=NULL;

CString strLine,strHtml;

TCHAR sRecv[1024];

UINT CodePage=65001;//CP_UTF8:65001 CP_ACP:0

TRY

{

htmlFile=(CHttpFile*)mySession.OpenURL(url);//打开连接

//获取网页编码

while(htmlFile->ReadString(sRecv,1024))

{

//先用UTF8来进行转换,如果html页面编码是gbk或gb2312,转换后中文字符为

//乱码,但英文字符显示正常,我们判断html页码编码,通过寻找英文就可以了

int nBufferSize = MultiByteToWideChar(CP_UTF8, 0, (LPCSTR)sRecv, -1, NULL, 0);

wchar_t *pBuffer = new wchar_t[nBufferSize+1];

memset(pBuffer,0,(nBufferSize+1)*sizeof(wchar_t));

MultiByteToWideChar(CP_UTF8, 0, (LPCSTR)sRecv, -1 , pBuffer, nBufferSize*sizeof(wchar_t));

strHtml=pBuffer;

if (-1!=strHtml.Find(_T("charset=gbk")))

{

CodePage=0;

delete pBuffer;

break;

}

if (-1!=strHtml.Find(_T("charset=GBK")))//http://www.sohu.com

{

CodePage=0;

delete pBuffer;

break;

}

if (-1!=strHtml.Find(_T("charset=gb2312")))

{

CodePage=0;

delete pBuffer;

break;

}

if (-1!=strHtml.Find(_T("charset=GB2312")))

{

CodePage=0;

delete pBuffer;

break;

}

if (-1!=strHtml.Find(_T("charset=utf-8")))

{

CodePage=65001;

delete pBuffer;

break;

}

if (-1!=strHtml.Find(_T("charset=UTF-8")))

{

CodePage=65001;

delete pBuffer;

break;

}

delete pBuffer;

}

strHtml=_T("");

//获取网页源码

htmlFile=(CHttpFile*)mySession.OpenURL(url);//重新打开连接

while(htmlFile->ReadString(sRecv,1024))

{

// 编码转换,可解决中文乱码问题

//gb2312转为unicode,则用CP_ACP

//gbk转为unicode,也用CP_ACP

//utf-8转为unicode,则用CP_UTF8

int nBufferSize = MultiByteToWideChar(CodePage, 0, (LPCSTR)sRecv, -1, NULL, 0);

wchar_t *pBuffer = new wchar_t[nBufferSize+1];

memset(pBuffer,0,(nBufferSize+1)*sizeof(wchar_t));

//gb2312转为unicode,则用CP_ACP

//gbk转为unicode,也用CP_ACP

//utf-8转为unicode,则用CP_UTF8

MultiByteToWideChar(CodePage, 0, (LPCSTR)sRecv, -1 , pBuffer, nBufferSize*sizeof(wchar_t));

strHtml+=pBuffer;

strHtml+="\r\n";

delete pBuffer;

}

htmlFile->Close();

mySession.Close() ;

delete htmlFile;

return strHtml;

}

CATCH (CException, e)

{

TCHAR err[1024];

e->GetErrorMessage(err,1024);

return "";

}

END_CATCH

}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值