2

我使用 micro 创建了一个小 api。

运行localhost:3000/get-status应该返回数据对象。到目前为止,console.log()正在打印预期的对象。

但是在我得到的浏览器Endpoint not found和服务器上我得到了错误Si7021 reset failed: Error [ERR_HTTP_HEADERS_SENT]: Cannot set headers after they are sent to the client

我的getStatus()功能做错了什么?我想我已经把一些东西与承诺和异步的东西混为一谈了。也许我不必要地嵌套了函数......

const { send } = require('micro')
const { router, get } = require('microrouter')
const Si7021 = require('si7021-sensor')

const getStatus = async (req, res) => {
  const si7021 = new Si7021({ i2cBusNo: 1 })
  const readSensorData = async () => {
    const data = await si7021.readSensorData()
    console.log(data)
    send(res, 201, { data })
  }

  si7021.reset()
    .then((result) => readSensorData())
    .catch((err) => console.error(`Si7021 reset failed: ${err} `))
}

const notFound = (req, res) => {
  console.log('NOT FOUND.')
  send(res, 404, 'Endpoint not found')
}

module.exports = router(
  get('/get-status', getStatus),
  get('/*', notFound)
)
4

1 回答 1

2

看起来您的处理程序返回了一个立即解决的承诺。您可以尝试像这样重写最后一行吗?

return si7021.reset()
    .then((result) => readSensorData())
    .catch((err) => console.error(`Si7021 reset failed: ${err}`));

它可以更简洁地写成:

const getStatus = async (req, res) => {
  try {
    const si7021 = new Si7021({ i2cBusNo: 1 });
    await si7021.reset();
    const data = await si7021.readSensorData();
    console.log(data);
    return send(res, 201, { data });
  } catch (e) {
    console.error(`Si7021 reset failed: ${err}`)
  }
}

但是您可能还想在catch处理程序中发送一些东西。

另外,请注意,承诺从

si7021.reset()
    .then((result) => readSensorData());

不仅在.reset失败时拒绝。它也拒绝readSensorData失败。所以你的错误信息不完整。总而言之,我宁愿推荐以下内容:

const getStatus = async (req, res) => {
  try {
    const si7021 = new Si7021({ i2cBusNo: 1 });
    await si7021.reset();
    const data = await si7021.readSensorData();
    console.log(data);
    send(res, 201, { data });
  } catch (e) {
    console.error(`Si7021 failed: ${err.message}`);
    send(res, 500, err.message);
  }
}
于 2018-10-08T09:45:23.880 回答