0

我试图让我的模拟 API(json-server)以一种方式响应,如果客户端AUTH_TOKEN在他的请求的标头中发送了一个,如果他没有,则以另一种方式响应。这段代码是我正在使用的,它来自 json-server 文档。

const jsonServer = require('json-server')
const server = jsonServer.create()
const router = jsonServer.router('db.json')
const middlewares = jsonServer.defaults()

server.use(middlewares)
server.use((req, res, next) => {
 if (isAuthorized(req)) { // add your authorization logic here
   next() // continue to JSON Server router
 } else {
   res.sendStatus(401)
 }
})
server.use(router)
server.listen(3000, () => {
  console.log('JSON Server is running')
})

当然这可行,除了该isAuthorized(req)函数需要检查请求标头。我的isAuthorized函数如下所示(伪)。

const isAuthorized = (req) => {
  return req.getHeader('AUTH_TOKEN') ? true : false;
}

这不起作用,因为req没有getHeader方法,但我的意图很明确 - 我需要检查令牌,如果它存在则返回 true,否则返回 false。

我怎样才能做到这一点?

req.headers返回以下内容。

{
  host: 'localhost:3000',
  map: '[object Object]',
  'if-none-match': 'W/"a...........5r/3c"',
  accept: 'application/json, text/plain, */*',
  'user-agent': 'App/1 CFNetwork/887 Darwin/16.7.0',
  'accept-language': 'en-us',
  'accept-encoding': 'gzip, deflate',
  connection: 'keep-alive'
}

这与我在实际请求中发送的标头没有任何关系。

4

1 回答 1

3

下面是使用 expressjs。查看他们的文档(https://expressjs.com/en/4x/api.html),您似乎可以使用req.get('Header name here').

于 2017-10-30T09:03:03.680 回答