如果我的的get、post回调函数中,没有next参数,那么就匹配上第一个路由,就不会往下匹配了。
如果想往下匹配的话,那么需要写next()
1app.get("/",function(req,res,next){
2 console.log("1");
3 next();
4});
5
6app.get("/",function(req,res){
7 console.log("2");
8}); 下面两个路由,感觉没有关系:
1app.get("/:username/:id",function(req,res){
2 console.log("1");
3 res.send("用户信息" + req.params.username);
4});
5
6app.get("/admin/login",function(req,res){
7 console.log("2");
8 res.send("管理员登录");
9});
但是实际上冲突了,因为admin可以当做用户名 login可以当做id。 解决方法1:交换位置。 也就是说,express中所有的路由(中间件)的顺序至关重要。
匹配上第一个,就不会往下匹配了。 具体的往上写,抽象的往下写。
1app.get("/admin/login",function(req,res){
2 console.log("2");
3 res.send("管理员登录");
4});
5
6app.get("/:username/:id",function(req,res){
7 console.log("1");
8 res.send("用户信息" + req.params.username);
9});
报错,因为send了两次。
解决方法2:
1app.get("/:username/:id",function(req,res,next){
2 var username = req.params.username;
3 //检索数据库,如果username不存在,那么next()
4 if(检索数据库){
5 console.log("1");
6 res.send("用户信息");
7 }else{
8 next();
9 }
10});
11
12app.get("/admin/login",function(req,res){
13 console.log("2");
14 res.send("管理员登录");
15}); 路由get、post这些东西,就是中间件,中间件讲究顺序,匹配上第一个之后,就不会往后匹配了。next函数才能够继续往后匹配。
--------------------------------------------------------------------------------
app.use()也是一个中间件。与get、post不同的是,他的网址不是精确匹配的。而是能够有小文件夹拓展的。
比如网址: http://127.0.0.1:3000/admin/aa/bb/cc/dd
1app.use("/admin",function(req,res){
2 res.write(req.originalUrl + "\n"); // /admin/aa/bb/cc/dd
3 res.write(req.baseUrl + "\n"); // /admin
4 res.write(req.path + "\n"); // /aa/bb/cc/dd
5 res.end("你好");
6}); 如果写一个/
1//当你不写路径的时候,实际上就相当于"/",就是所有网址
2app.use(function(req,res,next){
3 console.log(new Date());
4 next();
5}); app.use()就给了我们增加一些特定功能的便利场所。
实际上app.use()的东西,基本上都从第三方能得到。 ● 大多数情况下,渲染内容用res.render(),将会根据views中的模板文件进行渲染。如果不想使用views文件夹,想自己设置文件夹名字,那么app.set("views","aaaa");
● 如果想写一个快速测试页,当然可以使用res.send()。这个函数将根据内容,自动帮我们设置了Content-Type头部和200状态码。send()只能用一次,和end一样。和end不一样在哪里?能够自动设置MIME类型。
● 如果想使用不同的状态码,可以:
res.status(404).send('Sorry, we cannot find that!');
● 如果想使用不同的Content-Type,可以:
res.set('Content-Type', 'text/html');

06.js

/**
* Created by Danny on 2015/9/22 10:47.
*/
var http = require("http"); // 这个语句,就在打开服务器的时候,执行一次。
// 每次用户访问的时候,不执行这个语句
var a = 100; var server = http.createServer(function(req,res){
// 用户访问的时候,执行这里的语句:
a++;
res.end(a.toString());
}); server.listen(3000,"127.0.0.1");

07.js

/**
* Created by Danny on 2015/9/22 10:22.
*/
var express = require("express"); var app = express(); var a = 100; //路由从上往下找,找到就不向下找了,
app.get("/:username/:id",function(req,res,next){
var username = req.params.username;
//检索数据库,如果username不存在,那么next()
if(检索数据库){
console.log("1");
res.send("用户信息");
}else{
next();//继续向下找匹配的路由
}
}); app.get("/admin/login",function(req,res){
console.log("2");
res.send("管理员登录");
}); app.listen(3000);

08.js

/**
* Created by Danny on 2015/9/22 10:22.
*/
var express = require("express"); var app = express(); //当你不写路径的时候,实际上就相当于"/",就是所有网址
app.use(function(req,res,next){
console.log(new Date());
next();
}); //http://localhost:3000/haha/ssss是匹配不了的
app.get("/haha",function(req,res){
console.log("哈哈");
});
//http://127.0.0.1:3000/admin/aa/bb/cc/dd
app.use("/admin",function(req,res){
res.write(req.originalUrl + "\n");// /admin/aa/bb/cc/dd
res.write(req.baseUrl + "\n");// /admin
res.write(req.path + "\n");
res.end("你好");
}); app.listen(3000);

09.js

/**
* Created by Danny on 2015/9/22 10:22.
*/
var express = require("express");
var fs = require("fs"); var app = express(); //当你不写路径的时候,实际上就相当于"/",就是所有网址
app.use(haha); app.get("/admin",function(req,res){
res.send("管理员");
}) app.listen(3000); function haha(req,res,next){
var filePath = req.originalUrl;
//根据当前的网址,读取public文件夹中的文件
//如果有这个文件,那么渲染这个文件
//如果没有这个文件,那么next();
fs.readFile("./public/" + filePath,function(err,data){
if(err){
//文件不存在
next();
return;
}
res.send(data.toString());
});
}

10.js

/**
* Created by Danny on 2015/9/22 10:22.
*/
var express = require("express"); var app = express(); //静态服务,一般静态资源往上写。不执行next();
app.use("/jingtai",express.static("./public")); //新的路由
app.get("/images",function(req,res){
res.send("哈哈");
}); //会自动识别err参数,如果有,那么就这个函数能捕获err
app.use(function(req,res){
res.status(404).send("没有这个页面!");
}); app.listen(3000);

11.js

/**
* Created by Danny on 2015/9/22 10:22.
*/
var express = require("express");
var app = express();
app.set("views","aaaa");//如果不想使用views文件夹,想自己设置文件夹名字,
app.set("view engine","ejs"); app.get("/",function(req,res){
res.render("haha",{news:[]});
}); app.get("/check",function(req,res){
res.send({
"user" : "ok"
});
}); app.listen(3000);

node09---中间件的更多相关文章

  1. ASP.NET Core 中的那些认证中间件及一些重要知识点

    前言 在读这篇文章之间,建议先看一下我的 ASP.NET Core 之 Identity 入门系列(一,二,三)奠定一下基础. 有关于 Authentication 的知识太广,所以本篇介绍几个在 A ...

  2. ASP.NET Core应用的错误处理[3]:ExceptionHandlerMiddleware中间件如何呈现“定制化错误页面”

    DeveloperExceptionPageMiddleware中间件利用呈现出来的错误页面实现抛出异常和当前请求的详细信息以辅助开发人员更好地进行纠错诊断工作,而ExceptionHandlerMi ...

  3. ASP.NET Core应用的错误处理[2]:DeveloperExceptionPageMiddleware中间件如何呈现“开发者异常页面”

    在<ASP.NET Core应用的错误处理[1]:三种呈现错误页面的方式>中,我们通过几个简单的实例演示了如何呈现一个错误页面,这些错误页面的呈现分别由三个对应的中间件来完成,接下来我们将 ...

  4. ASP.NET Core 中间件之压缩、缓存

    前言 今天给大家介绍一下在 ASP.NET Core 日常开发中用的比较多的两个中间件,它们都是出自于微软的 ASP.NET 团队,他们分别是 Microsoft.AspNetCore.Respons ...

  5. .NET Core中间件的注册和管道的构建(3) ---- 使用Map/MapWhen扩展方法

    .NET Core中间件的注册和管道的构建(3) ---- 使用Map/MapWhen扩展方法 0x00 为什么需要Map(MapWhen)扩展 如果业务逻辑比较简单的话,一条主管道就够了,确实用不到 ...

  6. .NET Core中间件的注册和管道的构建(2)---- 用UseMiddleware扩展方法注册中间件类

    .NET Core中间件的注册和管道的构建(2)---- 用UseMiddleware扩展方法注册中间件类 0x00 为什么要引入扩展方法 有的中间件功能比较简单,有的则比较复杂,并且依赖其它组件.除 ...

  7. .NET Core中间件的注册和管道的构建(1)---- 注册和构建原理

    .NET Core中间件的注册和管道的构建(1)---- 注册和构建原理 0x00 问题的产生 管道是.NET Core中非常关键的一个概念,很多重要的组件都以中间件的形式存在,包括权限管理.会话管理 ...

  8. 从中间件的历史来看移动App开发的未来

    在移动开发领域我们发现一个很奇怪的现象:普通菜鸟新手经过3个月的培训就可以拿到 8K 甚至上万的工作:在北京稍微有点工作经验的 iOS 开发,就要求 2 万一个月的工资.不知道大家是否想过:移动应用开 ...

  9. ASP.NET Core的路由[4]:来认识一下实现路由的RouterMiddleware中间件

    虽然ASP.NET Core应用的路由是通过RouterMiddleware这个中间件来完成的,但是具体的路由解析功能都落在指定的Router对象上,不过我们依然有必要以代码实现的角度来介绍一下这个中 ...

  10. ASP.NET Core应用针对静态文件请求的处理[5]: DefaultFilesMiddleware中间件如何显示默认页面

    DefaultFilesMiddleware中间件的目的在于将目标目录下的默认文件作为响应内容.我们知道,如果直接请求的就是这个默认文件,那么前面介绍的StaticFileMiddleware中间件会 ...

随机推荐

  1. Android新手入门2016(8)--ListView之ArrayAdapter

    本文来自肥宝传说之路,引用必须注明出处! ListView是Android中经常使用的控件. 什么是列表视图,让我们先看看图: watermark/2/text/aHR0cDovL2Jsb2cuY3N ...

  2. keras中使用预训练模型进行图片分类

    keras中含有多个网络的预训练模型,可以很方便的拿来进行使用. 安装及使用主要参考官方教程:https://keras.io/zh/applications/   https://keras-cn. ...

  3. 多年iOS开发经验总结(一)

    总结了几个月的东西终于能和大家分享了,不多说,直接看东西! 1.禁止手机睡眠 1 [UIApplication sharedApplication].idleTimerDisabled = YES; ...

  4. 利用flashback transaction query新特性进行事务撤销

    具备了flashback version query查询的基础,我们就可以进行基于flashback version query的恢复.这就是flashback transaction query.f ...

  5. 2016 提高组c++ 错题

    需重做 树的重心 链表 计算机基础知识 无线通讯技术: 蓝牙,wifi,GPRS 现在常用的无线通信技术:FM调频广播(用于收音机): 2G.3G移动通信技术(中国移动.中国联通.中国电信正在运营的网 ...

  6. Centos7 minimal 系列之Redis(五)

    一.Redis安装 1.1 .进入/usr/local 创建redis文件夹(mkdir)方便统一管理 1.2.下载redis $ wget http://download.redis.io/rele ...

  7. 五步完成一个 VSCode 扩展(插件)开发

    第一步: 安装扩展生成器 npm install -g yo generator-code vsce 第二步: 初始化一个 Hello World 扩展 yo code 图来自 CN-VScode-D ...

  8. struts2学习之基础笔记3

    第8章Struts 2类型转换 使用类型转换器 自定义类型转换器 步骤:1. Struts 2 构建流程 2.自定义类型转换器类(继承 DefaultTypeConverter /StrutsType ...

  9. SpringBoot(九) ElasticSearch 全文检索

    ElasticSearch ​ ElasticSearch是一个基于Lucene的搜索服务器.它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口.Elasticsearch是用 ...

  10. border-spacing和borer-collapse以及empty-cells属性

    1.border-spacing 用于设置表格中,单元格之间的间隙 示例1:border-spacing: 7px: 单元格水平方向7px间隔,垂直方向7px间隔 示例2:border-spacing ...