VB中UTF8转Unicode编码

 
 
  1. PrivateDeclareFunctionMultiBytetoWideCharLib"kernel32"(ByValCodePageAsLong,ByValdwFlagsAsLong,ByReflpMultiByteStrAsAny,ByValcchMultiByteAsLong,ByVallpWideCharStrAsLong,ByValcchWideCharAsLong)AsLong
  2. PrivateConstCP_UTF8=65001
  3. 'Purpose:ConvertUtf8toUnicode
  4. PublicFunctionUTF8_Decode(ByValsUTF8AsString)AsString
  5. DimlngUtf8SizeAsLong
  6. DimstrBufferAsString
  7. DimlngBufferSizeAsLong
  8. DimlngResultAsLong
  9. DimbytUtf8()AsByte
  10. DimnAsLong
  11. IfLenB(sUTF8)=0ThenExitFunction
  12. OnErrorGoToEndFunction
  13. bytUtf8=StrConv(sUTF8,vbFromUnicode)
  14. lngUtf8Size=UBound(bytUtf8)+1
  15. OnErrorGoTo0
  16. lngBufferSize=lngUtf8Size*2
  17. strBuffer=String$(lngBufferSize,vbNullChar)
  18. 'Translateusingcodepage65001(UTF-8)
  19. lngResult=MultiBytetoWideChar(CP_UTF8,bytUtf8(0),_
  20. lngUtf8Size,StrPtr(strBuffer),lngBufferSize)
  21. 'Trimresulttoactuallength
  22. IflngResultThen
  23. UTF8_Decode=Left$(strBuffer,lngResult)
  24. EndIf
  25. EndFunction

把你上面获取内容转一下就行,比如Text1.Text=UTF8_Decode(strResponse) 还可以加多一句InStr(1,strResponse,"charset=utf-8") > 0判断是否是UTF8编码再执行,不是UTF8的就直接显示。 还有些网页编码那里是大写的,要这样写InStr(1,"charset=UTF-8") > 0

相关文章

Format[$] ( expr [ , fmt ] ) format 返回变体型 format$ 强...
VB6或者ASP 格式化时间为 MM/dd/yyyy 格式,竟然没有好的办...
在项目中添加如下代码:新建窗口来显示异常信息。 Namespace...
转了这一篇文章,原来一直想用C#做k3的插件开发,vb没有C#用...
Sub 分列() ‘以空格为分隔符,连续空格只算1个。对所选...
  窗体代码 1 Private Sub Text1_OLEDragDrop(Data As Dat...