WinHTTP教程

最近有些忙,也没更新BLOG,这几天在捣鼓一个小玩意要用到WinHTTP API,发现资料很少,而且大都是些MFC封装的例子,看得我是一个头几个大。就把自己关于WinHTTP的学习总结了一下,仅供参考,各人理解可能有区别。另外非常感谢前人在网络上提供的相关参考。

BTW:Google Chrome就是基于WinHTTP写的,如果想深入学习,可以阅读分析Chrome Code.
从此处获取Chrome的源代码等相关信息
SVN: http://src.chromium.org/svn/trunk/src/chrome/
VIEW: http://src.chromium.org/viewvc/

WinHTTP APIs是一组用来进行HTTP操作的函数,相比WinINet更加安全和健壮一些。

WinHTTP API List:

WinHttpAddRequestHeaders
WinHttpCheckPlatform
WinHttpCloseHandle
WinHttpConnect
WinHttpCrackUrl
WinHttpCreateUrl
WinHttpDetectAutoProxyConfigUrl
WinHttpGetDefaultProxyConfiguration
WinHttpGetIEProxyConfigForCurrentUser
WinHttpGetProxyForUrl
WinHttpOpen
WinHttpOpenRequest
WinHttpQueryAuthSchemes
WinHttpQueryDataAvailable
WinHttpQueryHeaders
WinHttpQueryOption
WinHttpReadData
WinHttpReceiveResponse
WinHttpSendRequest
WinHttpSetCredentials
WinHttpSetDefaultProxyConfiguration
WinHttpSetOption
WinHttpSetStatusCallback
WinHttpSetTimeouts
WinHttpTimeFromSystemTime
WinHttpTimeToSystemTime
WinHttpWriteData


WinHTTP API逻辑上分成三个独立的对象进行建模:会话对象、连接对象、请求对象。大致为:

初始化WinHTTP(获得会话对象,)-->创建连接(连接1,连接2,...N)-->发送请求(请求1,请求2,....N)

会话对象、连接对象、请求对象都由HINTERNET句柄表示,句柄的使用传递过程大致为:

WinHttpOpen-->return Session handle
                        |
WinHttpConnect-->return Connection handle
                        |
WinHttpOpenRequest-->return Request handle

各对象句柄可以使用WinHttpCloseHandle进行关闭。为了进一步加深了解WinHTTP APIs的调用过程和关系,我们来看下面的图:

                                                           (图来自MSDN)


会话对象
会话对象使用WinHttpOpen函数来进行创建。函数原形如下:

HINTERNET WinHttpOpen(
          __in LPCWSTR   pwszUserAgent,
          __in DWORD   dwAccessType,
          __in LPCWSTR   pwszProxyName,
          __in LPCWSTR   pwszProxyBypass
          __in DWORD   dwFlags
);

第一个参数指向一个应用程序自身名称及版本的字符串,使用在HTTP协议的User Agent中。如:Mozilla/4.0
第二个参数是WinHttp的访问类型要求。可能为下列值
WINHTTP_ACCESS_TYPE_NO_PROXY             //不使用默认代理服务器
WINHTTP_ACCESS_TYPE_DEFAULT_PROXY   //使用默认的代理服务器(储存在注册表中的WINHTTP代理设置,注意:与IE的代理设置不同,为独立的)
WINHTTP_ACCESS_TYPE_NAMED_PROXY //使用指定的代理服务器设置
第三个参数指向一个代理服务器名称的字符串,如果前一个参数dwAccessType未设置为WINHTTP_ACCESS_TYPE_NAMED,这个参数就必须为WINHTTP_NO_PROXY_NMAE。
第四个参数指向一个HTTP服务器列表,其中的服务器不能通过前一个参数指定的代理服务器进行路由(这与IE代理服务器设置中的例外情况设置类似)
第五个参数定义了一个标记,当前只定义了一个标记
WINHTTP_FLAG_ASYNC //指示WinHTTP API将异步执行。

连接对象
连接对象使用WinHttpConnect函数来进行创建(注意前面提到的一个会话对象可以创建多个连接对象)。函数原形如下:

HINTERNET WinHttpConnect(
          __in HINTERNET   hSession,
          __in LPCWSTR   pswzServerName,
          __in INTERNET_PORT   nServerPort
          __in reserved DWORD   dwReserved
);

第一个参数指定连接的所属会话句柄。
第二个参数指定连接的服务器名称或IP地址
第三个参数指定服务器的端口号,这个参数还可以指定为下列值
INTERNET_DEFAULT_HTTP_PORT //使用默认HTTP Service端口号80
INTERNET_DEFAULT_HTTPS_PORT //使用默认HTTPS安全连接端口号443
INTERNET_DEFAULT_PORT //常规HTTP请求使用80,HTTPS请求使用443(这是个便利的参数值)
第四个参数是保留的,必须为0

请求对象
请求对象使用WinHttpOpenRequest函数来进行创建(注意前面提到的一个连接对象可以创建多个请求对象)。从请求对象开始,就进入原本目的HTTP操作了。函数原形如下:

HINTERNET WinHttpOpenRequest(
          __in HINTERNET   hConnect,
          __in LPCWSTR   pwszVerb,
          __in LPCWSTR   pwszObjectName,
          __in LPCWSTR   pwszVersion,
          __in LPCWSTR   pwszReferrer,
          __in LPCWSTR   *ppwszAcceptTypes,
          __in DWORD   dwFlags
)

第一个参数指定请求所属的连接句柄
第二个参数指定HTTP协议动作(如:GET、POST和HEAD),如果此参数为NULL,函数会默认使用GET。
第三个参数指定正在请求的资源名称和相对路径
第四个参数指定使用的HTTP协议版本,如果此参数为NULL,函数会默认使用HTTP/1.1
第五个参数指定引用的URL,如果没有,可以设置为WINHTTP_NO_REFERER
第六个参数指定客户端(本应用程序)将接受的媒体类型(如:image/gif、text/*、*/*),一般可以指定为WIN_HTTP_DEFAULT_ACCEPT_TYPES。
第七个参数指定请求行为标记,如可以指定为WINHTTP_FLAG_SECURE标记发出HTTPS请求,一般可以为0。其他可指定值请参考MSDN,我就不罗列了。


至此介绍了三个WinHTTP API,经过这个过程就基本建立了一个HTTP网络连接。由此我们已经对WInHTTP有了基本概念性的认识。WinHTTP APIs(2)中将再介绍利用WinHTTP API进行更为复杂的操作和实际的应用例子

  • 5
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
WinHTTP提供以下功能: WinHttpAddRequestHeaders 向HTTP请求句柄添加一个或多个HTTP请求标头。 WinHttpCheckPlatform 确定WinHTTP是否支持当前平台。 WinHttpCloseHandle 关闭单个 HINTERNET句柄。 WinHttpConnect 指定HTTP请求的初始目标服务器WinHttpCrackUrl 将URL分为其组成部分,例如主机名和路径。 WinHttpCreateProxyResolver 创建WinHttpGetProxyForUrlEx使用的句柄。 WinHttpCreateUrl 从组件部分创建URL,例如主机名和路径。 WinHttpDetectAutoProxyConfigUrl 查找代理自动配置(PAC)文件的URL。此功能报告PAC文件的URL,但不下载该文件。 WinHttpFreeProxyResult 释放从以前的调用WinHttpGetProxyResult检索的数据。 WinHttpGetDefaultProxyConfiguration 从注册表中检索默认的WinHTTP代理配置。 WinHTTPGetIEProxyConfigForCurrentUser 获取当前用户的Internet Explorer(IE)代理配置。 WinHttpGetProxyForUrl 检索指定URL的代理信息。 WinHttpGetProxyForUrlEx 检索指定URL的代理信息。 WinHttpGetProxyResult 检索到调用的结果WinHttpGetProxyForUrlEx。 WinHttpOpen 初始化应用程序对WinHTTP功能的使用WinHttpOpenRequest 创建HTTP请求句柄。 WinHttpQueryAuthSchemes 返回服务器支持的授权方案。 WinHttpQueryDataAvailable 返回可立即与读取数据的字节数 WinHttpReadData。 WinHttpQueryHeaders 检索与HTTP请求相关联的头信息。 WinHttpQueryOption 在指定的句柄上查询Internet选项。 WinHttpReadData 从WinHttpOpenRequest函数打开的句柄中读取数据 。 WinHttpReceiveResponse 结束由WinHttpSendRequest启动的HTTP请求 。 WinHttpResetAutoProxy 重置自动代理。 WinHttpSendRequest 将指定的请求发送到HTTP服务器WinHttpSetCredentials 将所需的授权凭证传递给服务器WinHttpSetDefaultProxyConfiguration 在注册表中设置默认的WinHTTP代理配置。 WinHttpSetOption 设置Internet选项。 WinHttpSetStatusCallback 设置WinHTTP可以在操作过程中进行调用的回调函数。 WinHttpSetTimeouts 设置涉及HTTP事务的各种超时。 WinHttpTimeFromSystemTime 根据HTTP版本1.0规范格式化日期和时间。 WinHttpTimeToSystemTime 获取HTTP时间/日期字符串并将其转换为 SYSTEMTIME结构。 WinHttpWriteData 将请求数据写入HTTP服务器WinHttpWebSocketClose 关闭WebSocket连接。 WinHttpWebSocketCompleteUpgrade 完成由WinHttpSendRequest启动的WebSocket握手。 WinHttpWebSocketQueryCloseStatus 获取服务器发送的关闭状态。 WinHttpWebSocketReceive 从WebSocket连接接收数据。 WinHttpWebSocketSend 通过WebSocket连接发送数据。 WinHttpWebSocketShutdown 向WebSocket连接发送关闭框架
MFC(Microsoft Foundation Class)是微软公司提供的一个用于开发Windows应用程序的C++类库,而WinHTTPWindows HTTP Services)是一组用于操作和管理HTTP协议的应用程序接口(API)。 MFC通过提供一系列封装好的类和函数,简化了Windows应用程序的开发过程。WinHTTP则提供了一些用于创建和管理HTTP请求的功能,使开发者可以在Windows平台上进行HTTP通信。与传统的WinINet相比,WinHTTP更加轻量级和可靠,并具有更好的性能。 使用MFC WinHTTP,开发者可以方便地在自己的应用程序中实现对HTTP服务器的请求和响应操作。通过封装好的类和方法,可以实现发送GET和POST请求、设置请求头、处理响应头、获取响应数据等操作。同时,WinHTTP还支持HTTPS协议,并提供了相应的安全机制,保证了数据的安全性。 MFC WinHTTP对于开发需要与网络进行交互的应用程序非常有用。例如,在开发一个聊天软件时,可以使用WinHTTP来发送和接收聊天消息;在开发一个在线视频播放器时,可以使用WinHTTP来请求视频流并进行播放;在开发一个网页爬虫时,可以使用WinHTTP来获取网页内容。 总之,MFC WinHTTP是一个在MFC框架下进行HTTP通信的强大工具。它提供了一套方便易用的API,使得开发者可以轻松地实现对HTTP服务器的请求和处理。对于需要进行网络交互的应用程序开发来说,MFC WinHTTP是一个不可或缺的利器。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值