nodejs 爬虫 axios 异步爬虫 教程 【一】

axios 自定义headers

javascript 复制代码
axios.defaults.headers.common["User-Agent"] =

  "Googlebot/2.1 (+http://www.google.com/bot.html)";

运行环境:

node :v18

javascript 复制代码
const axios = require("axios");
axios.defaults.headers.common["User-Agent"] =
  "Googlebot/2.1 (+http://www.google.com/bot.html)";

async function crawler() {
  try {
    let task = [];
    console.log(new Date().getTime());
    console.time("run");

    for (let i = 1; i < 100; i++) {
      const url = `https://licai.cofool.com/ask/new-${i}.html`;
      const response = await axios.get(url);
      task.push(response);
    }

    const result = await Promise.all(task);
    for (let item of result) {
      ret_obj = item.data.length;
      console.log(ret_obj);
    }
    console.timeEnd("run");
    console.log(new Date().getTime());
  } catch (error) {
    console.error(error);
  }
}
for (let j = 0;; j++) {
  crawler();
}

程序不断遍历翻页url,从第一页到100页。然后是一个死循环。 要控制次数,可以在最后一行修改:

javascript 复制代码
for (let j = 0; j<100; j++) {
  crawler();
}

程序没有做解析html的功能,首先调试通过后,会输出获取的html的文档大小。

下一节课我们会带大家去解析html的内容。

相关推荐
自由日记18 小时前
python简单线性回归
开发语言·python·线性回归
程序员-周李斌18 小时前
Java NIO [非阻塞 + 多路复用解]
java·开发语言·开源软件·nio
猪八戒1.018 小时前
onenet接口
开发语言·前端·javascript·嵌入式硬件
h***839318 小时前
JavaScript开源
开发语言·javascript·ecmascript
Z***258018 小时前
JavaScript虚拟现实案例
开发语言·javascript·vr
Halo_tjn18 小时前
Set集合专项实验
java·开发语言·前端·python
席万里18 小时前
关于Go的init函数执行顺序#黑魔法
开发语言·网络·golang
橘子真甜~19 小时前
C/C++ Linux网络编程6 - poll解决客户端并发连接问题
服务器·c语言·开发语言·网络·c++·poll
safestar201219 小时前
React 19 深度解析:从并发模式到数据获取的架构革命
前端·javascript·react.js
9***Y4819 小时前
Java开发工具IntelliJ IDEA技巧
java·开发语言·intellij-idea