快速入门:



# 快速初始化Npm
npm init -y

# 安装全局express脚手架: https://github.com/expressjs/generator
npm install -g express-genertator

# 安装项目express
npm install express --save-dev

# 使用脚手架快速构建一个依赖于sass(styl、less)的项目
express -c sass my-application# 安装项目依赖
cd express && npm install

# 开启项目
DEBUG-my-application ./bin/www


 

安装依赖的过程中,如果你是window用户,可能会出现类似 node-sass 等等这样那样的环境或依赖问题导致编译失败。

请先安装windows-build-tools. 然后重试



# github地址
https://github.com/felixrieseberg/windows-build-tools

# 安装命令(使用管理员运行powershell / cmd运行以下代码)
npm install --global --production windows-build-tools


 

如果一切顺利,开启任意浏览器进入 http://localhost:3000 查看:

Nodejs express 学习_json

 

接下来,我们就从脚手架生成的代码来学习

 



 

补充: 每次修改nodejs的源码(除了jade、pug、ejs等模板引擎),都需要重新启动app.js才能生效。

我们可以使用 supervisor 来帮助我们自动重启应用。 npm install supervisor -g 

你怎么通过node启动应用的,就换成使用supervisor启动即可。



# before 
node app

# after
supervisor app


 

 



 

1、Express核心:路由



# app.js
var index = require('./routes/index');
var users = require('./routes/users');

app.use('/', index);
app.use('/users', users);


打开 http://localhost:3000/ 和 http://localhost:3000/users 可以看到对应的界面。我们也可以自己写一个中间件试试



// 试试水
app.use('/about', function (req,rep,next) {
rep.send("fuck you about");
})


访问 http://localhost:3000/about

Nodejs express 学习_post请求_02

 

补充:这里有个神坑



# app.js
app.use('/reg', reg);

# routes/reg.js
router.get('/reg', function(req, res, next) {
res.render('reg', { title: 'Express' });
});
当我们访问 http://localhost:3000 时,会发现显示404。原因是什么呢?
其实只要把reg.js中的 router.get('/reg', ...) 改为 router.get('/', ...) 即可。
因为前者索引的地址为 http://localhost:3000/reg/reg 而后者才是我们想要实现的路由。可以试试


  

2、Express核心:中间件

app.js中的每一行代码几乎都是中间件:app.use(<middleware>)

1、logger: 会不停的在控制台打印请求输出日志

2、bodyParser: 解析HTTP请求

3、cookieParser: 解析Cookie数据

...

 



 

3、不使用脚手架、生成器、中间件、高级模块。照样可以快速的构建express应用

  • 创建文件结构和目录、文件
  • NPM初始化
  • 依赖声明
  • app.js
  • jade
  • 运行node服务



# 创建文件夹和文件
mkdir views db public routes && touch app.js && cd views && touch index.jade
# 初始化npm 和 安装依赖
npm init -y && npm install express jade stylus mongoskin --save


 

app.js



var express =require('express');
var http = require('http');
var path = require('path');

var app = express();

app.set('port', process.env.PORT || 3000);
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');

app.all('*', function (req,res) {
res.render('index', {msg: "welcome to my blogs!"})
})

http.createServer(app).listen(app.get('port'), function () {
console.log("express server listeng on port" + app.get('port'));
});


 

index.jade



h1 hello
p #{msg}


 

node app 运行服务

Nodejs express 学习_post请求_03

 



 

4、使用 Mocha + Expect.js 进行 BDD 测试

目标: 通过mocha + 断言库 对express的启动服务功能进行单元测试



# 创建测试目录和测试文件
mkdir tests && touch index.test.js

# 安装相关依赖
npm install expect.js mocha superagent --save

# 安装全局Mocha
npm install mocha -g
# expect.js github 和 API手册
https://github.com/Automattic/expect.js


 

修改 app.js 的代码以便进行单元测试



// http.createServer(app).listen(app.get('port'), function () {
// console.log("express server listeng on port" + app.get('port'));
// });

var server = http.createServer(app);

var boot = function () {
server.listen(app.get('port'), function () {
console.log('express server listening on port: ' + app.get('port'))
})
}

var shutdown = function () {
server.close();
}

if (require.main === module) {
boot()
} else {
console.log("Running app as a module");
exports.boot = boot;
exports.shutdown = shutdown;
exports.port = app.get('port')
}


 

编写测试用例:tests / index.test.js



var boot = require('../app').boot;
var shutdown = require('../app').shutdown;
var port = require('../app').port;
// http请求库
var superagent = require('superagent');
// 注意这个库的全名必须带.js
var expect = require('expect.js');
describe('server', function () {
before(function () {
boot();
});

describe('homepage', function () {
it ('should respond to GET', function (done) {
superagent.get('http://localhost:' + port)
.end(function (err, res) {
expect(res.status).to.equal(200);
done()
})
})
})

after (function () {
shutdown()
})
})


 

运行测试用例: mocha tests/index.test.js

Nodejs express 学习_json_04

 



 

5、单独使用和学习jade. 


 



 

6、继续回到脚手架,通过脚手架学习

(1)req.query:处理get请求,获取get的请求参数

(2)req.params: 处理/:xxx形式的get或post请求,获取get/post的请求参数

(3)rep.bodu:处理Post请求,获取Post请求体

(4)rep.param():处理get和post请求

 

7、使用github + express登录

1、打开github并且登录,在右上角个人信息中选择Settings -> Developer settings -> OAuth applications -> Register a new application

Nodejs express 学习_json_05

 

回到项目中,安装 passport 和 passport-github 



npm install passport-github passport --save-dev


 

在项目的入口app.js代码中,加入如下代码块



const passport = require('passport')
const GithubStrategy = require('passport-github').Strategy

const app = express()
app.use('/login',  require('./routes/login'))
app.use(passport.initialize()) // 初始化passport
if (app.get('env') === 'development') {
passport.use(new GithubStrategy({
clientID: "e50400ce682488d87b71",
clientSecret: "13e406e42b4578ab600c93df8e059bd80a3205b8",
callbackURL: "http://localhost:3000/login/github/callback"
}, function (accessToken, refreshToken, profile, done) {
done(null, profile);
}))
}


 

进入/routes/login.js中,加入如下代码块.



const passport = require('passport')
router.get('/github', passport.authenticate('github', {session: false}))
router.get('/github/callback', passport.authenticate('github', {
session: false,
failureRedirect: '/login',
successFlash: '登录成功'
}),
function (req, res, next) {
req.session.user = {
name: req.user.username,
head: "http://gravatar.com/avatar/" + req.user._json.gravatar_id + "?s=48"
};
res.redirect('/')
}
)


由于我的项目直接使用了express的session功能,所以禁掉了Passport的session功能。

Passport 默认会将用户信息存储在req.user中。这里我们获取到了用户的头像("http://gravatar.com/avatar/" + req.user._json.gravatar_id + "?s=48") 和 用户名 (req.user.username)。并且加入到session中。然后跳转到首页。

就这么简单

 

持续更新知识点...