node.js中路由,中间件,ge请求和post请求的参数详解


Posted in Javascript onDecember 26, 2017

一、路由

 1、什么是路由

服务器需要根据不同的URL或请求来执行不一样的操作,我们可以通过路由来实现这个步骤

 2、实现路由的方法

2.1、get请求访问网址时,做什么事

app.get("网址",function(req,res){
  
 });

2.2、post请求访问网址时,做什么事

 

app.post("网址",function(req,res){
  
 });

 

 2.3、任何请求访问这个网址

app.all("网址",function(){
  
 });

 

注意:1、'这里的网址不分大小写,例如

app.get("/AAb",function(req,res){


//我们访问
/aab也是可以的
  res.send("你好");
 });

 

 2、你路由到/a , 实际/a?id=2&sex=nan 也能被处理。

 

3、路由中正则表达式的使用

3.1、正则表达式中,未知部分用圆括号分组,然后可以用req.params[0]、[1]得到。req.params类数组对象。 

app.get(/^\/student\/([\d]{10})$/,function(req,res){
  res.send("学生信息,学号" + req.params[0]);
 });

  3.2、冒号写法(推荐)

var express=require('express');
var app=express();
//冒号1
app.get("/student/:id",function (req,res) {
 var id=req.params["id"];








//得到id的值
 var reg=/^[\d]{6}$/;
 if(reg.test(id)){
  res.send(id);
 }else {
  res.send("请检查格式");
 }

});
//冒号2
app.get("/:username/:oid",function(req,res){
 var username = req.params["username"];





//得到username的值
 var oid = req.params["oid"];








//得到//oid的值
 res.write(username);
 res.end(oid);
});
app.listen(3000);
 运行结果:

冒号1:

node.js中路由,中间件,ge请求和post请求的参数详解

 冒号2:

node.js中路由,中间件,ge请求和post请求的参数详解

二、中间件

1、什么是中间件

应用于应用之间 充当连接服务的,例如上面的get、post请求就是中间件

2、express中所有的路由(中间件)的顺序(很重要)

 2.1、next()方法

 

var express=require("express");
var app=express();
app.get("/",function (req,res,next) {
 console.log(1);
 next();    //如果没有next参数,就只会conlose出来1,而不会是1,2
});
app.get("/",function (req,res) {
 console.log(2);
});
 app.listen(3000);

2.2、顺序冲突:下面这两个路由,看起来没有关系,但其实是有冲突的,因为admin可以当做用户名 login可以当做id

var express=require("express");
var app=express();
app.get("/:username/:id",function(req,res){
  console.log("1");
  res.send("用户信息" + req.params.username);
});

app.get("/admin/login",function(req,res){
  console.log("2");
  res.send("管理员登录");
});
app.listen(3000)

运行结果:当我们访问172.0.0.1:3000/admin/login时只会输出  用户信息admin 而不会是管理员登录

2.3、解决顺序冲突

2.3.1、具体的往上写,抽象的往下写

var express=require("express");
var app=express();
//具体的
app.get("/admin/login",function(req,res){
  console.log("2");
  res.send("管理员登录");
});
//抽象的
app.get("/:username/:id",function(req,res){
  console.log("1");
  res.send("用户信息" + req.params.username);
});
app.listen(3000)
运行结果:当我们访问172.0.0.1:3000/admin/login时输出  管理员登录 而不会是用户信息admin 

 

2.3.2、检索数据库

var express=require("express");
var app=express();
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)
 

3、app.use()中间件:与get、post不同的是,他的网址不是精确匹配的。而是能够有小文件夹拓展的。

3.1、get.use()的模糊匹配

var express=require("express");
var app=express();
//匹配所有网址
//法一
//当你不写路径的时候,实际上就相当于“/”,就是所有网址
// app.use(function (req,res,next) {
//  console.log(new Date());
//  next();     //执行下面的
// });
//法二
app.use("/",function (req,res,next) {
 console.log(new Date());
 next();     //执行下面的
});
//匹配/admin所有地址,例如/admin/ss/aa这个都行
app.use("/admin",function (req,res) {
 res.write(req.originalUrl+"\n"); // /admin/ss/aa
 res.write(req.path+"\n");   // /ss/aa
 res.write(req.baseUrl+"\n");  // /admin
 res.end("你好");
});
app.listen(3000);
 

3.2、get.use()读取文件

var express=require("express");
var fs=require("fs");
var app=express();

//当你不写路径的时候,实际上就相当于“/”,就是所有网址
app.use(haha);  //haha是一个函数
app.listen(3000);
// function haha(req,res) {
//  res.send("哈哈");
// }

app.use('/admin',function (req,res) {
 res.send('管理员登录');
})
//根据当前的网址,读取punlic文件夹的文件
//如果有这个文件,就渲染这个文件
//如果没有这个文件,那么next()
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());
 })
}
 

4、render和send

 4.1、res.send()方法快速测试页

var express=require("express");
var app=express();
//静态服务
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);
 

4.2、res.render()渲染内容,将会根据views中的模板文件进行渲染。如果不想使用views文件夹,想自己设置文件夹名字,那么app.set("views","aaaa");

 

var express=require("express");
var app=express();

// //设置ejs文件夹名字  //在day3文件夹下新建文件夹a,然后在里面放ejs文件
// app.set("views","a")
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);
 

5、req.query:当输入http://127.0.0.1:3000/?id=0&ag=9

var express=require("express");
var app=express();
app.get("/",function (req,res) {
 console.log(req.query);
 res.send();
});
app.listen(3000);
运行结果:

node.js中路由,中间件,ge请求和post请求的参数详解

 

三、get请求参数post请求参数:

GET请求的参数:在URL中,在Express中,不需要使用url模块了。可以直接使用req.query对象。

POST请求参数:在express中不能直接获得,必须使用body-parser模块。使用后,将可以用req.body得到参数。但是如果表单中含有文件上传,那么还是需要使用formidable模块。

//form.ejs

<!doctype html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title></title>
</head>
<body>
<form action="#" method="post">
 <input type="text" name="name"/>
 <input type="text" name="age"/>

 <input type="submit"/>
</form>
</body>
</html>
 
//.jsvar express=require("express");
var bodyParser=require('body-parser');
var app=express();
app.set('view engine','ejs')
app.get('/',function (req,res) {
 res.render("form");
});
//bodyParser API
app.use(bodyParser.urlencoded({extended:false}));
app.post('/',function (req,res) {
 console.log(req.body);
});
app.listen(3000);

 运行结果:

node.js中路由,中间件,ge请求和post请求的参数详解

node.js中路由,中间件,ge请求和post请求的参数详解

Javascript 相关文章推荐
Extjs ajax同步请求时post方式参数发送方式
Aug 05 Javascript
JS TextArea字符串长度限制代码集合
Oct 31 Javascript
jQuery对象的length属性用法实例
Dec 27 Javascript
JavaScript File分段上传
Mar 10 Javascript
javacript获取当前屏幕大小
Jun 04 Javascript
Javascript中获取浏览器类型和操作系统版本等客户端信息常用代码
Jun 28 Javascript
JS常用函数和常用技巧小结
Oct 15 Javascript
jQuery插件HighCharts绘制2D半圆环图效果示例【附demo源码下载】
Mar 09 Javascript
手把手教你搭建ES6的开发运行环境
Jul 11 Javascript
JavaScript中将值转换为字符串的五种方法总结
Jun 06 Javascript
原生JS实现萤火虫效果
Mar 07 Javascript
JQuery使用数组遍历跳出each循环
Sep 01 jQuery
Angular实现可删除并计算总金额的购物车功能示例
Dec 26 #Javascript
浅谈React深度编程之受控组件与非受控组件
Dec 26 #Javascript
使用vue实现简单键盘的示例(支持移动端和pc端)
Dec 25 #Javascript
vue的一个分页组件的示例代码
Dec 25 #Javascript
jQuery图片查看插件Magnify开发详解
Dec 25 #jQuery
AngularJS实现的生成随机数与猜数字大小功能示例
Dec 25 #Javascript
推荐10款扩展Web表单的JS插件
Dec 25 #Javascript
You might like
php绝对路径与相对路径之间关系的的分析
2010/03/03 PHP
深入理解PHP几个算法:PHP冒泡、PHP二分法、PHP求素数、PHP乘法表
2013/06/06 PHP
php使用qr生成二维码的示例分享
2014/01/20 PHP
php抽象方法和抽象类实例分析
2016/12/07 PHP
JS动画效果代码3
2008/04/03 Javascript
JS打开新窗口的2种方式
2013/04/18 Javascript
javascript两种function的定义介绍及区别说明
2013/05/02 Javascript
javascript调试过程中找不到哪里出错的可能原因
2013/12/16 Javascript
不提示直接关闭网页窗口的JS示例代码
2013/12/17 Javascript
js/jquery判断浏览器的方法小结
2014/09/02 Javascript
JS实现控制表格行文本对齐的方法
2015/03/30 Javascript
ajax+jQuery实现级联显示地址的方法
2015/05/06 Javascript
Angular2 之 路由与导航详细介绍
2017/05/26 Javascript
微信小程序实现tab切换效果
2017/11/21 Javascript
js消除图片小游戏代码
2019/12/11 Javascript
jquery制作的移动端购物车效果完整示例
2020/02/24 jQuery
python中threading超线程用法实例分析
2015/05/16 Python
python 接口测试response返回数据对比的方法
2018/02/11 Python
django连接mysql配置方法总结(推荐)
2018/08/18 Python
在Pycharm中修改文件默认打开方式的方法
2019/01/17 Python
Python Django Vue 项目创建过程详解
2019/07/29 Python
Python 网络编程之TCP客户端/服务端功能示例【基于socket套接字】
2019/10/12 Python
python中的TCP(传输控制协议)用法实例分析
2019/11/15 Python
python zip,lambda,map函数代码实例
2020/04/04 Python
英国厨房与餐具用品为主的设计品牌:Joseph Joseph
2018/04/26 全球购物
英国时尚泳装品牌:Maru Swimwear
2019/10/06 全球购物
blueseventy官网:铁人三项和比赛泳衣
2021/02/06 全球购物
高级销售求职信
2014/02/21 职场文书
体育课外活动总结
2014/07/08 职场文书
孝敬父母的活动方案
2014/08/28 职场文书
列车乘务员工作不细心检讨书
2014/10/07 职场文书
材料员岗位职责
2015/02/10 职场文书
八一建军节主持词
2015/07/01 职场文书
2016年“12.4”法制宣传日活动总结
2016/04/01 职场文书
导游词之河北邯郸
2019/09/12 职场文书
铁拳制作人赞《铁拳7》老头环Mod:制作精良 但别弄了
2022/04/03 其他游戏