第6章WinInet编程OKOK讲述.ppt
文本预览下载声明
网络编程实用教程 第6章 WinInet编程 第6章 WinInet编程 WinInet是Windows Internet扩展应用程序高级编程接口,是专为开发具有Internet功能的客户端应用程序而提供的。 WinInet支持如下协议: Ftp Http Gopher 可以与这些服务器进行连接,交换数据信息。操作该服务器等。 第6章 WinInet编程 WinInet开发包的两种形式: WinInet API包含一个C语言的函数集 MFC WinInet类层次则是对前者的面向对象的封装 6.1 使用WinInet API的共性问题 WinInet API的函数原型定义在Wininet.h头文件中,对应的函数实现在Wininet.lib 库文件中。要想成功地编译使用WinInet API 的应用程序,正在使用的C/C++的include 目录中必须有Wininet.h头文件,library目录中必须有Wininet.lib库文件。 6.1.1 WinInet API的HINTERNET句柄 HINTERENT: HINTERNET句柄是一种特殊的数据类型,是由少数WinInet API函数创建的,大多数WinInet API函数通过使用HINTERNET类型的句柄来实现它的操作。 它跟其他的Win32 Handle很类似,但是不能够跟其他类型的Win32 Handle相互交换使用。而各个函数返回的HINTERNET处于一个树型结构中。 6.1.1 WinInet API的HINTERNET句柄 6.1.2 典型的操作流程和使用的句柄 1.使用InternetOpenUrl直接打开因特网上指定的文件 6.1.2 典型的操作流程和使用的句柄 2.FTP操作的层级结构: (1) 对FTP服务器的目录和文件进行操作 6.1.2 典型的操作流程和使用的句柄 (2)使用内存缓冲区来操作FTP服务器上的文件 (3)查询FTP服务器上的文件 6.1.3 如何获取WinInet API函数的错误信息 应用程序可以根据函数执行后的返回值来判断函数的执行是否成功。 WinInet API函数的返回值主要有两种类型: HINTERNET句柄型:当执行成功时返回有效句柄;失败时返回NULL。 布尔型:执行成功时返回TRUE ;当函数失败时,返回FALSE。 在函数调用失败后 ,要了解出错的具体原因,可以调用GetLastError 函数来获取更具体的错误信息。 6.1.4 关于返回信息的缓冲区参数。 通过缓冲区返回信息: 许多WinInet API函数使用两个参数来向应用程序返回信息。lpszBuffer 是指向数据缓冲区的指针可以为NULL。lpdwBufferLength 是指向缓冲区长度的指针(LPDWORD lpdwBufferLength ),它在函数开始执行时指示缓冲区的大小,不能为NULL。 6.1.5 WinInet API的异步操作模式 WinInet函数在进行I/O操作时,默认为同步操作模式; 异步操作要检查函数的返回值,以确定是否执行成功。(通过GetLastError函数) 为了使WinInet以异步方式操作,可以采用以下方法: 设置异步方式标志 调用InternetOpen()时, dwFlags=INTERNET_FLAG_ASYNC 设置非零的环境值 环境值入口参数dwContext=INTERNET_FLAG_ASYNC 定义并实现一个状态回调函数 为句柄注册有效的回调函数 6.1.6 回调函数的定义实现与注册 1.回调函数的原型 VOID (CALLBACK * INTERNET_STATUS_CALLBACK)( IN HINTERNET hInternet,//哪个句柄产生的异步操作 IN DWORD dwContext,//句柄的非0的环境值 IN DWORD dwInternetStatus,//状态码 IN LPVOID lpvStatusInformation,//缓冲区地址信息 IN DWORD dwStatusInformationLength//缓冲区长度 ); 6.1.6 回调函数的定义实现与注册 2.INTERNET_ASYNC_RESULT结构的定义 此结构包含异步回调函数的结果。 typedef struct { DWORD dwResult; DWORD dwError; }INTERNET_ASYNC_RESULT, * LPINTERNET_ASYNC_RESULT; 6.1.6 回调函数的定义实现与注册 3.注册
显示全部