InternetOpenUrl
InternetOpenUrl
InternetOpenUrl,計算機編程語言函數,見於C++語言。
目錄
HINTERNET InternetOpenUrl
( HINTERNET hInternet ,
LPCTSTR lpszUrl ,
LPCTSTR lpszHeaders ,
DWORD dwHeadersLength ,
DWORD dwFlags ,
DWORD_PTR dwContext)
通過一個完整的FTP,Gopher或HTTP網址打開一個資源。
參數
hInternet
當前的 Internet 會話句柄。句柄必須由前期的 InternetOpen 調用返回。
lpszUrl
lpszHeaders
dwHeadersLength
額外的頭的大小,以TCHAR為單位。如果這個參數是-1L並且lpszHeaders不是NULL,lpszHeaders被假設為零終止( ASCIIZ ),而長度被自動計算。
dwFlags
此參數可為下列值之一。
數值 說明
INTERNET_FLAG_EXISTING_CONNECT
如果使用相同的必須屬性創建會話,會嘗試利用現有的InternetConnect對象。這隻對FTP操作非常有用,因為FTP是唯一在同一會話中執行多種操作的協議。WinINet API 為每個由InternetOpen產生的HINTERNET句柄緩衝一個單獨鏈接句柄。InternetOpenUrl使用此標誌的HTTP和FTP連接。
INTERNET_FLAG_HYPERLINK
當決定何時從網路重載時,如果伺服器沒有返回 expires time 和 LastModified,那麼強制重載。
INTERNET_FLAG_IGNORE_CERT_CN_INVALID
停用檢查從伺服器對必須的主機名稱返回的SSL/PCT-based證書。 WinINet函數使用簡單的比較匹配主機名稱和通配符的規則檢查證書。
INTERNET_FLAG_IGNORE_CERT_DATE_INVALID
停用檢查的SSL/PCT-based的證書的適當的有效日期。
INTERNET_FLAG_IGNORE_REDIRECT_TO_HTTP
禁用檢測這中特殊的重定向。當使用此標誌, WinINet 透明允許從HTTPS到HTTP URL的重定向。
INTERNET_FLAG_IGNORE_REDIRECT_TO_HTTPS
禁用檢測這中特殊的重定向。當使用此標誌, WinINet 透明的允許的HTTP到HTTPS URL的重定向。
INTERNET_FLAG_KEEP_CONNECTION
如果可能的話,為連接使用保活語義。這個標誌要求微軟網路( MSN ),NTLM和其他類型的身份驗證。
INTERNET_FLAG_NEED_FILE
如果要創建的文件不能被緩存,創建臨時文件。
INTERNET_FLAG_NO_AUTH
不試圖自動驗證。
INTERNET_FLAG_NO_AUTO_REDIRECT
不自動處理HttpSendRequest中的重定向。
INTERNET_FLAG_NO_CACHE_WRITE
不添加返回實體到緩存。
INTERNET_FLAG_NO_COOKIES
不會自動添加的Cookie頭到請求,並且不自動添加返回的cookie到cookie資料庫。
INTERNET_FLAG_NO_UI
禁用Cookie的對話框。
INTERNET_FLAG_PASSIVE
使用被動FTP語義。InternetOpenUrl為FTP的文件和目錄使用此標誌。
INTERNET_FLAG_PRAGMA_NOCACHE
即使代理中存在緩存副本,也強制要求由源伺服器返回。
INTERNET_FLAG_RAW_DATA
檢索的Gopher目錄信息時,傳回的數據作為GOPHER_FIND_DATA結構,如果檢索的FTP目錄信息時,作為一個WIN32_FIND_DATA結構。如果此標誌沒有指定,或者請求通過CERN代理創建, InternetOpenUrl返回的HTML版本的目錄。
INTERNET_FLAG_RELOAD
從原伺服器強制下載所要求的文件,對象,或目錄列表,而不是從緩存下載。
INTERNET_FLAG_RESYNCHRONIZE
重新載入的HTTP資源,如果資源在最後一次下載后已被修改。所有FTP和Gopher資源將被重載。
INTERNET_FLAG_SECURE
使用安全傳輸語義。這次傳輸使用安全套位元組層/專用通信技術(的SSL / PCT ),這隻有在HTTP請求時有意義。
dwContext
一個指向一個應用程序定義的值,將隨著返回的句柄,一起傳遞給回調函數。
返回值
如果已成功建立到FTP,Gopher,或HTTP URL的連接,返回一個有效的句柄,如果連接失敗返回NULL。要檢索特定的錯誤訊息,請GetLastError 。要確定為什麼對伺服器的訪問被拒絕,請調用InternetGetLastResponseInfo。
備註
先調用InternetCanonicalizeUrl,如果正在使用的網址包含一個相對URL和一個空格分隔的基礎URL。
這是一個通用的函數,可用於使用任何WinINet支持的協議檢索數據。這個函數在應用程序並不需要指定特定的協議,只需要相應的URL的數據時,特別有用。InternetOpenUrl函數解析URL字元串,建立連接到伺服器,並準備下載的指定URL的數據。該應用程序可以用InternetReadFile (對文件)或InternetFindNextFile (對目錄)來檢索URL的數據。沒有必要在InternetOpenUrl 前調用InternetConnect。
InternetOpenUrl在少於1024埠上禁用Gopher,除了70——標準的Gopher埠和105——通常用於中央服務組織(民間組織)的名字搜索。
在使用完InternetOpenUrl返回的HINTERNET句柄后,必須使用InternetCloseHandle函數關閉它。
注意:當工作在非同步模式(InternetOpen的dwFlags參數指定INTERNET_FLAG_ASYNC)和dwContext參數是零 (INTERNET_NO_CALLBACK),使用InternetSetStatusCallback函數設置的回調,將不被引用,但是,將仍然在非同步模式執行回調。
要求
客戶端
需要 Windows Vista, Windows XP, Windows 2000 Professional, Windows NT Workstation 4.0, Windows Me, Windows 98, 或者 Windows 95。
伺服器-
版本:
需要 Internet Explorer 3.0 或更高版本。
頭
在 Wininet.h 中聲明。
庫
使用 Wininet.lib 。
DLL
需要 wininet.dll 。
執行InternetOpenUrlW(Unicode)和InternetOpenUrlA (ANSI) 的。