node.js - axios 内请求/Express 上的 POST 请求

标签 node.js express routes axios

如下所示,在我的 server.js 文件中,我有一个在表单提交时调用的/POST Info 请求。

我开始对阅读 app.post 和 Express 路线之间的差异感到困惑,以及无论如何使用路线是否会对我的代码有利。

在/POST 信息中,我对 2 个不同的 API 有两个 axios 请求,我认为将代码移到其他地方以使其更清晰是明智的。

了解这里的路线如何工作会对我有好处吗?如果您能解释这里的差异,那就太好了。

app.post('/Info', function (req, res) {
   var State = req.body.State;
   var income = Number(req.body.income);
   var zip = req.body.ZIP;
   axios.post('https://taxee.io/api/v2/calculate/2017', {
      //data sent to Taxee.io
      "exemptions": 1
      , "filing_status": "single"
      , "pay_periods": 1
      , "pay_rate": income || 100000
      , "state": State || "NY"
   }, {
         headers: {
            'Authorization': "Bearer <API_KEY>"
            //headers
         }
   }).then(function (response) {
      var obj = {
        income: '$' + income
        , fica: response.data.annual.fica.amount
        , federal: response.data.annual.federal.amount
        , residence: State + ", " + zip
        , state: response.data.annual.state.amount
      }
      axios.get("https://www.quandl.com/api/v3/datasets/ZILL/Z" + zip + "_RMP.json?api_key=<API_KEY>").then(function (response) {
         var monthRent = response.data.dataset.data[0][1]
         obj.rent = monthRent
         obj.yearlyRent = Number(monthRent) * 12;
      }).then(function (response) {
         res.send(obj);
      });
  }).catch(function (error) {
      alert('error');
  });
}

最佳答案

在 Express 应用程序中定义路由有两种方法:

直接使用 Express 应用程序 (app) 对象:

const express = require('express')
const app = express()

app.post(...)
app.get(...)
app.put(...)
// and so on

或者使用router对象:

const express = require('express')
const app = express()
const router = express.Router()

router.post(...)
router.get(...)
router.put(...)
// and so on

app.use(router)

我的猜测是,您已经阅读了带有 router 对象的后一段代码。使用 express 'Router对象确实可以使代码更清晰易读,因为有更多的关注点分离。

从您自己的 API 调用外部 API 没有任何问题。例如,在我的一个项目中,我在this上调用Google Calendar API。线。我的和你的唯一区别是我使用了 Google APIs Node.js Client当您使用标准 HTTP 请求时。我当然可以使用 HTTP 请求,如图所示 here .

您的代码很好,但可以改进。例如,代替:

axios.post('...', {
  exemptions: 1,
  filing_status: 'single',
  pay_periods: 1,
  pay_rate: income || 100000,
  state: State || 'NY'
})

您可以调用准备选项对象的辅助函数:

function prepareOptions (state = 'NY', income = 100000) {
  return {
    exemptions: 1,
    filing_status: 'single',
    pay_periods: 1,
    pay_rate: income,
    state: State
  }
}

然后这样调用它:

axios.post('...', prepareOptions(State, income))

这使得代码更具可读性。

最后,没有理由在服务器端使用axios。只需使用 Node 的内置 HTTP module .

关于node.js - axios 内请求/Express 上的 POST 请求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44912172/

相关文章:

ruby-on-rails - Rails 缺少模板

ruby-on-rails - Rails 路由逻辑

android - 在驾驶/步行期间在谷歌地图上绘制路径

javascript - 在 AngularJS 中使用数据库 - 我应该在哪里编写数据库连接代码?

javascript - Electron 在页面上保存用户更改

node.js - 如何在 mixin 中按名称获取变量

javascript - 从node.js中的不同文件设置环境变量?

node.js - 在 Node.js 中嵌套异步查询

node.js - (Flutter) Paytm 支付网关集成

node.js - 用于捕获错误处理的快速 Controller