Checks route params (req.params), ex: /user/:id
Checks query string params (req.query), ex: ?id=12
Checks urlencoded body params (req.body), ex: id=
1、例如:127.0.0.1:3000/index,这种情况下,我们为了得到index,我们可以通过使用req.params得到,通过这种方法我们就可以很好的处理Node中的路由处理问题,同时利用这点可以非常方便的实现MVC模式;
2、例如:127.0.0.1:3000/index?id=12,这种情况下,这种方式是获取客户端get方式传递过来的值,通过使用req.query.id就可以获得,类似于PHP的get方法;
3、例如:127.0.0.1:300/index,然后post了一个id=2的值,这种方式是获取客户端post过来的数据,可以通过req.body.id获取,类似于PHP的post方法;
下面举例介绍下这三个方法:
如下一个test.html代码
<form action="/index" method="get">
<input type="text" name="login_name"/>
<input type="submit" value="Sign In" />
</form>
在nodeJs中我们要自定义HTTP,因此创建index.js
var app = require('express').createServer()
app.get('/:key', function(req, res){
console.log(req.params.key)//输出index
console.log(req.query.login_name)//输出表单get提交的login_name
res.send('great you are right for get method!')//显示页面文字信息
})
app.post('/:key', function(req, res){
<pre name="code" class="javascript"> console.log(req.params.key)//输出index
console.log(req.body.login_name)//输出表单post提交的login_name
res.send('great you are right for post method!')//显示页面文字信息
})app.listen(3000)
之后运行node index.js就可以看到本效果,当然前提是你要先访问test.html,至于如何通过express访问一个html文件我就不详细描述了,可以参考如下代码:
global.fs=require('fs')
var realpath = VIEW + "test.html"
var file = fs.readFileSync(realpath)
res.end(file)
我最近在研究爬虫,你这个好像跟爬虫差不多。我说一下我的方法。
要用到request模块,cheerio模块(提供像jQuery一样的具有选择器作用的函数)
request(url, function(err,res,body){if (!err && res.statusCode == 200) {
var $ = cheerio.load(html) //采用cheerio模块解析html
var items = $(".repo-list li h3 a")//根据html选择器,获得链接所在的html元素
items.each(function(index, item) {//如果获得了多个元素,则遍历每个元素
var src = item.attribs.href"//将每个链接提取出来
searchHref($, src)//再分别对每个链接,进行 *** 作
})
}
})
function downloadZip($, src) {
request(src){
//获取每个链接的数据,这是你自己的 *** 作了
}
}
这里发的是一个Post请求,请求的路径是localhost:8080/v1/sendEmail,并不是请求某个文件。Node里可以配置routers,接受对应的请求如router.post('/v1/sendEmail',function(req,res,next){//这里执行相应的 *** 作})欢迎分享,转载请注明来源:内存溢出
评论列表(0条)