欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Node.js?中使用fetch?按JSON格式發(fā)post請(qǐng)求的問題解析

 更新時(shí)間:2023年04月01日 14:19:06   作者:loseran  
最近在測(cè)試一個(gè)api,可以用curl命令直接訪問,指定header相關(guān)配置,request?body(JSON),成功后返回一個(gè)JSON,這篇文章主要介紹了Node.js?中使用fetch?按JSON格式發(fā)post請(qǐng)求,需要的朋友可以參考下

Node.js 中使用fetch 按JSON格式發(fā)post請(qǐng)求

最近在測(cè)試一個(gè)api,可以用curl命令直接訪問,指定header相關(guān)配置,request body(JSON),成功后返回一個(gè)JSON。

原本想搞個(gè)靜態(tài)頁面html,在script標(biāo)簽里用fetch做個(gè)簡(jiǎn)單的demo的,結(jié)果就遇到跨域問題。遂使用后端請(qǐng)求,就想到了Nodejs。

既然有現(xiàn)成的工具,那就使用唄。

環(huán)境node --version: 18.15.0

1.全局安裝express-generator:

npm i express-generator -g

2.生成一個(gè)測(cè)試項(xiàng)目:

express nodepost

3. 安裝依賴

cd nodepostnpm install

4.試運(yùn)行(沒有意外的話可以在瀏覽器輸入 localhost:3000,看到Express 歡迎頁)

npm start

5. VSCODE編輯

code .

6.修改routers/index.js, 增加以下代碼段,注意按你實(shí)際配置來(url, requestData, authkey...)

router.get('/json', (req, res, next) => {
  let success = true;
  const data = {
    k: 'your real data'
  };
  fetch('https://example.com/api/g', {
    method: 'POST',
    body: JSON.stringify(data),
    headers: {
      'Content-type': 'application/json; charset=UTF-8',
      'Authorization': 'your real auth key if neccessory, otherwise you could not config this item',
 
    },
  }
  ).then((res) => res.json())
  .then((json) => console.log(json))
  .catch(err => {
    success = false;
    console.log('err:', err);
  })
  res.json({
    success
  })
});

7.訪問 localhost:3000/json, 不出問題的話能在后端控制臺(tái)查看請(qǐng)求結(jié)果

PLUS:

選擇新版本的Node,不能低于17.5.0,否則不能直接使用fecth,在文末有補(bǔ)充說明。

低版本用node-fetch庫或者原生的http模塊, node-fetch我自己導(dǎo)入一直有問題,原生http模塊要寫不少東西,故不采用。

補(bǔ)充:寫 Node.js,終于能用 Fetch 發(fā)請(qǐng)求了

Node.js 支持 Fetch API 啦!

2d16016182ed529566e3d653aad395e2.png

在以前,使用原生的 Node.js API 發(fā)送一個(gè) HTTP 請(qǐng)求非常麻煩,你可能要寫下面的代碼:

const https = require('https')
const options = {
  hostname: 'nodejs.cn',
  port: 443,
  path: '/todos',
  method: 'GET'
}
 
const req = https.request(options, res => {
  console.log(`狀態(tài)碼: ${res.statusCode}`)
 
  res.on('data', d => {
    process.stdout.write(d)
  })
})
 
req.on('error', error => {
  console.error(error)
})
 
req.end()

所以通常,我們可能會(huì)引入一些第三方的 NPM 包,比如 axios、needle、node-fetch、request 這些。

98596c3df330bcde4f0a791f59df4541.png

在最新的 Node.js v17.5 版本中,增加了對(duì) Fetch API 的支持,所以無需借助這些第三方 HTTP 請(qǐng)求庫啦。

Fetch API 可能大家都比較熟悉了,他是當(dāng)前最流行的跨平臺(tái) HTTP Client API ,目前已經(jīng)可以在瀏覽器和 Web/Service Workers 中運(yùn)行,當(dāng)前 Web 環(huán)境里用到最多的請(qǐng)求方式應(yīng)該就是它了。

Node.js 中的Fetch API 基于 Undici 實(shí)現(xiàn),它提供了一個(gè) WHATWG 標(biāo)準(zhǔn)接口來獲取資源,并且也是基于 Promise 的,使用方式基本和瀏覽器中一致,包括四個(gè)核心模塊:

  • fetch() - 用于發(fā)起請(qǐng)求的函數(shù)
  • Headers 類 - 用于處理請(qǐng)求頭和響應(yīng)頭
  • Request 類 - 表示傳入請(qǐng)求的實(shí)例
  • Response 類 - 表示傳入響應(yīng)的實(shí)例
const res = await fetch('https://www.conardli.top');
const json = await res.json();
console.log(json);

其實(shí)這并不是簡(jiǎn)單的支持了一個(gè)新的原生 HTTP 請(qǐng)求庫那么簡(jiǎn)單,這意味著很多之前在 Web 中用到 FetchNPM 包也可以在 Node.js 里以同樣的方式工作了,這些包同樣可以實(shí)現(xiàn)跨平臺(tái)兼容了~

Node.js v17.5 中,它還是個(gè)實(shí)驗(yàn)特性,現(xiàn)在想要試用的話可以通過 node --experimental-fetch flag 開啟。

Fetch 的優(yōu)勢(shì)在于它是原生支持,并且可以兼容多平臺(tái),其他的請(qǐng)求庫估計(jì)都要慢慢的靠邊站了~ 對(duì)此你有啥看法?

到此這篇關(guān)于Node.js 中使用fetch 按JSON格式發(fā)post請(qǐng)求的文章就介紹到這了,更多相關(guān)Node.js fetch post請(qǐng)求內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解Node.js中間件是怎樣工作的

    詳解Node.js中間件是怎樣工作的

    這篇文章主要介紹了詳解Node.js中間件是怎樣工作的,對(duì)中間件感興趣的同學(xué),可以參考下
    2021-04-04
  • Node.js包管理器代理工具Verdaccio輕松創(chuàng)建管理本地npm包倉庫

    Node.js包管理器代理工具Verdaccio輕松創(chuàng)建管理本地npm包倉庫

    這篇文章主要為大家介紹了Node.js包管理器代理工具Verdaccio輕松創(chuàng)建管理本地npm包倉庫的使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-10-10
  • node版本切換與版本升級(jí)降級(jí)教程(win)

    node版本切換與版本升級(jí)降級(jí)教程(win)

    nvm是一個(gè)node的版本管理工具,可以簡(jiǎn)單操作node版本的切換、安裝、查看,下面這篇文章主要給大家介紹了關(guān)于node版本切換與版本升級(jí)降級(jí)教程的相關(guān)資料,需要的朋友可以參考下
    2022-11-11
  • node.js多個(gè)異步過程中判斷執(zhí)行是否完成的解決方案

    node.js多個(gè)異步過程中判斷執(zhí)行是否完成的解決方案

    這篇文章主要給大家介紹了關(guān)于node.js多個(gè)異步過程中判斷執(zhí)行是否完成的幾種解決方案,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起看看吧。
    2017-12-12
  • 深入理解nodejs中Express的中間件

    深入理解nodejs中Express的中間件

    一個(gè)Express應(yīng)用就是在調(diào)用各種中間件??梢娭虚g件在web應(yīng)用開發(fā)中的重要性,有興趣的可以了解一下
    2017-05-05
  • NodeJS學(xué)習(xí)筆記之Module的簡(jiǎn)介

    NodeJS學(xué)習(xí)筆記之Module的簡(jiǎn)介

    模塊是Node.js 應(yīng)用程序的基本組成部分,文件和模塊是一一對(duì)應(yīng)的。換言之,一個(gè) Node.js 文件就是一個(gè)模塊,這個(gè)文件可能是JavaScript 代碼、JSON 或者編譯過的C/C++ 擴(kuò)展。
    2017-03-03
  • express框架實(shí)現(xiàn)基于Websocket建立的簡(jiǎn)易聊天室

    express框架實(shí)現(xiàn)基于Websocket建立的簡(jiǎn)易聊天室

    本篇文章主要介紹了express框架實(shí)現(xiàn)基于Websocket建立的簡(jiǎn)易聊天室,具有一定的參考價(jià)值,有興趣的可以了解一下
    2017-08-08
  • 初始Nodejs

    初始Nodejs

    本文屬于nodejs的基礎(chǔ)知識(shí)介紹篇,從nodejs的基本概念,到架構(gòu)示意圖,同步異步等方面做了詳細(xì)的解答,是篇非常不錯(cuò)的文章
    2014-11-11
  • 在Node.js應(yīng)用程序中處理大數(shù)的操作指南

    在Node.js應(yīng)用程序中處理大數(shù)的操作指南

    在JavaScript生態(tài)系統(tǒng)中,你可以使用BigInt來處理大整數(shù),但是,你也可以使用具有類似于BigInt功能的第三方庫,本文將是使用BigInt和提供類似功能的流行庫管理大數(shù)的完整指南,我們還將比較第三方庫的用例、優(yōu)勢(shì)和劣勢(shì)
    2023-06-06
  • node.js+jQuery實(shí)現(xiàn)用戶登錄注冊(cè)AJAX交互

    node.js+jQuery實(shí)現(xiàn)用戶登錄注冊(cè)AJAX交互

    本篇文章主要介紹了用Node.js當(dāng)作后臺(tái)、jQuery寫前臺(tái)AJAX代碼實(shí)現(xiàn)用戶登錄和注冊(cè)的功能的相關(guān)知識(shí)。具有很好的參考價(jià)值。下面跟著小編一起來看下吧
    2017-04-04

最新評(píng)論