WinHttpConnect 函数 (winhttp.h)
WinHttpConnect 函数指定 HTTP 请求的初始目标服务器,并将 HINTERNET 连接句柄返回到该初始目标的 HTTP 会话。
语法
WINHTTPAPI HINTERNET WinHttpConnect(
[in] HINTERNET hSession,
[in] LPCWSTR pswzServerName,
[in] INTERNET_PORT nServerPort,
[in] DWORD dwReserved
);
参数
[in] hSession
先前 调用 winHttpOpen返回的有效 HINTERNET WinHTTP 会话句柄。
[in] pswzServerName
指向包含 HTTP 服务器的主机名的 null终止字符串的指针。 或者,字符串可以包含站点的 IP 地址作为字符串,例如 10.0.1.45。 请注意,WinHttp 不接受国际主机名,而无需先将其转换为 Punycode。 有关详细信息,请参阅 处理国际化域名(IDN)。
[in] nServerPort
无符号整数,指定连接到的服务器上的 TCP/IP 端口。 此参数可以是任何有效的 TCP/IP 端口号,也可以是以下值之一。
价值 | 意义 |
---|---|
|
使用 HTTP 服务器的默认端口(端口 80)。 |
|
使用 HTTPS 服务器的默认端口(端口 443)。 选择此端口不会自动建立安全连接。 仍必须使用具有 WinHttpOpenRequest的 WINHTTP_FLAG_SECURE 标志来指定安全事务语义的使用。 |
|
将端口 80 用于 HTTP,将端口 443 用于安全超文本传输协议(HTTPS)。 |
[in] dwReserved
此参数是保留的,必须为 0。
返回值
如果连接成功,则返回 HTTP 会话的有效连接句柄,否则 NULL。 若要检索扩展的错误信息,请调用 GetLastError。 返回的错误代码如下。
错误代码 | 描述 |
---|---|
|
为此操作提供的句柄类型不正确。 |
|
发生了内部错误。 |
|
URL 无效。 |
|
该操作已取消,通常是因为操作完成之前请求已关闭的句柄。 |
|
无法识别或不支持 URL 方案。 |
|
WinHTTP 函数支持正在关闭或卸载。 |
|
没有足够的内存可用于完成请求的操作。 (Windows 错误代码) |
言论
即使 WinHTTP 在异步模式下使用(即在 WinHttpOpen中设置 WINHTTP_FLAG_ASYNC),此函数也会同步运行。 返回值指示成功或失败。 若要获取扩展的错误信息,请调用 GetLastError。
调用应用程序使用 WinHttpConnect返回的 HINTERNET 句柄后,必须使用 WinHttpCloseHandle 函数将其关闭。
WinHttpConnect 指定目标 HTTP 服务器,但如果重定向了请求,则响应可能来自另一台服务器。 可以使用WINHTTP_OPTION_URL标志调用 WinHttpQueryOption 来确定发送响应的服务器 URL。
例子
以下示例演示如何使用安全事务语义从 HTTPS 服务器下载资源。 示例代码初始化 Microsoft Windows HTTP Services (WinHTTP) 应用程序编程接口 (API),选择目标 HTTPS 服务器,然后打开并发送此安全资源的请求。
WinHttpQueryDataAvailable 与请求句柄一起使用来确定可供下载的数据量,然后使用 WinHttpReadData 读取该数据。 此过程重复,直到检索并显示整个文档。
DWORD dwSize = 0;
DWORD dwDownloaded = 0;
LPSTR pszOutBuffer;
BOOL bResults = FALSE;
HINTERNET hSession = NULL,
hConnect = NULL,
hRequest = NULL;
// Use WinHttpOpen to obtain a session handle.
hSession = WinHttpOpen( L"WinHTTP Example/1.0",
WINHTTP_ACCESS_TYPE_DEFAULT_PROXY,
WINHTTP_NO_PROXY_NAME,
WINHTTP_NO_PROXY_BYPASS, 0);
// Specify an HTTP server.
if (hSession)
hConnect = WinHttpConnect( hSession, L"www.microsoft.com",
INTERNET_DEFAULT_HTTPS_PORT, 0);
// Create an HTTP request handle.
if (hConnect)
hRequest = WinHttpOpenRequest( hConnect, L"GET", NULL,
NULL, WINHTTP_NO_REFERER,
WINHTTP_DEFAULT_ACCEPT_TYPES,
WINHTTP_FLAG_SECURE);
// Send a request.
if (hRequest)
bResults = WinHttpSendRequest( hRequest,
WINHTTP_NO_ADDITIONAL_HEADERS,
0, WINHTTP_NO_REQUEST_DATA, 0,
0, 0);
// End the request.
if (bResults)
bResults = WinHttpReceiveResponse( hRequest, NULL);
// Keep checking for data until there is nothing left.
if (bResults)
do
{
// Check for available data.
dwSize = 0;
if (!WinHttpQueryDataAvailable( hRequest, &dwSize))
printf("Error %u in WinHttpQueryDataAvailable.\n", GetLastError());
// Allocate space for the buffer.
pszOutBuffer = new char[dwSize+1];
if (!pszOutBuffer)
{
printf("Out of memory\n");
dwSize=0;
}
else
{
// Read the Data.
ZeroMemory(pszOutBuffer, dwSize+1);
if (!WinHttpReadData( hRequest, (LPVOID)pszOutBuffer,
dwSize, &dwDownloaded))
printf( "Error %u in WinHttpReadData.\n", GetLastError());
else
printf( "%s\n", pszOutBuffer);
// Free the memory allocated to the buffer.
delete [] pszOutBuffer;
}
} while (dwSize > 0);
// Report any errors.
if (!bResults)
printf("Error %d has occurred.\n", GetLastError());
// Close any open handles.
if (hRequest) WinHttpCloseHandle(hRequest);
if (hConnect) WinHttpCloseHandle(hConnect);
if (hSession) WinHttpCloseHandle(hSession);
要求
要求 | 价值 |
---|---|
最低支持的客户端 | 具有 SP3 的 Windows XP、Windows 2000 Professional [仅限桌面应用] |
支持的最低服务器 | Windows Server 2003、带 SP3 的 Windows 2000 Server [仅限桌面应用] |
目标平台 | 窗户 |
标头 | winhttp.h |
库 | Winhttp.lib |
DLL | Winhttp.dll |
可再发行组件 | Windows XP 和 Windows 2000 上的 WinHTTP 5.0 和 Internet Explorer 5.01 或更高版本。 |