前言
创新互联公司成立与2013年,是专业互联网技术服务公司,拥有项目做网站、成都网站设计网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元东河做网站,已为上家服务,为东河各地企业和个人服务,联系电话:028-86922220
大家应该都知道,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
结合正则表达式使用更强大。
总结
以上就是这篇文章的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对创新互联的支持。