- 创建服务器
var app=require('express').createServer();
app.get('/',function(req,res){
res.send('hello, world from csseer.cml');
});
app.listen(3000); - 创建Https服务器
var app=require('express').createServer({key:...}); 需要传递一个对象作为配置参数,该对象接收
key,cert和其他在nodejs https文档参数
3.生产环境 (有待学习)
4.______dirname是node.js里面的全局变量,即取得执行的js所在的路径 ,
__filename是目前执行的js文件名
5.bodyParser用于解析客户端请求的body中的内容,内部使用JSON编码处理,url编码处理以及对于文件的上传处理.
6.中间件, 可以通过connect 传入express。createServer();
var express =require('express');
var app= express.createServer(
express.logger(),
express.bodyParser()
);
7.路由中间件
这里路径映射可以理解为路由的意思,路由通过传入一个或者多个附加的回调函数到方法中。
多重路由中间件可以被按照顺序来执行,从而可以实现更复杂的逻辑。
function andRestrictToSellf(req,res,next){
req.authenticatedUser.id==req.user.id?next():next(new Error('无权限'));
}
app.get('/user/:id/edit',loadUser,andREstrictToSelf,function(req,res){
res.send('开始编辑用户'+req.user.name);
})
请记住中间件是简单的函数,返回中间件的函数
function andRestrictToSellf(role){
return function(req,res,next){ req.authenticatedUser.role==role?next():next(new Error('无权限
'))};
}
app.del('/user/:id/edit',loadUser,andREstrictToSelf('admin'),function(req,res){
res.send('已经删除'+req.user.name);
})
//app.del的第三个参数之所以可以这样写,是因为其返回的是一个函数,而该函数可以访问’admin’的值,这里涉及到闭包的概念,
8.session support
可以在Express中通过增加Connect的session中间件来开启Session支持,当然前提是需要在这之前使用cookieParser中间件,用于分析和处理req.cookies的cookie数据(我们知道session会利用cookie进行通信保持的)。
app.use(express.cookieParser());
app.use(express.session({ secret: "keyboard cat" }));
默认session中间件使用Connect绑定的内存存储,但也有另外的实现方式。比如connect-redis就提供了一个Redis的session存储方案:
var RedisStore = require('connect-redis');
app.use(express.cookieParser());
app.use(express.session({ secret: "CSSer加密字符串", store: new RedisStore }))
req.session 和 req.sessionStore属性就可以被所有路由及下级中间件所访问,req.session的属性会伴随着每次响应发送给客户端,