express 学习笔记

  1. 创建服务器
    var app=require('express').createServer();
    app.get('/',function(req,res){
    res.send('hello, world from csseer.cml');
    });
    app.listen(3000);
  2. 创建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的属性会伴随着每次响应发送给客户端,

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容