我不太了解节点中的流。
我尝试将应用程序的请求和响应信息保存到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中。
最佳答案
使用项目https://www.npmjs.com/package/mongo-morgan。使用正则表达式修改index.js中的流,然后可以轻松地将Morgan的数据放入Mongodb