用Wininet API读取的Unicode网页内容为乱码

woshishagua 2004-10-17 09:33:02
代码:
hSession = InternetOpen("vb wininet", 1, vbNullString, vbNullString, 0)
hInternet = InternetOpenUrl(hSession, sUrl, vbNullString, 0, IF_NO_CACHE_WRITE, 0)
iResult = InternetReadFile(hInternet, sBuffer, BUFFER_LEN, lReturn)
sData = sBuffer
InternetCloseHandle hInternet
InternetCloseHandle hSession

(sUrl的网页,charset为UTF-8,用IE浏览时,编码选择为Unicode可正常显示中文,选择成GB2312会出现乱码)

现在用上述代码,得到的sData里的中文都是乱码,比如"媒体"会变成"濯掍綋"
即使用StrConv转换也没有:sData = StrConv(sData, vbFromUnicode)

有没有谁知道这是什么原因?
谢谢

...全文
275 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
RedAngel001 2004-11-04
  • 打赏
  • 举报
回复
API返回的可能是ASC码,需要转化一下。
tztz520 2004-11-04
  • 打赏
  • 举报
回复
Private Declare Function InternetOpen Lib "wininet.dll" Alias "InternetOpenA" ( _
ByVal sAgent As String, ByVal lAccessType As Long, _
ByVal sProxyName As String, ByVal sProxyBypass As String, _
ByVal lFlags As Long) As Long
Private Declare Function InternetOpenUrl Lib "wininet.dll" Alias "InternetOpenUrlA" ( _
ByVal hInternetSession As Long, ByVal sUrl As String, _
ByVal sHeaders As String, ByVal lHeadersLength As Long, _
ByVal lFlags As Long, ByVal lContext As Long) As Long
Private Declare Function InternetReadFile Lib "wininet.dll" ( _
ByVal hFile As Long, ByVal sBuffer As String, _
ByVal lNumBytesToRead As Long, _
lNumberOfBytesRead As Long) As Integer
Private Declare Function InternetCloseHandle Lib "wininet.dll" ( _
ByVal hInet As Long) As Integer
Private Const INTERNET_FLAG_NO_CACHE_WRITE = &H4000000
Dim s



Private Function GetUrlFile(stUrl As String) As String
Dim lgInternet As Long, lgSession As Long
Dim stBuf As String * 1024
Dim inRes As Integer
Dim lgRet As Long
Dim stTotal As String
stTotal = vbNullString
lgSession = InternetOpen("VBTagEdit", 1, vbNullString, vbNullString, 0)
If lgSession Then
lgInternet = InternetOpenUrl(lgSession, stUrl, vbNullString, _
0, INTERNET_FLAG_NO_CACHE_WRITE, 0)
If lgInternet Then
Do
inRes = InternetReadFile(lgInternet, stBuf, 1024, lgRet)
If (lgRet = 1024) Then
stTotal = stTotal & stBuf
Else
stTotal = stTotal & StrConv(LeftB$(StrConv(stBuf, vbFromUnicode), lgRet), vbUnicode)
End If
Loop While (lgRet <> 0)
'
End If
inRes = InternetCloseHandle(lgInternet)
End If
GetUrlFile = stTotal
End Function


Private Sub Command1_Click()
Debug.Print GetUrlFile("http://www.163.com")
End Sub
行云边 2004-11-04
  • 打赏
  • 举报
回复
把 UTF-8 转化为 unicode
关于 UTF-8 见:
http://www.linuxfans.org/nuke/modules.php?name=News&file=article&op=view&sid=1749
xiaoyuanzhi 2004-11-04
  • 打赏
  • 举报
回复
up
xiaoyuanzhi 2004-11-03
  • 打赏
  • 举报
回复
歪歪 2004-11-03
  • 打赏
  • 举报
回复
up,偶也遇到这个问题
woshishagua 2004-10-17
  • 打赏
  • 举报
回复
与Buffer的大小没有关系,我用Inet1.OpenURL(..)得到的结果同上面一样
CHKK 2004-10-17
  • 打赏
  • 举报
回复
是不是buffer的大小的问题
莫情莫钱 2004-10-17
  • 打赏
  • 举报
回复
不晓得,帮忙顶

7,763

社区成员

发帖
与我相关
我的任务
社区描述
VB 基础类
社区管理员
  • VB基础类社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧