用libcurl访问百度并获取返回数据

库的安装

下载

https://github.com/curl/curl/releases/tag/curl-7_71_1

安装

将下载的包放在ubuntu中
在这里插入图片描述
安装步骤如下

    ./configure
    make
    make test (optional)//安装选项,可以不选,省去这一步
    make install//默认安装可能安装到/usr/lib中,需要root权限

依次输入

./configure --prefix=$PWD/_install
make -j8
make install

–prefix是编译选项,用于指定编译安装路径
此外还有
–host=arm-linux-gcc
可以用来指定交叉编译工具,比如用arm-linux-gcc编译完可以放在树莓派上运行

在这里插入图片描述
安装完成后可以看到在指定路径下生成了我们的目标文件夹
在这里插入图片描述
我们要用到的就是着一些头文件

访问百度

#include <stdio.h>
#include <curl/curl.h>

#define true 1
#define false 0
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;
    }
}
int main(void)
{   
    getUrl("/tmp/get.html");
}

这里要注意的是,C语言中没有bool这个变量,c++才会有
所以要用typedef来定义这个变量

编译

gcc demo1.c -I ~/tools/curl-7.71.1/_install/include/ -L ~/tools/curl-7.71.1/_install/lib/ -lcurl

配置临时环境变量

export LD_LIBRARY_PATH=~/tools/curl-7.71.1/_install/lib/

现象

vim /tmp/get.html 

在函数指定文件夹中可以看到拿到的数据
在这里插入图片描述
前几行可以参考https://blog.csdn.net/qq_28258885/article/details/112093574
如第一行为

  • 协议版本
  • 访问成功的状态码
  • 状态码的解释

在这里插入图片描述
后面这些就是百度的代码
打开百度,右键–查看网页源码
在这里插入图片描述
发现一致

用户界面只是使用前端技术将这些代码排版过的

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
以下是一个简单的使用libcurl访问百度网站的示例,并使用变量接收返回值并统计请求时间: ```c++ #include <iostream> #include <string> #include <curl/curl.h> #include <chrono> using namespace std::chrono; // 回调函数,处理返回数据 static size_t write_callback(char* ptr, size_t size, size_t nmemb, std::string* data) { data->append(ptr, size * nmemb); return size * nmemb; } int main() { // 初始化libcurl CURL* curl = curl_easy_init(); if (!curl) { std::cerr << "Failed to initialize libcurl" << std::endl; return 1; } // 设置请求的URL curl_easy_setopt(curl, CURLOPT_URL, "http://www.baidu.com"); // 创建一个string来保存返回数据 std::string response; // 设置回调函数,处理返回数据 curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, write_callback); curl_easy_setopt(curl, CURLOPT_WRITEDATA, &response); // 发送请求并计时 auto start = steady_clock::now(); CURLcode res = curl_easy_perform(curl); auto end = steady_clock::now(); auto duration = duration_cast<milliseconds>(end - start); // 检查请求是否成功 if (res != CURLE_OK) { std::cerr << "Failed to send request: " << curl_easy_strerror(res) << std::endl; curl_easy_cleanup(curl); return 1; } // 输出返回数据和请求时间 std::cout << "Response: " << response << std::endl; std::cout << "Request time: " << duration.count() << "ms" << std::endl; // 清理并释放资源 curl_easy_cleanup(curl); return 0; } ``` 该示例中使用了C++11中的chrono库来计时,使用了CURLcode枚举类型来检查请求是否成功。运行该程序,将输出百度网站返回的HTML代码和请求所花费的时间。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Spark!

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值