express
// 创建一个app.js,记得npm install express
// 引入 express 模块,并将它赋予 express 这个变量等待使用。
var express = require('express');
// 调用 express 实例,它是一个函数,不带参数调用时,会返回一个 express 实例,将这个变量赋予 app 变量。
var app = express();
//一个类似filter的中间件,将有:id通配符参数的请求进行拦截并过滤
app.param('id',(req,res,next,username)=>{
console.log('1');
//调用下一个中间件
next();
})
// app.use为注册一个中间件,不带路径则表示匹配所有路由,express.static是一个方法,可以托管静态资源,默认路径为当前项目根目录的文件路径
app.use(express.static('./'))
//较广的路由匹配,可以匹配/app,/app/asdfasd...等
app.use('/app',()=>{})
//注册操作cookie的中间件
app.use(cookieParser());
//注册post请求提交的数据的中间件
app.use(bodyparse());
// app 本身有很多方法,其中包括最常用的 get、post、put/patch、delete,在这里我们调用其中的 get 方法,为我们的 `/abc/:id` 路径指定一个 handler 函数。:id为通配符参数
// 这个 handler 函数会接收 req 和 res 两个对象,他们分别是请求的 request 和 response。
// request 中包含了浏览器传来的各种信息,比如 query 啊,body 啊,headers 啊之类的,都可以通过 req 对象访问到。
// res 对象,我们一般不从里面取信息,而是通过它来定制我们向浏览器输出的信息,比如 header 信息,比如想要向浏览器输出的内容。这里我们调用了它的 #send 方法,向浏览器输出一个字符串。id为通配符
app.get('/abc/:id', (req, res , next) => {
//get访问localhost:3000/?q=123,页面会输出123,即req.query是url问号传参
var q = req.query.q;
//使用了bodyparsee中间件之后,可以用req.body获取post提交的数据
var data = req.body;
//使用了cookie的中间件之后,操作cookie
res.cookie('key','value',{option:xxx,maxAge:900,path:'123'})
//需要返回字符串、buffer、对象格式
res.send(q);
//允许网址的重定向
response.redirect('http://www.baidu.com');//前面可以加状态码
//用于发送文件,可以让客户端显示网页
response.sendFile('./views/index.html');
//方法用于渲染网页模板,将message变量传入index模板,渲染成html网页
response.render('index',{message:'hello world'});
});
// 定义好我们 app 的行为之后,让它监听本地的 3000 端口。这里的第二个函数是个回调函数,会在 listen 动作成功后执行,我们这里执行了一个命令行输出操作,告诉我们监听动作已完成。
app.listen(3000, function () {
console.log('app is listening at port 3000');
});
上面是最基本的express的接口,接下来就可以用node app.js开启服务器,并且去浏览器上面试验了。
多路由
一般一个页面会有多个路由,这时最好就把路由放到一个单独的文件中
// routes/index.js
module.exports = function(app){
app.get('/',(req,res)=>{
res.send('hello world');
}
app.get('/customer',()=>{
res.send('customer page');
})
app.get('/admin',(req,res)=>{
res.send('admin page');
})
}
然后在index.js引入
// index.js
var express = require('express');
var app = express();
var routes = require('./routes')(app);
app.listen(3000);
简单爬虫
app.get('/',(req,res)=>{
//用superagent去抓取网页的内容
superagent.get('https://cnodejs.org/')
.end((err,sres)=>{
//sres.txt里面存储着网页的html的内容,将它传给cheerio.load之后,就可以实现一个jquery接口的变量。
var $ = cheerio.load(sres.text);
var items = [];
$('#topic_list .topic_title').each(function(index,element){
var $element = $(element);
items.push({
title:$element.attr('title'),
href:$element.attr('href')
});
})
res.send(items);
})
})