谷歌浏览器的源码分析(28)
上一次说到使用WinHTTP函数来创建HTTP连接,并且使用它来发送请求,那么数据接收回来,当然也是从它那里接收的,因此下面来分析它的接收数据的几个函数,然后再来看看chrome里收到数据后发送到那里处理。
在WinHTTP里使用WinHttpOpen函数来创建HTTP连接,然后使用WinHttpConnect连接需要下载数据的网站,接着调函数WinHttpOpenRequest来创建一个请求,使用函数WinHttpSendRequest发送HTTP请求,如果有数据发送到服务器,就通过WinHttpWriteData函数来发送,最后调用函数WinHttpReceiveResponse来查询状态码,WinHttpQueryDataAvailable函数查询可以接收到的数据大小,调用函数WinHttpQueryHeaders来查询传送回来的html头的大小,调用函数WinHttpReadData来接收到WEB服务器发送回来的数据。
chrome就是通过下面的函数来实现数据接收的,如下:
#001  void HttpTransactionWinHttp::HandleStatusCallback(DWORD status,
#002                                                    DWORD_PTR result,
#003                                                    DWORD error,
#004                                                    DWORD secure_failure) {
#005    int rv = ERR_FAILED;
#006  
#007    switch (status) {
#008      case WINHTTP_CALLBACK_STATUS_REQUEST_ERROR:
#009        rv = DidReceiveError(error, secure_failure);
#010        break;
#011      case WINHTTP_CALLBACK_STATUS_SENDREQUEST_COMPLETE:
#012        PopulateSSLInfo(secure_failure);
#013        rv = DidSendRequest();
#014        break;
#015      case WINHTTP_CALLBACK_STATUS_WRITE_COMPLETE:
#016        rv = DidWriteData(static_cast<DWORD>(result));
#017        break;
接收到HTTP协议头的数据 。
#018      case WINHTTP_CALLBACK_STATUS_HEADERS_AVAILABLE:
#019        rv = DidReceiveHeaders();
#020        break;
接收HTTP协议的数据 。
#021      case WINHTTP_CALLBACK_STATUS_READ_COMPLETE:
#022        rv = DidReadData(static_cast<DWORD>(result));
#023        break;
#024      default:
#025        NOTREACHED() << "unexpected status code";
#026    }
#027  
#028    if (rv == ERR_IO_PENDING) {
#029      session_callback_->AddRef();  // balanced when callback runs.
#030    } else if (callback_) {
#031      DoCallback(rv);
#032    }
#033  }
通过上面的分析知道数据怎么样从WinHTTP接收到,并且发送到下一个阶段处理。
 
                    
                 
                
            
         浙公网安备 33010602011771号
浙公网安备 33010602011771号