Curl命令简介(转)
Curl命令简介
相关1:http://blog.csdn.net/windows_nt/article/details/9630567
相关2:http://php.net/manual/zh/function.curl-setopt.php
1、使用curl命令发送post数据:
curl -d ‘{post内容}’ ip(或域名)/path?get参数
如:curl -d ‘{post内容}’ baidu.com/ask?p=xx
2、使用curl命令发送get数据
curl ‘请求url’
3、c++下使用curl命令:
#include <curl/curl.h>
CURL *curl; // 声明一个CURL对象
CURLcode res; //如果成功,会返回一个CURLE_OK标记,反之,会给你一个数字,你可以在curl.h里面找到对应的解释。
curl = curl_easy_init(); // 初始化一个Curl对象,它会生成一个CUrl的指针返回。如果返回是NULL,就是建立链接失败。
curl_slist *plist = curl_slist_append(NULL,
"Content-Type:application/json;charset=UTF-8");
char url_buffer[MAX_BUFFER_LEN_M];
url_buffer[0] = '\0';
char post_buffer[MAX_BUFFER_LEN_M];
post_buffer[0] = '\0';
bds_xl_str_t xl_str;
xl_str.clear();
snprintf(url_buffer, sizeof(url_buffer), g_conf.req_url.c_str());
snprintf(post_buffer, sizeof(post_buffer), "{\"acid\":%d,\"request\":{\"ids\":{\"type\":%d,\"id\":\"%s\"}}}",
g_conf.account_id, id_type, imei.c_str());
if (curl)
{
curl_easy_setopt(curl, CURLOPT_URL, url_buffer); // 请求地址
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, post_buffer); // 请求的post内容
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, plist); //将plist设置的字符串,附加到Http请求消息头上
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, write_buffer); // 设置回调接口write_buffer
curl_easy_setopt(curl, CURLOPT_WRITEDATA, &xl_str);// 指定一个对象,用于你在回调函数的时候将收到的数据片拼接成一个完整的。
curl_easy_setopt(curl, CURLOPT_NOSIGNAL, 1L); // //注意,毫秒超时一定要设置这个,否则会core
curl_easy_setopt(curl, CURLOPT_TIMEOUT_MS, 40L); // 设置超时时间(允许 cURL 函数执行的最长毫秒数。),如果服务器在40毫秒不返回,Curl就会触发一个TimeOUT错误,CURLOPT_TIMEOUT对应的是秒
res = curl_easy_perform(curl);//开始执行你的url下载活动,他返回一个CUrlRes 对象
if (CURLE_OK != res)
{
XGL_LOG_WARNING("Curl http request failed [%d]", res);
curl_slist_free_all(plist);
curl_easy_cleanup(curl);
return -1;
}
curl_slist_free_all(plist); //当你一次抓取执行完毕,你必须设置curl_slist_free_all(plist);除非你的plist在下次使用的时候和以前一样,则不必做这样的操作。但是最终你必须curl_slist_free_all(plist);否则会有内存泄露。
curl_easy_cleanup(curl);//当你执行完你的网页抓取,一定不要忘了curl_easy_cleanup(m_pCurl);释放你这个对象,否则同理,你的内存会泄露。
}
else
{
XGL_LOG_WARNING("Init curl failed");
return -1;
}
Json::Reader reader;
Json::Value value;
if (!reader.parse(xl_str.c_str(), xl_str.c_str() + xl_str.size(), value))
{
XGL_LOG_WARNING("Json parse failed [%s]", tdata.xl_str.c_str());
return -1;
}
回调函数:
size_t write_buffer(void *buffer, size_t size, size_t nmemb, void *userp)
{
if (!buffer)
{
XGL_LOG_WARNING("get_user_portray: return buffer is null");
}
if (size* nmemb > MAX_BUFFER_LEN_L -1)
{
XGL_LOG_WARNING("buffer is too long");
}
bds_xl_str_t *receive_str = static_cast<bds_xl_str_t*>(userp);
return receive_str->append((const char*)buffer, size * nmemb);
}
bds_xl_str_t的定义:
const size_t XL_STR_SIZE = 1024 * 16;
#define BDS_ASSERT(cond) bds_assert< (cond) >::assert_true() template <bool condition> struct bds_assert{}; template <> struct bds_assert<true> { static void assert_true(){} }; // 定长string wrapper template <size_t bucket> struct bds_str_t { bds_str_t() { BDS_ASSERT(bucket > 1024); data[0] = '\0'; len = 0; } inline void clear() { data[0] = '\0'; len = 0; } // 返回实际写入的字符数目,空间不足时,直接return 0,不进行写入 inline size_t append(const char* str, size_t str_len) { if (str_len > remains()) { return 0; } memcpy(data + len, str, str_len); len += str_len; data[len] = '\0'; return str_len; } inline size_t remains() const { return (len + 1) < bucket ? (bucket - len - 1) : 0; } inline const char * c_str() const { return data; } inline size_t size() const { return len; } char data[bucket]; size_t len; }; typedef bds_str_t<XL_STR_SIZE> bds_xl_str_t;

浙公网安备 33010602011771号