目录
四、查看README | docs |INSTALL 安装指导
①:指定配置路径(./configure --prefix=指定配置的路径)
③:make install 安装生成 ./configure --prefix=指定的文件夹
二、代码将获取到的网页信息存储在/tmp/get.html中
前言
(一)什么是libcurl库?
参考:百度百科
通俗易懂:libcurl就是用不同的协议(http.....)连接和访问不同的服务器。
例子 :本文通过http协议访问百度网页
(二)如何安装libcurl库?
一、下载libcurl库(libcurl库)
自定义下载libcurl版本
二、window拷贝ubuntu中(自定义拷贝方式)
三、指令解压
sudo tar zxvf curl-7.71.1.tar.gz
四、查看README | docs |INSTALL 安装指导
瞎摸索------最后打开vi INSTALL.md找到libcurl库的编译步骤
五、编译步骤
①:指定配置路径(./configure --prefix=指定配置的路径)
①:./configure --prefix=/usr/libcurl
②:make编译
make
③:make install 安装生成 ./configure --prefix=指定的文件夹
注意:以上便安装libcurl库成功
(三)准备撸起代码调用libcurl库访问百度网页
一、撸代码
#include <stdio.h>
#include <curl/curl.h>
#define true 1
#define false 2
typedef unsigned int bool;
bool getUrl(char *filename)
{
CURL *curl;
CURLcode res;
FILE *fp;
if ((fp = fopen(filename, "w")) == NULL) // 返回结果用文件存储
return false;
struct curl_slist *headers = NULL;
headers = curl_slist_append(headers, "Accept: Agent-007");
curl = curl_easy_init(); // 初始化
if (curl)
{
//curl_easy_setopt(curl, CURLOPT_PROXY, "10.99.60.201:8080");// 代理
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, headers);// 改协议头
curl_easy_setopt(curl, CURLOPT_URL,"http://www.baidu.com");
curl_easy_setopt(curl, CURLOPT_WRITEDATA, fp); //将返回的http头输出到fp指向的文件
curl_easy_setopt(curl, CURLOPT_HEADERDATA, fp); //将返回的html主体数据输出到fp指向的文件
res = curl_easy_perform(curl); // 执行
if (res != 0) {
curl_slist_free_all(headers);
curl_easy_cleanup(curl);
}
fclose(fp);
return true;
}
}
bool postUrl(char *filename)
{
CURL *curl;
CURLcode res;
FILE *fp;
if ((fp = fopen(filename, "w")) == NULL)
return false;
curl = curl_easy_init();
if (curl)
{
curl_easy_setopt(curl, CURLOPT_COOKIEFILE, "/tmp/cookie.txt"); // 指定cookie文件
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, "&logintype=uid&u=xieyan&psw=xxx86"); // 指定post内容
//curl_easy_setopt(curl, CURLOPT_PROXY, "10.99.60.201:8080");
curl_easy_setopt(curl, CURLOPT_URL, " http://mail.sina.com.cn/cgi-bin/login.cgi "); // 指定url
curl_easy_setopt(curl, CURLOPT_WRITEDATA, fp);
res = curl_easy_perform(curl);
curl_easy_cleanup(curl);
}
fclose(fp);
return true;
}
int main(void)
{
getUrl("/tmp/get.html");
postUrl("/tmp/post.html");
}
二、代码将获取到的网页信息存储在/tmp/get.html中
三、编译代码
gcc libcurl.c -I /usr/libcurl/include/ -L /usr/libcurl/lib/ -lcurl
-I 路径----->指定编译器在指定的路径找头文件
-L 路径----->指定编译器在指定的路径链接库
四、查看效果
vi /tmp/get.html
总结:如果最后编译没问题,打开get.html 文件内容空或者没有生成此文件,检车设备联网状态