node.js express中app.param的用法详解
时间:2019-03-30
本文章向大家介绍node.js express中app.param的用法详解,主要包括node.js express中app.param的用法详解使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
前言
大家应该都知道,express中app.param
方法用于验证参数,我个人把它理解成类似对参数过滤的一个中间件。在这里我来结合几个demo,加深大家对app.param
方法的理解。下面话不多说,来一起通过示例代码看看详细的介绍吧。
demo1:
var express = require('express'); var app = express(); app.param(function(param, option) { return function (req, res, next, val) { if (val == option) { next(); // } else { res.sendStatus(404); } } }); app.param('id', 1337); app.get('/user/:id', function (req, res) { res.send('参数通过检验'); }); app.listen(3000, function () { console.log('Ready'); });
在上述例子中,只有在地址栏输入http://localhost:3000/user/1337的情况下,页面才会显示“参数通过检验”。
也就是说app.params()
可以对地址栏参数进行过滤,针对不同参数作出不同响应。
但是上述代码,在运行的时候会有这样的提示:
express deprecated router.param(fn):Refactor to use path params
demo1中示例的写法并不推荐,改成如下写法,提示就会消失:
demo2:
var express = require('express'); var app = express(); app.param('id', function (req, res, next, id) { if(req.params.id==1337){ next(); } else{ res.sendStatus(404); } }); app.param('id', 1337); app.get('/user/:id', function (req, res) { res.send('参数通过检验'); }); app.listen(3000, function () { console.log('Ready'); });
tip:通常app.params
结合正则表达式使用更强大。
总结
以上就是这篇文章的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。
- 【Oracle12.2新特性掌上手册】-第八卷 PDB的快速创建与移除
- 《机器学习实战》学习笔记(十一):线性回归基础篇之预测鲍鱼年龄
- 你必须要知道CNN模型:ResNet
- CNN模型之SqueezeNet
- YOLO算法的原理与实现
- Batchnorm原理详解
- 【动手实践】Oracle 12.2 新特性:自动的列表分区创建
- AI从业者搞懂---这10种深度学习方法---老婆孩子热炕头
- OpenCV从零基础---检测及分割图像的目标区域
- Spark资源调优
- Tensorflow实战:Discuz验证码识别
- 【动手实践】:Lockdown Profile 的多租户权限控制
- 异步的JavaScript和XML(AJAX)
- JavaScript实现登录注册验证
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法