wininet,winhttp,xmlhttprequest,各版本区别 《转》

一、标准API接口WinINet(Microsoft Windows Internet)和WinHTTP(Microsoft Windows HTTP)

实现Http访问,微软提供了二套API:WinINet, WinHTTP(分别封装于system32目录下的wininet.dll和winhttp.dll内)

二者主要区别在于后者更为安全和稳定,可以说WinHTTP是WinINet的升级版

LZ所提的UDF WinHTTP.au3就是直接调用标准接口写成的自定义函数库文件

二、COM对象XMLHttpRequest和WinHttpRequest和ServerXMLHTTPRequest

XMLHttpRequest是基于WinInet封装的,

而WinHttpRequest和ServerXMLHTTPRequest则是基于WinHTTP封装的

所以三者的稳定性属XMLHttpRequest为最差

封装成COM形式主要是为了方便js vbs等脚本的调用,还具有易书写、降低开发难度等许多特点把

三、对象版本和封装位置

1、XMLHttpRequest对象版本和对应的封装dll文件

Microsoft.XMLHTTP 对应 msxml.dll

MSXML2.XMLHTTP 对应 msxml2.dll

MSXML2.XMLHTTP.3.0 对应 msxml3.dll

MSXML2.XMLHTTP.4.0 对应 msxml4.dll

MSXML2.XMLHTTP.5.0 对应 msxml5.dll(此版本是伴随office2007发布的,所以目录下可能找不到该版本的dll)

MSXML2.XMLHTTP.6.0 对应 msxml6.dll

如上各个dll的发布一般都是以补丁的形式发布,win7默认都集成了吧

2、ServerXMLHTTP对象版本和对应的封装dll文件

Msxml2.ServerXMLHTTP 对应 msxml2.dll(win7自带,下同!)

Msxml2.ServerXMLHTTP.3.0 对应 msxml3.dll

Msxml2.ServerXMLHTTP.4.0 对应 msxml4.dll

Msxml2.ServerXMLHTTP.5.0 对应 msxml5.dll

Msxml2.ServerXMLHTTP.6.0 对应 msxml6.dll

3、WinHttpRequest对象

WinHttp.WinHttpRequest.5.1 对应 Winhttp.dll

(如上高版本的通常稳定性会好一点)

四、对象成员(属性、方法、事件等),主要优缺点

XMLRequest成员参考

缺点:和浏览器挂钩,大多情况下会共享cookies,session,不支持单独设置代理

优点:和浏览器挂钩,大多情况下会共享cookies,session

ServerXMLHTTP成员参考

缺点:系统没有对应dll的情况下程序需要外挂一个dll文件

优点:脱离浏览器,使用代理方便

WinHttpRequest成员参考

缺点:暂无

优点:脱离浏览器,使用代理方便

五、总结

如果你对WinInet或Winhttp比较熟悉的话当然推荐直接使用标准接口,但同样要付出的代价就是书写更多的代码,记住更多的参数

就个人开发经验而言还是推荐大家使用WinHttpRequest对象,微软封装的COM还是很优秀的,应该足以应付大多数要求了

相关链接:

1、朱剑的财富博客

http://51lica.com/archives/1942

2、WinHTTP vs. WinINet

https://msdn.microsoft.com/en-us/library/windows/desktop/hh227297(v=vs.85).aspx

文档信息

版权声明:自由转载-非商用-非衍生-保持署名 | Creative Commons BY-NC-ND 3.0

原文网址: http://sunweiwei.com/2003/

最后修改时间: 2015年05月22日 15:12:27

相关推荐
千枫s18 小时前
做一个电脑版爬虫程序
爬虫·python
亿牛云爬虫专家19 小时前
生产级Go高并发爬虫实战:突破 net_http 长连接与隧道代理IP切换陷阱
爬虫·http·golang·代理ip·keepalive·隧道代理·https connect
威风少侠19 小时前
cursor快速实现前后端项目以及playwright实现爬虫程序
爬虫·cursor
小白学大数据20 小时前
分布式爬虫核心技术详解与工程实践
开发语言·分布式·爬虫·python
杜子不疼.1 天前
Python 爬虫 + AI 总结:自动生成行业日报系统
人工智能·爬虫·python
ZC跨境爬虫2 天前
Scrapy多级请求实战:5sing伴奏网爬取踩坑与优化全记录(JSON提取+Xpath解析)
爬虫·scrapy·html·json
willhuo2 天前
基于Playwright的抖音网页自动化浏览器项目使用指南
爬虫·c#·.netcore·webview
-To be number.wan2 天前
Python爬取百度指数保姆级教程
爬虫·python
程序员老邢2 天前
【产品底稿 04】商助慧 V1.1 里程碑:爬虫入库 + MySQL + Milvus 全链路打通
java·爬虫·mysql·ai·springboot·milvus
ZC跨境爬虫2 天前
【爬虫实战对比】Requests vs Scrapy 笔趣阁小说爬虫,从单线程到高效并发的全方位升级
前端·爬虫·scrapy·html