Express.js 中的中间件:Morgan 使用指南
2026-01-16 09:28:39作者:郁楠烈Hubert
1. 项目目录结构及介绍
Morgan 是一个用于 Node.js 的 HTTP 请求日志中间件,其设计简洁高效,非常适合集成在基于 Express.js 的应用中。以下是 Morgan 在克隆后的基本目录结构以及关键文件的简要说明:
├── LICENSE
├── README.md <- 项目的主要文档,包含了安装、使用方法及配置选项。
├── index.js <- 主入口文件,导出中间件函数。
├── lib <- 核心库目录,含中间件的核心逻辑。
│ ├── format.js <- 日志格式处理文件。
│ └── token.js <- 定义了所有可用的日志令牌(token)。
├── test <- 单元测试目录,确保代码质量。
│ └── ...
└── package.json <- 项目元数据文件,包括依赖项、版本等。
注意:实际开发中,您可能不会直接操作这些内部文件,而是通过配置Express来使用Morgan。
2. 项目的启动文件介绍
在使用Morgan时,通常不需要直接操作所谓的“启动文件”,因为它是作为Express应用的一部分引入的。但我们可以把如何在Express应用中启动Morgan视为这一部分的重点。
示例:在Express中引入并使用Morgan
// 假设这是您的app.js或server.js(启动文件)
const express = require('express');
const morgan = require('morgan');
const app = express();
// 在任何路由处理之前启用Morgan,以记录请求信息。
app.use(morgan('dev')); // 'dev'是常用的格式之一,适合开发环境。
// 接下来的代码是您的路由定义和其他中间件的使用。
app.get('/', (req, res) => {
res.send('Hello, World!');
});
// 启动服务器
app.listen(3000, () => {
console.log('Server running on port 3000');
});
3. 项目的配置文件介绍
Morgan本身并不直接使用外部配置文件。它的配置主要通过传递给中间件函数的字符串参数或自定义日志格式函数来实现。这通常发生在应用程序代码层面上,而非独立的配置文件中。
配置示例
-
预定义格式:
app.use(morgan('combined')); // 使用典型的clf(combined log format)格式 -
自定义格式:
app.use(morgan(':method :url :status - :response-time ms')); // 自定义格式示例 -
使用Stream进行日志记录到文件: 虽然不是配置文件的形式,但可以通过将输出重定向至文件流来达到类似配置的效果。
const accessLogStream = fs.createWriteStream(__dirname + '/access.log', { flags: 'a' }); app.use(morgan('combined', { stream: accessLogStream }));
通过这种方式,您可以灵活地控制和定制Morgan的行为,满足不同场景下的日志需求,无需依赖于传统的配置文件结构。
登录后查看全文
热门项目推荐
相关项目推荐
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
xw-cli实现国产算力大模型零门槛部署,一键跑通 Qwen、GLM-4.7、Minimax-2.1、DeepSeek-OCR 等模型Go06
yuanrongopenYuanrong runtime:openYuanrong 多语言运行时提供函数分布式编程,支持 Python、Java、C++ 语言,实现类单机编程高性能分布式运行。Go051
MiniCPM-SALAMiniCPM-SALA 正式发布!这是首个有效融合稀疏注意力与线性注意力的大规模混合模型,专为百万级token上下文建模设计。00
ebook-to-mindmapepub、pdf 拆书 AI 总结TSX01
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
541
3.77 K
Ascend Extension for PyTorch
Python
353
420
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
889
616
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
339
186
openJiuwen agent-studio提供零码、低码可视化开发和工作流编排,模型、知识库、插件等各资源管理能力
TSX
988
253
openGauss kernel ~ openGauss is an open source relational database management system
C++
169
233
暂无简介
Dart
778
194
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
115
142
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.35 K
759