使用 Got 在 Nodejs 中发出 HTTP 请求

在 node.js 中构建应用程序时,无论您是与外部 api 交互、获取数据还是在服务之间通信,发出 http 请求都是一项基本任务。虽然 node.js 具有用于发出请求的内置 http 模块,但它并不是最用户友好或功能丰富的解决方案。这就是像 got 这样的图书馆的用武之地。

got 是一个轻量级、功能丰富且基于 promise 的 node.js http 客户端。它简化了发出 http 请求的过程,提供了干净的 api、自动重试、对流的支持等等。在本文中,我们将探讨如何使用 got 来发出 http 请求和处理错误。

为什么选择 got 来处理 http 请求?

在深入研究代码之前,了解为什么 got 是许多开发人员的首选是很重要的:

简单的 api: got 提供了干净直观的 api,可以轻松执行各种类型的 http 请求。基于 promise: got 完全基于 promise,允许您使用 async/await 语法来获得更清晰、更易读的代码。自动重试: got 可以在网络故障或其他问题时自动重试请求,这对于提高应用程序的可靠性特别有用。支持流: got 支持流,这对于下载大文件或处理块数据非常有用。可定制: got 是高度可定制的,可以选择修改标头、查询参数、超时等。

安装got

要开始使用 got,您首先需要将其安装到 node.js 项目中。如果您尚未设置 node.js 项目,请按照以下步骤操作:

初始化您的项目:打开终端并为您的项目创建一个新目录:

   mkdir got-http-requests   cd got-http-requests   npm init -y

此命令创建一个新的项目目录并使用 package.json 文件对其进行初始化。

安装 got: 接下来,使用 npm 安装 got:

   npm install got

got 现已添加到您的项目中,您可以开始使用它来发出 http 请求。

使用 got 发出 http 请求

got 可以轻松执行各种类型的 http 请求。让我们来看看一些常见的用例。

1. 发出基本的 get 请求

get 请求是最常见的 http 请求类型,通常用于从服务器检索数据。使用 got,发出 get 请求非常简单:

const got = require('got');(async () => {    try {        const response = await got('https://jsonplaceholder.typicode.com/posts/1');        console.log('get request:');        console.log(response.body);    } catch (error) {        console.error('error in get request:', error.message);    }})();

说明:endpoint: https://jsonplaceholder.typicode.com/posts/1 是一个测试 api,返回 id 为 1 的帖子的详细信息。got 语法:got(url) 函数向指定的 url 发送 get 请求。响应被作为承诺处理,允许我们使用await来等待响应。响应: 响应正文记录到控制台,其中将包含帖子的 json 数据。

2. 发出 post 请求

post 请求用于将数据发送到服务器,通常用于创建新资源。使用 got,您可以轻松地在 post 请求中发送 json 数据:

const got = require('got');(async () => {    try {        const response = await got.post('https://jsonplaceholder.typicode.com/posts', {            json: {                title: 'foo',                body: 'bar',                userid: 1            },            responsetype: 'json'        });        console.log('post request:');        console.log(response.body);    } catch (error) {        console.error('error in post request:', error.message);    }})();

说明:端点: https://jsonplaceholder.typicode.com/posts 用于在服务器上创建新帖子。json 数据: got 请求中的 json 选项允许您指定要发送的数据。在这里,我们将发送一篇带有标题、正文和用户 id 的新帖子。响应: 服务器的响应(包括与新 id 一起发送的数据)会记录到控制台。

3. 处理错误

http 请求期间可能会出现网络问题或服务器错误。 got 提供了一种简单的方法来处理这些错误:

const got = require('got');(async () => {    try {        const response = await got('https://nonexistent-url.com');        console.log(response.body);    } catch (error) {        console.error('error handling example:', error.message);    }})();

说明:不存在的 url: 此示例尝试向不存在的 url 发出 get 请求。错误处理: 当请求失败时 got 自动抛出错误。 catch 块捕获此错误并将错误消息记录到控制台。

got 的高级功能

got 不仅仅是发出简单的 get 和 post 请求。它配备了一些高级功能,可以帮助您处理更复杂的场景。

1. 自定义请求选项

got 允许您通过设置标头、查询参数、超时等来自定义请求:

const got = require('got');(async () => {    try {        const response = await got('https://jsonplaceholder.typicode.com/posts/1', {            headers: {                'user-agent': 'my-custom-agent'            },            searchparams: {                userid: 1            },            timeout: 5000        });        console.log('customized request:');        console.log(response.body);    } catch (error) {        console.error('error in customized request:', error.message);    }})();

说明:标头: 您可以使用 headers 选项设置自定义标头。在这里,我们设置了一个自定义的 user-agent。查询参数: searchparams 选项允许您向 url 添加查询参数。超时: 超时选项设置请求在抛出错误之前可以花费的最长时间(以毫秒为单位)。

2. 与 got 一起直播

got 支持流式传输,这对于处理大数据或处理文件很有用:

const fs = require('fs');const got = require('got');(async () => {    const downloadStream = got.stream('https://via.placeholder.com/150');    const fileWriterStream = fs.createWriteStream('downloaded_image.png');    downloadStream.pipe(fileWriterStream);    fileWriterStream.on('finish', () => {        console.log('Image downloaded successfully.');    });})();

说明:流式传输: got.stream(url) 函数发起流式 get 请求。数据直接通过管道传输到可写流,例如文件。文件写入: fs.createwritestream() 函数用于将流式数据写入文件。

使用 Got 在 Nodejs 中发出 HTTP 请求

在这里下载源代码。

结论

got 是一个多功能且强大的库,用于在 node.js 中发出 http 请求。它通过提供干净直观的 api 简化了与 web 服务交互的过程,同时还提供错误处理、超时和流等高级功能。无论您是构建简单的脚本还是复杂的应用程序,got 都是处理 http 请求的绝佳选择。

通过使用 got,您可以编写更清晰、更易于维护的代码,并利用其强大的功能集来满足您的应用程序的需求。因此,下次您需要在 node.js 中发出 http 请求时,请考虑使用 got 以获得无忧无虑的体验。

感谢您的阅读…

快乐编码!

文章 making http requests in node.js with got 首次出现在 innovate with folasayo 上。

文章 making http requests in node.js with got 首先出现在 innovate with folasayo 上。

以上就是使用 Got 在 Nodejs 中发出 HTTP 请求的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1490894.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 13:31:49
下一篇 2025年12月19日 13:32:04

相关推荐

  • uniapp 中图片加载显示灰块,如何排查问题?

    uniapp 图片加载灰块问题排查 在 uniapp 中使用 image 组件时,可能会遇到图片加载不出来的情况,显示为灰色的占位区块。导致此问题的主要原因是: base64 代码不正确 使用 base64 编码加载图片时,如果编码有误,浏览器将无法正确解析和渲染图片。这会导致出现灰色的占位块。 解…

    2025年12月24日
    000
  • 配置 Tailwind CSS:初始化指南 |设置 Tailwind CSS:初始化指南

    简介 |简介意大利语:本文有意大利语和英语版本。向下滚动查看英文版本。英语:本文有意大利语和英语版本。向下滚动查看英文版本。 意大利语版 如何开始使用 tailwind css:项目完整指南 简介 在项目中配置 tailwind css 第一次似乎令人畏惧,特别是对于像我这样第一次尝试这个库的人来说…

    2025年12月24日
    000
  • 如何设置独立 CLI:在 Shopify 中使用 Tailwind CSS,而不使用 Nodejs

    依赖关系 Shopify CLI:一种命令行界面工具,可帮助您开发和管理 Shopify 主题。TailwindCSS:实用程序优先的 CSS 框架,用于快速构建自定义设计。 设置 我们使用 Tailwind 作为独立的 CLI 工具。更多信息可以参考官方指南。 注意:如果您在配备 Intel 处理…

    2025年12月24日
    000
  • css中文手册当前页面发生错误怎么办

    发生“当前页面发生错误”错误时,请依次尝试:检查网络连接;刷新页面;清除浏览器缓存;禁用浏览器扩展;检查浏览器版本;联系网站管理员;尝试其他浏览器;查看浏览器控制台。 CSS 中文手册当前页面发生错误怎么办 当您在使用 CSS 中文手册时遇到当前页面发生错误的情况,可以采用以下步骤进行排查和解决: …

    2025年12月24日
    000
  • 谷歌怎么下载html5_HTML5无需下载浏览器直接渲染运行页面文件【说明】

    HTML5不是需下载的软件,而是浏览器原生标准;Chrome默认支持,可通过file://协议直接打开本地.html文件,或用http-server启动本地服务器以支持完整API功能。 如果您已编写好HTML5页面文件,但误以为需要“下载HTML5”才能运行,则需明确:HTML5不是可下载的独立软件…

    2025年12月23日
    000
  • 手机编程html5工具_移动端代码编辑器推荐【指南】

    推荐五款移动端HTML5编辑器:Acode Editor支持一键预览;DroidEdit Pro可FTP/SFTP远程编辑;Codeanywhere提供云端IDE与Git集成;SpckEditor专注极简单页开发;Termux组合方案实现命令行本地服务。 如果您希望在手机上直接编写、调试和预览 HT…

    2025年12月23日
    000
  • 使用JavaScript实现动态货币转换:多价格同步更新与避免重复计算的教程

    本教程将指导您如何使用javascript动态地将多个价格转换为不同货币,并同步更新显示。我们将探讨如何从外部api获取汇率、正确选择和更新多个html元素,以及如何通过存储初始值来避免在多次转换中出现累积计算错误,确保价格始终基于原始值进行准确转换。 在现代Web应用中,动态货币转换是一个常见的需…

    2025年12月23日
    000
  • Django模板中实现可点击图片链接的正确方法

    本文详细介绍了在django模板中正确设置可点击图片链接的方法。核心在于将“标签嵌套在“标签内部,并强调了使用`alt`和`title`属性来提升网页的可访问性和用户体验,避免了常见的链接无效问题。 在Web开发中,将图片设置为可点击的链接是一个非常常见的需求,例如网站的Logo通常会…

    2025年12月23日 好文分享
    000
  • 在 HTML Canvas 中正确应用自定义字体:常见陷阱与解决方案

    在 html canvas 上应用自定义字体时,开发者常遇到字体不生效的问题。主要原因在于多词字体名称需要使用引号包裹,并且外部字体必须在绘制前通过 `document.fonts.ready` 确保加载完成。本文将详细讲解这些关键点,并提供实用的代码示例,帮助您在 canvas 中准确渲染自定义文…

    2025年12月23日
    000
  • 优化Leaflet弹出层图片显示:条件渲染策略

    本文旨在解决leaflet地图弹出窗口中因图片链接缺失而导致的“图片损坏”图标问题。通过引入javascript条件渲染策略,确保仅当图片url有效时才生成并显示标签,从而有效提升用户体验,避免不必要的视觉干扰,使地图弹出层内容呈现更加专业和清晰。 在开发基于Leaflet的交互式地图应用时,我们经…

    2025年12月23日 好文分享
    000
  • Leaflet地图弹窗图片加载优化:动态处理缺失图片链接以避免破损图标

    本文旨在解决leaflet地图弹窗中因图片链接缺失而导致显示破损图标的问题。通过动态判断图片链接是否存在,仅当链接有效时才渲染“标签,从而避免了无效图片源的加载,提升用户体验。此方法适用于需要根据数据动态展示内容的场景,确保界面内容的完整性和专业性。 在Leaflet地图应用中,开发者经常需要为地…

    2025年12月23日 好文分享
    000
  • Linux polybar状态栏,HTML+CSS加载进度实时!

    可通过 Bash 脚本在 Polybar 中模拟 HTML+CSS 风格进度条,利用 %{F#color} 标记和块字符 ▮ 动态显示已完成与未完成部分,结合实时任务进度输出格式化文本。 如果您希望在 Linux 的 Polybar 状态栏中显示一个基于 HTML+CSS 风格的加载进度条,并实时反…

    2025年12月23日
    000
  • Node.js Puppeteer爬虫的部署与自动化运行指南

    本教程详细指导如何部署基于node.js和puppeteer的网络爬虫,并实现其自动化定时执行。文章区分了前端静态网站与后端node.js脚本的部署策略,重点介绍了在windows环境下使用任务计划程序(task scheduler)进行定时任务配置的方法,同时提及了cors问题产生的原因及解决方案…

    2025年12月23日
    000
  • Linux Debian用Gulp自动化,CSS编译HTML零等待!

    首先安装Node.js与npm,再初始化项目并安装Gulp及插件,接着配置gulpfile.js定义Sass编译与浏览器同步任务,最后通过gulp命令启动自动化流程,实现CSS即时编译与HTML实时更新。 如果您希望在Linux Debian系统中通过Gulp实现自动化工作流,以达到CSS即时编译、…

    2025年12月23日
    000
  • Node.js爬虫的服务器端部署与定时任务配置指南

    本文旨在指导开发者如何部署基于%ignore_a_1%的puppeteer网络爬虫,并实现其定时自动化运行。针对本地开发环境,文章详细介绍了利用windows任务计划程序配置定时任务的步骤,确保node.js脚本能按预设时间自动执行,更新数据。同时,文章也探讨了生产环境下的部署思路,强调了客户端与服…

    2025年12月23日
    000
  • JavaScript教程:从API获取并正确渲染动态新闻列表

    本教程旨在解决从API获取数据并将其动态渲染到HTML页面时常见的逻辑错误。我们将深入探讨如何使用JavaScript的`fetch` API获取外部数据,并重点讲解如何利用数组的`map()`方法结合`join(”)`高效且正确地将多个数据项转换为HTML结构,最终更新DOM,避免常见…

    2025年12月23日 好文分享
    000
  • Node.js爬虫的部署、调度与静态网站数据集成指南

    本教程详细阐述如何部署和自动化运行node.js网络爬虫,实现定时数据抓取并更新静态网站内容。我们将探讨node.js脚本的服务器端运行机制、windows任务计划程序等调度工具的配置,以及爬取数据与静态html页面集成的策略,旨在帮助您构建高效且自动化的数据更新流程。 1. 理解Node.js爬虫…

    2025年12月23日
    000
  • 部署与自动化运行Node.js网络爬虫:使用Windows任务计划程序

    本文将指导您如何部署一个基于node.js和puppeteer的网络爬虫,并利用windows任务计划程序实现其每日定时自动运行。我们将深入探讨服务器端脚本与静态网页的区别,提供详细的步骤配置任务计划,并讨论在自动化过程中需要注意的关键事项,如资源管理、错误处理及跨平台部署思路。 理解Node.js…

    2025年12月23日
    000
  • 部署与调度Node.js爬虫:从本地执行到云端集成

    本教程详细指导如何部署和调度一个基于node.js的网页爬虫,使其能够每日自动运行并将其数据提供给前端应用。文章将区分客户端与服务器端javascript的运行环境,介绍本地任务调度方法,并探讨将爬虫集成到在线服务以实现数据共享的策略,同时涵盖数据持久化、cors处理及部署最佳实践。 1. 理解No…

    2025年12月23日
    000
  • nodejs如何打开html_Node.js环境中HTML文件打开方法

    如果您在Node.js环境中需要打开或提供HTML文件的访问,通常意味着您希望启动一个本地服务器来渲染并展示HTML页面。以下是实现该功能的具体方法: 一、使用内置http模块创建服务器 通过Node.js的内置http模块可以快速搭建一个简易服务器,用于读取并返回HTML文件内容给客户端浏览器。 …

    2025年12月23日
    000

发表回复

登录后才能评论
关注微信