2

我不太了解节点中的流。我尝试将我的应用程序的请求和响应信息保存到 mongodb。

首先,我想为 morgan 的结果设置一个变量:

var apiInfo = morgan('dev')
   app.use(console.log('test______',apiInfo))

但是,它不起作用。我在摩根官方网站上知道这一点:

var express = require('express')
var fs = require('fs')
var morgan = require('morgan')
var path = require('path')

var app = express()

// create a write stream (in append mode)
var accessLogStream = fs.createWriteStream(path.join(__dirname, 'access.log'), {flags: 'a'})

// setup the logger
app.use(morgan('combined', {stream: accessLogStream}))

app.get('/', function (req, res) {
  res.send('hello, world!')
})

但我不想将结果保存到 access.log,我只想将结果保存到变量 apiInfo。

4

1 回答 1

1

使用项目https://www.npmjs.com/package/mongo-morgan。使用正则表达式修改 index.js 中的流,然后就可以轻松将 Morgan 的数据放到 Mongodb 中了

于 2017-03-08T03:16:18.423 回答