如果我的的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. 2015.05.04,外语,读书笔记-《Word Power Made Easy》 14 “如何谈论日常现象” SESSION 41

    1. people are the craziest animals bovine(['bәuvain] adj. (似)牛的, 迟钝的),像牛一样placid(['plæsid] adj. 安静的, ...

  2. nyoj--68--三点顺序(数学)

    三点顺序 时间限制:1000 ms  |  内存限制:65535 KB 难度:3 描述 现在给你不共线的三个点A,B,C的坐标,它们一定能组成一个三角形,现在让你判断A,B,C是顺时针给出的还是逆时针 ...

  3. 2017-3-3 leetcod 1 35 448

    ACM退役了,接下来是考研的准备,刷刷leetcode保证不会生手,也算是调剂生活,初步计划是每天三题吧,希望可以坚持下去. 打算按照专题来做,先是Array....本来以为特别水,结果.... == ...

  4. JSP页面动态查询添加数据与分页数据显示

    1 . <%@ page language="java" contentType="text/html; charset=UTF-8"%> < ...

  5. Re:从 0 开始的微服务架构--(四)如何保障微服务架构下的数据一致性--转

    原文地址:http://mp.weixin.qq.com/s/eXvoJew3bjFKzLLJpS0Otg 随着微服务架构的推广,越来越多的公司采用微服务架构来构建自己的业务平台.就像前边的文章说的, ...

  6. 自定义view 之多个引导层动画效果

    SupernatantView 如果我英文还可以的话这个应该叫做漂浮在上层的view---引导层 今天闲来无事看了网上的一些引导层案例总感觉如果不是很舒服,就是类似于很死板的显示和消失 我在想能不能弄 ...

  7. 移动端 AnyProxy HTTPS 配置

    参考:AnyProxy HTTPS相关教程 参考教程中,说明了 Windows 和 Mac 系统的配置,这里补充一下移动端(Android.iOS)的配置 生成RootCA > 下载 rootC ...

  8. ECMAScript prototype的一个疑问。

    既然是疑问 当然首先要贴一段代码. 背景: 探究js的原型继承模式. 疑惑:为何person1和person2的prototype 居然是相等的. 附: 1.Object.create(proto, ...

  9. Unity局部坐标系与世界坐标系的区别

    局部坐标旋转是指以父物体为参考,进行旋转. 而世界坐标系以"坐标陀螺"来进行旋转. 类似的情况例如: 东.南.西.北.是世界坐标系. 前.后.左.右是局部坐标系

  10. my.cnf配置样例

    [mysql] no-auto-rehash port = socket = /data/mysql/data/mysqld.sock [mysqld] user = mysql port = bas ...