《Pro Express.js》学习笔记——app.params中间件

app.param中间件用于对URL中的参数进行获取、加工、输出,提供公有逻辑,以达到代码重构的目的。

以下示例采取三个步骤对代码进行重构,app.param中间件的作用非常明显:

  1. 不使用中间件
  2. 使用自定义中间件
  3. 使用app.param中间件

不使用中间件

1 var users = {
 2     ‘azat‘: {
 3         email: ‘[email protected]‘,
 4         website: ‘http://azat.co‘,
 5         blog: ‘http://webapplog.com‘
 6     }
 7 };
 8 
 9 var findUserByUsername = function (username, callback) {
10     if (!users[username]) {
11         return callback(new Error(‘No user matching ‘ + username));
12     }
13 
14     return callback(null, users[username]);
15 }
16 
17 app.get(‘/v1/users/:username‘, function (request, response, next) {
18     var username = request.params.username;
19     findUserByUsername(username, function (error, user) {
20         if (error) return next(error);
21         return response.render(‘user‘, user);
22     });
23 });
24 
25 app.get(‘/v1/admin/:username‘, function (request, response, next) {
26     var username = request.params.username;
27     findUserByUsername(username, function (error, user) {
28         if (error)return next(error);
29         return response.render(‘admin‘, user);
30     });
31 });

使用自定义中间件

1 var findUserByUsernameMiddleware = function (request, response, next) {
 2     if (request.params.username) {
 3         console.log(‘Username param was detected: ‘ + request.params.username);
 4         findUserByUsername(request.params.username, function (error, user) {
 5             if (error)return next(error);
 6             request.user = user;
 7             return next();
 8         })
 9     } else {
10         return next();
11     }
12 }
13 
14 app.get(‘/v2/users/:username‘,
15     findUserByUsernameMiddleware,
16     function (request, response, next) {
17         return response.render(‘user‘, request.user);
18     });
19 
20 app.get(‘/v2/admin/:username‘,
21     findUserByUsernameMiddleware,
22     function (request, response, next) {
23         return response.render(‘admin‘, request.user);
24     });

使用app.param中间件

1 app.param(‘v3Username‘,function(request,response,next,username){
 2     console.log(‘Username param was detected: ‘+username);
 3     findUserByUsername(username,function(error,user){
 4         if (error)return next(error);
 5         request.user = user;
 6         return next();
 7     });
 8 });
 9 
10 app.get(‘/v3/users/:v3Username‘,
11     function (request, response, next) {
12         return response.render(‘user‘, request.user);
13     });
14 
15 app.get(‘/v3/admin/:v3Username‘,
16     function (request, response, next) {
17         return response.render(‘admin‘, request.user);
18     });

小结

  1. app.param中间件起到AOP的作用,对含有指定参数的请求进行统一拦截处理,便于集中维护管理;
  2. app.param中间件简化了后面路由处理时的写法,无须再次显式调用中间件来处理,更简约。
时间: 2024-10-11 03:31:38

《Pro Express.js》学习笔记——app.params中间件的相关文章

[Pro Angular.JS]学习笔记1.1:设置开发环境

可以使用yeoman.io,很方便.我已经写了一篇随笔,介绍如何使用.这里也有一篇介绍的文章:http://www.cnblogs.com/JoannaQ/p/3756281.html 代码编辑器,在Mac下用了一下WebStorm,太恶心了.另外发现书的作者使用的开发环境是Windows + VS Express 2013,为了方便学习,我也使用VS Express 2013 Update2.VS2013用起来蛮舒服的,把WebStorm比得跟驼屎一样.也许是因为我没用习惯吧. 1.安装Nod

[express.js学习笔记]理解Router

(本文内容纯属个人理解,仅供学习探讨) 博主的工作用的是Java Web,私下对JavaScript很感兴趣,也就接触了Node.js,听过Node一般使用Express来搭建Web服务器,就找到了Express,开始阅读文档和例子. 发现官方文档API页面的导航列出了express的几个核心的类(对象): 1. express 2. Application 3. Request 4. Response 5. Router 其中,按照我的理解,express是一个Application对象的工厂

Node.js学习笔记(3) - 简单的curd

这个算是不算完结的完结吧,前段时间也是看了好久的Node相关的东西,总想着去整理一下,可是当时也没有时间: 现在看来在整理的话,就有些混乱,自己也懒了,就没在整理,只是简单的记录一下 一.demo的简单介绍 这次demo,只涉及到简单的curd操作,用到的数据库是mongo,所以要安装mongo数据库,数据库连接驱动是mongoose: 当然关于mongo的驱动有很多,比如mongous mongoskin等:(详见http://cnodejs.org/topic/4f4ca8e0940ce2e

【转】Backbone.js学习笔记(二)细说MVC

文章转自: http://segmentfault.com/a/1190000002666658 对于初学backbone.js的同学可以先参考我这篇文章:Backbone.js学习笔记(一) Backbone源码结构 1: (function() { 2: Backbone.Events // 自定义事件 3: Backbone.Model // 模型构造函数和原型扩展 4: Backbone.Collection // 集合构造函数和原型扩展 5: Backbone.Router // 路由

系列文章--Node.js学习笔记系列

Node.js学习笔记系列总索引 Nodejs学习笔记(一)--- 简介及安装Node.js开发环境 Nodejs学习笔记(二)--- 事件模块 Nodejs学习笔记(三)--- 模块 Nodejs学习笔记(四)--- 与MySQL交互(felixge/node-mysql) Nodejs学习笔记(五)--- Express安装入门与模版引擎ejs Nodejs学习笔记(六)--- Node.js + Express 构建网站预备知识 Nodejs学习笔记(七)--- Node.js + Exp

node.js学习笔记目录

1.node.js学习笔记(1)--Node.js简介及环境安装 2.node.js学习笔记(2)--使用Express快速创建应用 3.node.js学习笔记(3)--Express创建的项目分析 4.node.js学习笔记(4)--使用Express完成简单的登陆 5.node.js学习笔记(5)--MongoDB下载及安装 6.node.js学习笔记(6)--MongoDB简单入门 7.node.js学习笔记(7)--Node.js与MongoDB简单交互 8.node.js学习笔记(8)

Vue.js学习笔记:在元素 和 template 中使用 v-if 指令

f 指令 语法比较简单,直接上代码: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <title></title> <script src="https://cdn.bootcss.com/vue/2.2.

Angular JS 学习笔记

特定领域语言 编译器:遍历DOM来查找和它相关的属性, 分为编译和链接两个阶段, 指令:当关联的HTML结构进入编译阶段时应该执行的操作,可以写在名称里,属性里,css类名里:本质上是函数 稳定的DOM:绑定了数据模型的DOM元素的实例不会在绑定的生命周期发生改变 作用域:用来检测模型的改变和为表达式提供执行上下文的 AngularJS 和其它模板系统不同,它使用的是DOM而不是字符串 指令: 由某个属性.元素名称.css类名出现而导致的行为,或者说是DOM的变化 Filter过滤器:扮演着数据

JS学习笔记-OO疑问之封装

封装是面向对象的基础,今天所要学习的匿名函数与闭包就是为了实现JS的面向对象封装.封装实现.封装变量,提高数据.系统安全性,封装正是面向对象的基础. 匿名函数 即没有名字的函数,其创建方式为 function(){...} 单独存在的匿名函数,无法运行,可通过赋值给变量调用或通过表达式自我执行来实现运行. 1.赋值给变量为一般的函数使用方式 var run = function(){ return '方法运行中'; }; alert(run()); 2.通过表达式自我执行 (function(a