javascript - 如何使用服务器端 API 调用返回数据?
问题描述
我正在尝试在我的后端 node.js 应用程序中调用我的 api URL。以前我在前端 ajax 调用中传递了整个调用 url,但我想将它切换到服务器端 API 调用,这样我就不会暴露调用 url。我不熟悉在后端调用外部 API,所以我希望得到一些建议。我正在尝试使用 MVC 模式来保持代码干净。
这是控制器
require('dotenv').config();
module.exports = {
getModel: (req, res) => {
const { buildingNumber, commodity, meter, trainStart, trainEnd, analysisStart, analysisEnd } = req.query
try {
const model = process.env.API_URL + `building_number=${buildingNumber}&commodity_tag=${commodity}&meter=${meter}&train_start=${trainStart}&train_end=${trainEnd}&analysis_start=${analysisStart}&analysis_end=${analysisEnd}`
return res.json(model)
} catch (error) {
console.error(error.message)
}
}
}
这是我在前端 ajax 调用中使用的路由。
const router = require('express').Router()
const gatewayController = require('../controllers/apiGatewayModel')
router.get('/gateway', gatewayController.getModel);
module.exports = router
这是用于调用 api 的前端 ajax 调用。当我在前端运行这个 ajax 调用时,记录到控制台的响应是 api url。这是我尝试运行 ajax 调用后记录到控制台的示例。API_URL?building_number=0227&commodity_tag=S&meter=2032&train_start=2020-10-01&train_end=2021-09-29&analysis_start=2021-10-01&analysis_end=2021-10-31
我知道我只在控制台中返回 api url 的原因是因为我将 url 设置为控制器中的变量模型,然后我只是返回该模型变量。如何设置控制器以从 API 返回实际数据?任何意见是极大的赞赏!
const modelApi = function () {
const modelStart = $('.modelStart').val()
const modelEnd = $('.modelEnd').val()
const analysisStart = $('.analysisStart').val()
const analysisEnd = $('.analysisEnd').val()
$.ajax({
url: '/gateway',
method: 'GET',
data: {
buildingNumber: data[0][0].building_number,
commodity: data[0][0].commodity_tag,
meter: data[0][0].meter,
trainStart: modelStart,
trainEnd: modelEnd,
analysisStart: analysisStart,
analysisEnd: analysisEnd
}
}).then(response => {
console.log(response)
})
解决方案
只需使用 Axios 进行 API 调用
require('dotenv').config();
const axios = require('axios').default;
module.exports = {
getModel: async (req, res) => {
const { buildingNumber, commodity, meter, trainStart, trainEnd, analysisStart, analysisEnd } = req.query
try {
const model = `${process.env.API_URL}building_number=${buildingNumber}&commodity_tag=${commodity}&meter=${meter}&train_start=${trainStart}&train_end=${trainEnd}&analysis_start=${analysisStart}&analysis_end=${analysisEnd}`
const response = await axios.get(model)
return res.json(response.data)
} catch (error) {
console.error(error.message)
}
}
}
不使用 jQuery 获取调用 :)
const modelApi = async () => {
const modelStart = $('.modelStart').val()
const modelEnd = $('.modelEnd').val()
const analysisStart = $('.analysisStart').val()
const analysisEnd = $('.analysisEnd').val()
const res = await fetch('/gateway',
{
qs: {
buildingNumber: buildingNumber,
commodity: commodity,
meter: meter,
trainStart: trainStart,
trainEnd: trainEnd,
analysisStart: analysisStart,
analysisEnd: analysisEnd}
}).json();
console.log(res)
}
推荐阅读
- python - 如何打印用户从该列表中输入名称的完整列表?PYTHON
- sharepoint - ID 文档, ID 文件夹 SharePoint-Online
- javascript - 设置dom的innerHTML后页面没有响应
- redis - 在某些键上使用 TTL 调试 redis db
- python - Python - 迭代嵌套的 JSON 数据问题
- python - 使用烧瓶动态显示图像
- c# - 我如何用 Open XML 替换 Interop DLL,因为 Interop DLL 在 RDS 服务器中有访问问题
- linux - 我如何使用任何命令来剪切命令输出
- javascript - ajax POST 问题 - 500 内部服务器错误
- c# - C# 正则表达式:解析日志级别