Express 是一个简洁而灵活的 node.js Web应用框架, 提供了一系列强大特性帮助你创建各种 Web 应用,和丰富的 HTTP 工具。使用 Express 可以快速地搭建一个完整功能的网站。
Express 框架核心特性:
可以设置中间件来响应 HTTP 请求。
定义了路由表用于执行不同的 HTTP 请求动作。
可以通过向模板传递参数来动态渲染 HTML 页面。
首先,我们先npm init 初始化一个 node 项目,然后安装 express:
npm init
npm install express --save
以下几个重要的模块需要与 express 框架一起安装:
body-parser - node.js 中间件,用于处理 JSON, Raw, Text 和 URL 编码的数据。
cookie-parser - 这就是一个解析Cookie的工具。通过req.cookies可以取到传过来的cookie,并把它们转成对象。
multer - node.js 中间件,用于处理 enctype="multipart/form-data"(设置表单的MIME编码)的表单数据。
npm install body-parser --save npm install cookie-parser --save npm install multer --save
创建 express_demo.js 文件,代码如下所示:
var express = require(‘express‘); var app = express(); app.get(‘/‘, function (req, res) { res.send(‘Hello World‘); }) var server = app.listen(8081, function () { var host = server.address().address var port = server.address().port console.log("应用实例,访问地址为 http://%s:%s", host, port) })
执行 node express_demo.js ,在浏览器中访问 http://127.0.0.1:8081,可以看到浏览器中显示 hello world,这个就是服务器响应的内容。
Express 使用回调函数的参数: request 和 response 对象来处理请求和响应的数据。
app.get(‘/‘, function (req, res) { // -- })
request 和 response 对象的具体介绍:
Request 对象 - request 对象表示 HTTP 请求,包含了请求查询字符串,参数,内容,HTTP 头部等属性。常见属性有:
Response 对象 - response 对象表示 HTTP 响应,即在接收到请求时向客户端发送的 HTTP 响应数据。常见属性有:
路由决定由哪个脚本代码去响应客户端请求。在HTTP请求中,我们可以通过路由提取出请求的URL以及GET/POST参数。
创建 express_demo2.js 文件,代码如下所示:
var express = require(‘express‘); var app = express(); // 主页输出 "Hello World" app.get(‘/‘, function (req, res) { console.log("主页 GET 请求"); res.send(‘Hello GET‘); }) // POST 请求 app.post(‘/‘, function (req, res) { console.log("主页 POST 请求"); res.send(‘Hello POST‘); }) // /del_user 页面响应 app.get(‘/del_user‘, function (req, res) { console.log("/del_user 响应 DELETE 请求"); res.send(‘删除页面‘); }) // /list_user 页面 GET 请求 app.get(‘/list_user‘, function (req, res) { console.log("/list_user GET 请求"); res.send(‘用户列表页面‘); }) // 对页面 abcd, abxcd, ab123cd, 等响应 GET 请求 app.get(‘/ab*cd‘, function(req, res) { console.log("/ab*cd GET 请求"); res.send(‘正则匹配‘); }) var server = app.listen(8081, function () { })
执行以上代码:node express_demo2.js。由此我们访问不同的页面路径浏览器将显示不同的结果。
我们可以在浏览器中访问 http://127.0.0.1:8081、http://127.0.0.1:8081/list_user、 http://127.0.0.1:8081/abcd、http://127.0.0.1:8081/abcdefg 来查看结果。
Express 提供了内置的中间件 express.static 来设置静态文件如:图片, 文本文件txt 等。
你可以使用 express.static 中间件来设置静态文件路径。例如,如果你将图片, CSS, JavaScript 文件放在 public 目录下,你可以这么写:
原文:https://www.cnblogs.com/wenxuehai/p/14263767.html