我是靠谱客的博主 健康小海豚,最近开发中收集的这篇文章主要介绍libcurl库的http get和http post使用 一、libcurl中的http get使用方法 ,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

一、libcurl中的http get使用方法

1. 为什么要使用libcurl

1) 作为http的客户端,可以直接用socket连接服务器,然后对到的数据进行http解析,但要分析协议头,实现代理…这样太麻烦了。

 

2) libcurl是一个开源的客户端url传输库,支持 FTP,FTPS,TFTP,HTTP,HTTPS,GOPHER,TELNET,DICT,FILE和LDAP,支持 Windows,Unix,Linux等平台,简单易用,且库文件占用空间不到200K

 

2. get和post方式

客户端在http连接时向服务提交数据的方式分为get和post两种


3.Get方式将所要传输的数据附在网址后面,然后一起送达服务器,它的优点是效率比较高;缺点是安全性差、数据不超过1024个字符、必须是7位的ASCII编码;查询时经常用此方法


4.Post通过Http post处理发送数据,它的优点是安全性较强、支持数据量大、支持字符多;缺点是效率相对低;编辑修改时多使用此方法


5.Get使用实例,其关键点就是设置回调函数

[html] view plain copy
  1. <pre code_snippet_id="172026" snippet_file_name="blog_20140126_1_7646331" name="code" class="html"></pre>  
  2. <pre></pre>  
  3. <pre></pre>  
  4. <pre></pre>  

[html] view plain copy
  1. #include <stdio.h>  
  2. #include <stdlib.h>  
  3. #include <string.h>  
  4. #include "curl/curl.h"  
  5. #define HEAD_OUT "/root/project/test/head.out"  
  6. #define BODY_OUT "/root/project/test/body.out"  
  7. #define RET_EQUAL 0  
  8. #define RET_NOT_EQUAL 1  
  9. #define RET_NO_UPGRADE_FILE 2  
  10. #define RET_FIND_UPGRADE_FILE 3  
  11. #define RET_CHECK_OK 4  
  12. #define RET_ERROR 5  
  13. #define RET_SD_VERSION_ERROR 6  
  14. #define RET_OK 7  
  15. #define RET_CUR_VERSION_ERROR 8  
  16. #define RET_XOR_ERROR 9  
  17. #define RET_UPGRADE_OK 10  
  18. #define RET_UPGRADE_ERROR 11  
  19. #define RET_ERROR_FILE_NAME 12  
  20. #define RET_DELAY_CMD_NOT_RUN 13  
  21. #define RET_DEALY_CMD_ERROR 14  
  22. #define RET_GET_HASH_OK 15  
  23. #define RET_GET_HASH_ERROR 16  
  24. #define RET_AREADY_CP_VERSION 17  
  25. #define RET_NOT_CP_VERSION 18  
  26. #define RET_XOR_VERSION 19  
  27. #define RET_OPEN_VERSION_LIST_PATH_FAIL 20  
  28. #define OPEN_HEAD_FILE_ERROR 21  
  29. #define OPEN_BODY_FILE_ERROR 22  
  30. #define RET_GET_VERSION_PATH 23  
  31. #define RET_NOT_GET_VERSION_PATH 24  
  32. #define TIME_OUT 25  
  33. #define DOWNLOAD_OK 26  
  34. #define LOG fprintf  
  35. #define LOG_NOTICE stderr  
  36. size_t write_data(void * ptr, size_t size, size_t nmemb, void* stream)  
  37. {  
  38. int written = fwrite(ptr, size, nmemb, (FILE *)stream);  
  39. return written;  
  40. }  
  41. int detect_version(char * url)  
  42. {  
  43.   
  44. CURL * curl_handle;  
  45.   
  46. FILE * headerfile;  
  47.   
  48. FILE * bodyfile;  
  49.   
  50. static const char * headerfilename = HEAD_OUT;  
  51.   
  52. static const char * bodyfilename = BODY_OUT;  
  53.   
  54. // char buffer[STR_LEN] = {''};  
  55.   
  56. int res = 0;  
  57.   
  58. printf("url=%sn",url);  
  59.   
  60. curl_global_init(CURL_GLOBAL_ALL);  
  61.   
  62. curl_handle = curl_easy_init();  
  63.   
  64. curl_easy_setopt(curl_handle, CURLOPT_URL, url);  
  65.   
  66. curl_easy_setopt(curl_handle, CURLOPT_NOPROGRESS, 1L);  
  67.   
  68. curl_easy_setopt(curl_handle, CURLOPT_WRITEFUNCTION, write_data);  
  69.   
  70. headerfile = fopen(headerfilename, "wb");  
  71.   
  72. if(headerfilename == NULL) {  
  73.   
  74. curl_easy_cleanup(curl_handle);  
  75.   
  76. return OPEN_HEAD_FILE_ERROR;  
  77.   
  78. }  
  79.   
  80. bodyfile = fopen(bodyfilename, "wb");  
  81.   
  82. if(bodyfile == NULL) {  
  83.   
  84. curl_easy_cleanup(curl_handle);  
  85.   
  86. return OPEN_BODY_FILE_ERROR;  
  87.   
  88. }  
  89.   
  90. curl_easy_setopt(curl_handle, CURLOPT_WRITEHEADER, headerfile);  
  91.   
  92. curl_easy_setopt(curl_handle, CURLOPT_WRITEDATA, bodyfile);  
  93.   
  94. res = curl_easy_perform(curl_handle);  
  95.   
  96. if(res != CURLE_OK)  
  97.   
  98. LOG(LOG_NOTICE, "curl_easy_perform() faild:%sn",  
  99.   
  100. curl_easy_strerror(res));  
  101.   
  102. fclose(headerfile);  
  103.   
  104. fclose(bodyfile);  
  105.   
  106. curl_easy_cleanup(curl_handle);  
  107.   
  108. return res;  
  109.   
  110. }  
  111. int main()  
  112. {  
  113.     detect_version("http://car.9797168.com:823/get_bus_info?mac=00:11:22:33:44:55");  
  114.     return 0;  
  115. }  


6. POST使用实例,POST使用比较复杂但是比较常用

1.一般使用方法,可以解决大多数post数据的问题。

[html] view plain copy
  1. #include <stdio.h>     
  2. #include <stdlib.h>     
  3. #include <string.h>     
  4. #include <curl/curl.h>     
  5.     
  6. #define POSTURL "http://www.xiami.com/member/login"     
  7. #define POSTFIELDS "email=myemail@163.com&password=mypassword&autologin=1&submit=登 录&type="     
  8. #define FILENAME "curlposttest.log"     
  9.     
  10. size_t write_data(void *buffer, size_t size, size_t nmemb, void *userp);     
  11.     
  12. int main(int argc, char *argv[]) {     
  13.     CURL *curl;     
  14.     CURLcode res;     
  15.     FILE *fptr;     
  16.     struct curl_slist *http_header = NULL;     
  17.     
  18.     if ((fptr = fopen(FILENAME, "w")) == NULL) {     
  19.         fprintf(stderr, "fopen file error: %sn", FILENAME);     
  20.         exit(1);     
  21.     }     
  22.     
  23.     curl = curl_easy_init();     
  24.     curl_easy_setopt(curl, CURLOPT_URL, POSTURL);     
  25.     curl_easy_setopt(curl, CURLOPT_POSTFIELDS, POSTFIELDS);   //设置post属性,使用&来将表单属性连接在一起  
  26.     curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, write_data);   //回调函数,可有可无  
  27.     curl_easy_setopt(curl, CURLOPT_WRITEDATA, fptr);           //回调函数写入数据指针  
  28.     curl_easy_setopt(curl, CURLOPT_POST, 1);                 //设置libcurl发送的协议  
  29.     curl_easy_setopt(curl, CURLOPT_VERBOSE, 1);              //设置版本  
  30.     curl_easy_setopt(curl, CURLOPT_HEADER, 1);               //设置http数据头  
  31.     curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1);       //设置返回的数据量  
  32.     curl_easy_setopt(curl, CURLOPT_COOKIEFILE, "/Users/zhu/CProjects/curlposttest.cookie");   //设置cookie,不是必须  
  33.     res = curl_easy_perform(curl);     
  34.     curl_easy_cleanup(curl);     
  35. }     
  36.     
  37. size_t write_data(void *buffer, size_t size, size_t nmemb, void *userp) {     
  38.     FILE *fptr = (FILE*)userp;     
  39.     fwrite(buffer, size, nmemb, fptr);     
  40. }    


2.post高级使用方法,特点简单,但不易于理解,其使用二进制传输的方式,适合于加密数据的传输。

[html] view plain copy
  1. #include <stdio.h>  
  2. #include <stdlib.h>  
  3. #include <string.h>  
  4. #include "curl/curl.h"    
  5. #include "http_rsa.h"  
  6.   
  7. #define POSTURL "http://10.0.0.13:821/wifibox/"  
  8.    
  9. #define HTTP_UPLOAD_FILD "/root/project/upload/upload.tar.gz"  
  10. #define HTTP_POST_TYPE_GPS "gps"  
  11. #define HTTP_POST_TYPE_SYS "sys"  
  12. #define HTTP_REPORT_TYPE "type"  
  13. #define HTTP_REPORT_SIGNATURE "signature"  
  14. #define HTTP_REPORT_INDEX "ident"  
  15. #define HTTP_REPORT_CONTENT "content"  
  16. int report_http_post(char* type, char* index, char* content, char* url)  
  17. {  
  18.   
  19.  struct curl_httppost *post = NULL;  
  20.   
  21.  struct curl_httppost *last = NULL;  
  22.   
  23.  CURL *easy_handle = curl_easy_init();  
  24.   
  25.  char asr_buff[1024]={0};  
  26.   
  27.  int len =0;  
  28.   
  29.    
  30.   
  31.  // 使用multi-parts form post  
  32.   
  33.  curl_easy_setopt(easy_handle, CURLOPT_URL, url);  
  34.   
  35.  openssl_rsa_enc(type, strlen(type), asr_buff, &len);  
  36.   
  37.  // 文本数据  
  38.   
  39.  curl_formadd(&post, &last, CURLFORM_COPYNAME, HTTP_REPORT_TYPE, CURLFORM_COPYCONTENTS, type, CURLFORM_END);  
  40.   
  41.  curl_formadd(&post, &last, CURLFORM_COPYNAME, HTTP_REPORT_SIGNATURE, CURLFORM_COPYCONTENTS, asr_buff, CURLFORM_END);  
  42.   
  43.  // 文本文件中的数据  
  44.   
  45.  //curl_formadd(&post, &last, CURLFORM_COPYNAME, "signature", CURLFORM_FILECONTENT, "/root/project/sys", CURLFORM_END);  
  46.   
  47.  curl_formadd(&post, &last, CURLFORM_COPYNAME, HTTP_REPORT_INDEX, CURLFORM_COPYCONTENTS, index, CURLFORM_END);  
  48.   
  49.  if(1) //发送buff  
  50.   
  51.  {  
  52.   
  53.   curl_formadd(&post, &last, CURLFORM_COPYNAME, HTTP_REPORT_CONTENT, CURLFORM_COPYCONTENTS, content, CURLFORM_END);  
  54.   
  55.  }  
  56.   
  57.  else//发送文件  
  58.   
  59.  {  
  60.   
  61.   curl_formadd(&post, &last, CURLFORM_COPYNAME, HTTP_REPORT_CONTENT, CURLFORM_FILECONTENT, content, CURLFORM_END);  
  62.   
  63.  }  
  64.   
  65.  curl_easy_setopt(easy_handle, CURLOPT_HTTPPOST, post);  
  66.   
  67.  curl_easy_perform(easy_handle);  
  68.   
  69.  curl_formfree(post);  
  70.   
  71.  curl_easy_cleanup(easy_handle);  
  72.   
  73.  curl_global_cleanup();  
  74.   
  75.  return 0;  
  76.   
  77. }  
  78. #define MSC_INFO "11:22:33:44:55:66"  
  79. int main(int argc, char *argv[]) {  
  80.   
  81.  report_http_post("buff", MSC_INFO, "{"date": "2013-12-30 12:20:30"}", POSTURL);  
  82.   
  83.  report_http_post("file", MSC_INFO, HTTP_UPLOAD_FILD, POSTURL);  
  84.   
  85.  return 0;  
  86.   
  87. }  


这个是curl提供的一个高级使用方法,在post/get数据过程中,使用二进制的方式来进行数据交互,解决加密数据传输是乱码的问题。

使用比较简单

1)新建两个发送数据的链表指针

 struct curl_httppost *post = NULL;
 struct curl_httppost *last = NULL;
2)使用curl_formadd函数将链表指针添加进发送队列中。

 curl_formadd(&post, &last, CURLFORM_COPYNAME, HTTP_REPORT_TYPE, CURLFORM_COPYCONTENTS, type, CURLFORM_END);

CURLFORM_COPYNAME:表单属性名称属性

HTTP_REPORT_TYPE:post表单属性名

CURLFORM_COPYCONTENTS:表单值属性,注意,根据所设置的值不一样,来决定表单属性值的格式,可以是buff,可以是文件,图片等。

type:post表单属性值


3)当然,使用curl_formadd方式和一般的curl方法是一样的,需要一般的初始化流程

CURL *easy_handle = curl_easy_init();等

注意,此处可以和一般的curl使用方式兼容,可以设置返回值得回调函数等。

最后

以上就是健康小海豚为你收集整理的libcurl库的http get和http post使用 一、libcurl中的http get使用方法 的全部内容,希望文章能够帮你解决libcurl库的http get和http post使用 一、libcurl中的http get使用方法 所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(73)

评论列表共有 0 条评论

立即
投稿
返回
顶部