当前位置: 首页 > news >正文

南宁网站建设接单陕西省人民政府

南宁网站建设接单,陕西省人民政府,备案成功后怎么建网站,长治做百度网站一年多少钱使用morgan可以打印日志,但是要分割日志文件就需要使用file-stream-rotator,下面介绍使用方法: 1.安装2个依赖 npm i morgan file-stream-rotator 2.在入口文件app.js中引入相关插件 var express require("express"); var fs require("fs"); var pat…

使用morgan可以打印日志,但是要分割日志文件就需要使用file-stream-rotator,下面介绍使用方法:

1.安装2个依赖

npm i morgan file-stream-rotator

2.在入口文件app.js中引入相关插件

var express = require("express");
var fs = require("fs");
var path = require("path");
var morgan = require("morgan");//https://www.npmjs.com/package/morgan
var FileStreamRotator = require("file-stream-rotator");//https://www.npmjs.com/package/file-stream-rotator
var app = express();

3.使用插件打印日志

function getTime() {var d = new Date();return d.toLocaleString() + "." + d.getMilliseconds();
}
// 自定义的 token 来获取请求头数据
morgan.token("auth", function (req, res) {return req.headers["token"]; //获取请求头的token值,一般是token或者authorization
});
// 自定义的 token 来获取本地时间
morgan.token("local-time", getTime);
// 自定义 token 来获取请求体
morgan.token("request-body", function (req, res) {return JSON.stringify(req.body);
});
// 自定义 token 来记录响应体,需要下面的中间件配合才能获取到
morgan.token("response-body", (req, res) => {return res.body || "";
});
// 自定义中间件来捕获响应体
app.use(function (req, res, next) {const originalSend = res.send.bind(res); // 暂存原始的 end 方法res.send = function (body) {res.body = body; // 保存响应体return originalSend(body); // 正常发送响应};next();
});// 创建一个写入流到文件
var logDirectory = path.join(__dirname, "../logs");//根据个人需要设置文件存放位置
if (!fs.existsSync(logDirectory)) {fs.mkdirSync(logDirectory);
}
var configs = function (type) {return {date_format: "YYYYMMDD", //日期类型filename: path.join(logDirectory, "%DATE%-" + type), //文件名frequency: "daily", //每天的频率verbose: false, //使用 console.log 在事件发生时提供额外的信息。默认值为 false。extension: ".log",//日志后缀名size: "20m", //文件大小,单位k,m,gmax_logs: "30", //最多保留日志文件数量,如果后面跟随d表示保留天数,超过会自动删除};
};
// 创建错误日志输出流
var errorLogStream = FileStreamRotator.getStream(configs("error"));
// 创建访问日志输出流
var accessLogStream = FileStreamRotator.getStream(configs("access"));//如果需要将代码中console.log打印的内容也添加到日志文件中才需要下面的自定义流和重定向流
// 创建一个自定义的日志流
var combinedStream = {write: (message) => {// 写入文件accessLogStream.write(message);// 同时输出到控制台// process.stdout.write(message);},
};
// 重定向 console.log 到自定义日志流
var originalConsoleLog = console.log;
console.log = function (message) {// 将消息写入日志文件combinedStream.write(`${getTime()} ${JSON.stringify(message)}\n`);// 同时输出到控制台//   originalConsoleLog.apply(console, [message]);
};var customFormat =":local-time :method :url :status :res[content-length] :response-time ms :auth \n  请求 :request-body \n  响应 :response-body \n";app.use(morgan(customFormat, {immediate: false,stream: errorLogStream,//使用原始的,console.log不会输出到日志文件skip: function (req, res) {return res.statusCode < 400; //code >= 400不过滤},})
);
app.use(morgan(customFormat, {immediate: false,stream: combinedStream,//使用自定义的,console.log会输出到日志文件skip: function (req, res) {//可以根据res.statusCode<400,req.method === 'GET',req.url === '/getUserInfo'判断是否过滤var arr = [".js", ".css", ".png", ".jpg"];return arr.some(function (item) {return req.url.indexOf(item) > -1;});},})
);

http://www.hkea.cn/news/771557/

相关文章:

  • wordpress网站价格seo域名综合查询
  • 支付网站怎么做的网络自动推广软件
  • js做网站统计品牌关键词优化
  • 微信公众号管理平台官网谷歌seo建站
  • 鲜花购物网站源码企业网站营销的优缺点
  • 表白网站制作在线日照网站优化公司
  • 企业网站建设策划书 前言徐州关键词优化排名
  • 一级a做爰片视频网站全国新闻媒体发稿平台
  • 唐山网站建设哪家专业高德北斗导航
  • wordpress 地址 .html企业网站seo贵不贵
  • 提供网站制作公司哪家好网络软文范文
  • 做原型网站枣庄网络推广seo
  • 品牌网站开发设计外贸网站平台
  • 网站做留言板网站推广在线
  • 长春服务好的网络营销seo网站推广的主要目的
  • 搜索引擎优化和关键词竞价广告的区别宿州百度seo排名软件
  • 一搜同志网站建设电话青岛网站seo优化
  • 官方做任务网站网络营销公司注册找哪家
  • django做视频网站网络营销推广专家
  • 国外手做网站搜索引擎推广的关键词
  • 网站建设商标注册多少类目域名注册免费
  • 哪里有网站设计公司长沙网络公司最新消息
  • 试描述一下网站建设的基本流程百度怎么发布短视频
  • 我现在有域名怎么做网站搜索关键词热度
  • 海外如何 淘宝网站建设快速seo整站优化排行
  • 代还信用卡网站建设赣州seo顾问
  • 响应式网站建设推广开网店
  • 成都专业网站推广公司优化大师优化项目有
  • 怎么用wordpress搭建网站百度关键词排名点
  • 外挂网站模板域名搜索引擎入口