Var express = require(“express”) //引用模块
var app = express()
1、body-parser - node.js 中间件,用于处理 JSON, Raw, Text 和 URL 编码的数据。
2、cookie-parser - 这就是一个解析Cookie的工具。通过req.cookies可以取到传过来的cookie,并把它们转成对象。
3、multer - node.js 中间件,用于处理 enctype="multipart/form-data"(设置表单的MIME编码)的表单数据
4、Express 应用使用回调函数的参数: request 和 response 对象来处理请求和响应的数据。
5、request 和 response 对象的具体介绍:
Request 对象 - request 对象表示 HTTP 请求,包含了请求查询字符串,参数,内容,HTTP 头部等属性。常见属性有:
- req.app:当callback为外部文件时,用req.app访问express的实例
- req.baseUrl:获取路由当前安装的URL路径
- req.body / req.cookies:获得「请求主体」/ Cookies
- req.fresh / req.stale:判断请求是否还「新鲜」
- req.hostname / req.ip:获取主机名和IP地址
- req.originalUrl:获取原始请求URL
- req.params:获取路由的parameters
- req.path:获取请求路径
- req.protocol:获取协议类型
- req.query:获取URL的查询参数串
- req.route:获取当前匹配的路由
- req.subdomains:获取子域名
- req.accepts():检查可接受的请求的文档类型
- req.acceptsCharsets / req.acceptsEncodings / req.acceptsLanguages:返回指定字符集的第一个可接受字符编码
- req.get():获取指定的HTTP请求头
- req.is():判断请求头Content-Type的MIME类型
Response 对象 - response 对象表示 HTTP 响应,即在接收到请求时向客户端发送的 HTTP 响应数据。常见属性有:
- res.app:同req.app一样
- res.append():追加指定HTTP头
- res.set()在res.append()后将重置之前设置的头
- res.cookie(name,value [,option]):设置Cookie
- opition: domain / expires / httpOnly / maxAge / path / secure / signed
- res.clearCookie():清除Cookie
- res.download():传送指定路径的文件
- res.get():返回指定的HTTP头
- res.json():传送JSON响应
- res.jsonp():传送JSONP响应
- res.location():只设置响应的Location HTTP头,不设置状态码或者close response
- res.redirect():设置响应的Location HTTP头,并且设置状态码302
- res.render(view,[locals],callback):渲染一个view,同时向callback传递渲染后的字符串,如果在渲染过程中有错误发生next(err)将会被自动调用。callback将会被传入一个可能发生的错误以及渲染后的页面,这样就不会自动输出了。
- res.send():传送HTTP响应
- res.sendFile(path [,options] [,fn]):传送指定路径的文件 -会自动根据文件extension设定Content-Type
- res.set():设置HTTP头,传入object可以一次设置多个头
- res.status():设置HTTP状态码
- res.type():设置Content-Type的MIME类型
6、Express 提供了内置的中间件 express.static 来设置静态文件如:图片, CSS, JavaScript 等。
7、set 方法
使用set方法,为系统变量“views”和“view engine”指定值
常规设置:
views, 放模板文件的目录,比如: app.set('views', './views')
view engine, 模板引擎,比如: app.set('view engine', 'ejs')
如上按照ejs的写法就可以渲染我们的页面的,但是很恶心,至少我觉得,个人写html习惯了,subtime还提供语法高亮和emmet快捷写法,使用ejs的写法,没颜色,没快捷。下面改造下,
app.set('views','./views');
app.set('view engine','html');
app.engine('.html',require('ejs').__express);
8、app.use用法
use是express 注册中间件的方法,它返回一个函数。
use方法内部可以对访问路径进行判断,据此就能实现简单的路由,根据不同的请求网址,返回不同的网页内容。
除了在回调函数内部判断请求的网址,use方法也允许将请求网址写在第一个参数。这代表,只有请求路径匹配这个参数,后面的中间件才会生效。无疑,这样写更加清晰和方便。
app.use('/path', someMiddleware);
上面代码表示,只对根目录的请求,调用某个中间件。
9、all方法和HTTP动词方法
针对不同的请求,express提供了use方法的一些别名。比如上面代码也可以用别名的形式来写
栗子:
app.all("*", function(request, response, next) { response.writeHead(200, { "Content-Type": "text/plain" }); next(); });
app.get("/", function(request, response) { response.end("Welcome to the homepage!"); });
all方法表示,所有请求都必须通过该中间件,参数中的“*”表示对所有路径有效。get方法则是只有GET动词的HTTP请求通过该中间件,它的第一个参数是请求的路径。由于get方法的回调函数没有调用next方法,所以只要有一个中间件被调用了,后面的中间件就不会再被调用了。
除了get方法以外,Express还提供post、put、delete方法,即HTTP动词都是Express的方法。
这些方法的第一个参数,都是请求的路径。除了绝对匹配以外,Express允许模式匹配。
*set方法用于设定内部变量,use方法用于调用express的中间件!!!
10、栗子:静态网页模板
在项目目录之中,建立一个子目录views,用于存放网页模板。
假定这个项目有三个路径:根路径(/)、自我介绍(/about)和文章(/article)。那么,app.js可以这样写:
var express = require('express');
var app = express();
app.get('/', function(req, res) { res.sendfile('./views/index.html'); });
app.get('/about', function(req, res) { res.sendfile('./views/about.html'); });
app.get('/article', function(req, res) { res.sendfile('./views/article.html'); });
app.listen(3000);
上面代码表示,三个路径分别对应views目录中的三个模板:index.html、about.html和article.html。另外,向服务器发送信息的方法,从send变成了sendfile,后者专门用于发送文件。
app.configure
开发者可以使用configure() 方法根据当前环境的需要进行设置,当configure() 没有传入环境名称时,它会在各环境之前被调用
定义共享环境
app.configure(function(){
app.use(express.methodOverride());
app.use(express.bodyParser());
app.use(app.router); });
定义开发环境
app.configure('development',function(){
app.use(express.static(__dirname + '/public'));
app.use(express.errorHandler({ dumpExceptions: true, showStack: true }));
});
定义生产环境
app.configure('production', function(){
var oneYear = 31557600000;
app.use(express.static(__dirname + '/public', { maxAge: oneYear }));
app.use(express.errorHandler());
});
Node.js 常用模块
node.js当中的fs模块与readline模块主要对应着系统的文件操作,node当中的文件操作和网络操作都属于阻塞性操作,故存在着大量的异步回调函数;
并且为了避免出错,凡是涉及文件操作,我们一律使用文件的绝对物理路径来传递文件路径参数,这里常用的为path.join()和__dirname
fs模块当中的常用API
1、fs.stat(path,callback)
该方法用于检测文件的状态,可以借此来判断某个文件是否存在。path参数传入该文件的绝对物理路径,该callback回调函数有两个参数err和stats。
其中err为错误信息参数,stats为一个文件状态对象。
2、fs.writeFile(path,data[,options],callback)
该方法可用于往指定文件当中写入内容,该内容会覆盖文件当中原有的内容。若传入的文件路径当中的文件不存在,则先完成该文件的穿件,再往里面写入指定内容。path参数为该文件的绝对物理路径,data为需要写入该文件当中的数据内容,其中options参数可选,可以传入编码格式,若不传则默认为utf8。callback回调参数当中只有一个错误信息参数err,一般在写入失败时触发调用。
3、fs.unlink(path,callback)
该方法可用于完成指定文件的删除。
4、fs.readFile(path[,options],callback)
该方法用于读取指定文件当中的内容,path参数为该文件的绝对物理路径,其中options参数可选,可以传入编码格式,如读取文本文件时,可传入'utf8',若不指定编码格式,则默认输出读取的文件内容为Buffer形式,故一般都会传入该参数。callback回调参数当中有两个参数err和data,其中err为错误信息参数,一般在在文件不存在或者读取文件失败时触发调用,data为文件内容
path模块
功能:格式规范化路径
//引入模块
var path = require("path");
var str = "../d\/d/fg/gg//.l";
//格式化不规范的路径
console.log(path.normalize(str));
//拼接路径
var res = path.join("s/b/c/d","../f");
console.log(res);
util 模块
node 里面一个工具模块 ,node 里面几乎所有的模块 都会用到 在这个模块
* 功能:
* 1 实现继承 这是主要功能
* 2 实现对象的完整输出
* 3 实现判断数据类型
node-dev\nodemon
node-dev\nodemon 模块是一个开发工具,当你的 js 文件修改保存后,他会自动重启服务进程,另外它还支持桌面提醒。
使用方法
node-dev --debug app.js