第二人生的源码分析(六十二)类Easy实现多协议文

系统 1568 0
从上一节里可以看到,在类 LLCurl声明里主要声明嵌套类Easy,最后通过嵌套类Easy来实现libcurl功能,下面就来仔细地分析它。它的类声明如下:
#001 class LLCurl::Easy
#002 {
#003     LOG_CLASS(Easy);
#004 
#005 private:
#006     Easy();
#007    
#008 public:
 
用工厂模式来创建类实例。
#009     static Easy* getEasy();
#010     ~Easy();
#011 
 
返回当前 libcurl库的句柄。
#012     CURL* getCurlHandle() const { return mCurlEasyHandle; }
#013 
 
设置错误缓冲区。
#014     void setErrorBuffer();
 
设置授权认证。
#015     void setCA();
#016    
 
调用库的函数 curl_easy_setopt。
#017     void setopt(CURLoption option, S32 value);
#018     // These assume the setter does not free value!
#019     void setopt(CURLoption option, void* value);
#020     void setopt(CURLoption option, char* value);
#021     // Copies the string so that it is gauranteed to stick around
#022     void setoptString(CURLoption option, const std::string& value);
#023    
 
调用库函数 curl_slist_append来添加到列表头里面。
#024     void slist_append(const char* str);
 
设置 HTTP协议头数据。
#025     void setHeaders();
#026    
 
报告错误信息。
#027     U32 report(CURLcode);
 
获取传送信息。
#028     void getTransferInfo(LLCurl::TransferInfo* info);
#029 
 
在使用库下载数据前的设置。
#030     void prepRequest(const std::string& url, ResponderPtr, bool post = false);
#031    
#032     const char* getErrorBuffer();
#033 
 
获取输入流对象。
#034     std::stringstream& getInput() { return mInput; }
 
获取输出协议头流对象。
#035     std::stringstream& getHeaderOutput() { return mHeaderOutput; }
 
获取输出流对象。
#036     LLIOPipe::buffer_ptr_t& getOutput() { return mOutput; }
#037     const LLChannelDescriptors& getChannels() { return mChannels; }
#038    
 
清空所有流对象和一些状态。
#039     void resetState();
#040 
#041 private:   
#042     CURL*               mCurlEasyHandle;
#043     struct curl_slist* mHeaders;
#044    
#045     std::stringstream   mRequest;
#046     LLChannelDescriptors mChannels;
#047     LLIOPipe::buffer_ptr_t mOutput;
#048     std::stringstream   mInput;
#049     std::stringstream   mHeaderOutput;
#050     char                mErrorBuffer[CURL_ERROR_SIZE];
#051 
#052     // Note: char*'s not strings since we pass pointers to curl
#053     std::vector<char*> mStrings;
#054    
#055     ResponderPtr        mResponder;
#056 };
 
上面的类Easy封装了函数curl_easy_init来初始化一个协议实例,函数curl_easy_cleanup来删除相应的实例,函数curl_easy_reset来复位相关状态,通过函数curl_easy_getinfo来获取信息。最后通过函数curl_easy_setopt来设置不同的参数,这样才实现libcurl库的功能调用。

第二人生的源码分析(六十二)类Easy实现多协议文件传送


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论