nodejs-Express web 学习与实践

Express web 开发框架简介

Express 是一个简洁而灵活的 node.js Web应用框架, 提供一系列强大特性帮助你创建各种Web应用。

Express英文官网
Express中文官网

Express web 开发框架特点

  1. 实现了路由功能。
  2. 中间件功能。
  3. 对request和response对象的扩展。
  4. 可以继承其他模板引擎。

Express web 开发框架基本使用

  1. 安装

    创建目录
    $ mkdir myapp
    $ cd myapp
    
    初始化package.json
    $ npm init
    安装 express 框架
    $ npm install express --save (保存到依赖列表)
    $ npm install express --no-save (临时安装,不添加到依赖中)
    
  2. 应用

    // 加载 expres 模块
    const express = require('express');
    // 创建一个 app 对象
    const app = express();
    // 通过中间件监听指定的路由
    app.get('/', (req, res) => {
        res.send('hello world!世界,你好!');
        // res.end('hello world!世界,你好!')
    });
    // 启动服务,监听8088端口
    app.listen(8088, () => {
        console.log('http://localhost:8088');
    })
    
  3. res.endres.send的区别

    • 接受参数
      • res.end只能接受 StringBuffer 两种类型;
      • res.send能接受各种类型,如 stringbufferjsonarrayobject等;
    • 响应报文头
      • res.end 不会默认设置 content-type,(会出现中文乱码)
      • res.send 默认生成更多的响应报文头,包括content-type(不会出现中文乱码)
  4. app.getapp.useapp.all 注册路由的区别

    • 请求方法
      • app.get请求方法必须是GET;
      • app.useapp.all请求方式不限,什么请求方法都可以;
    • 路由匹配
      • app.getapp.all请求路径的 pathname必须全等于(===);
      • app.use请求的路径中的第一部分与路由匹配即可,并不要求 pathname完全匹配。
  5. 获取pathquery路由参数

    // 获取 path 参数;GET /news/2019/8/1
    app.get('/news/:year/:month/:day', (req, res) => {
    res.send(req.params);
    });
    
    // 获取 query参数;GET /news?year=2019&month=8&day=1
    app.get('/news', (req, res) => {
    res.send(req.params);
    })
    

tips:路径规则支持正则表达式

  1. 小结
  • req.query: 获取 query参数;
  • req.params: 获取path参数;
  • req.body: 获取请求体(body)
  • req.param('key'): 处理get和post请求,但查找优先级由高到低为req.params--->req.body--->req.query

Express web 开发框架更多应用

  1. Express处理静态资源
    const express = require('express');
    const path = require('path');
    
    const app = express();
    
    // 处理静态资源的方法
    const static = express.static(path.join(__dirname, 'static'));
    app.use('/', static);
    app.use('/xxx', static);
    app.use('/www', static);
    
    app.listen(6666, () => {
    console.log('http://localhost:6666');
    });
    
  2. res常用的对象方法
  • res.json([body]) 发送 json response (等价于res.sen(json))
    res.json(null);
    res.json({user: 'zkk'});
    res.status(404).json({error: 'not found!'});
    
  • res.redirect([status,]path) 重定向
    res.redirect('/foo/bar'); // 状态码默认302
    res.redirect(301, 'https://www.baidu.com')
    
  • res.sendFile(path[,options][,fn]) 发送文件
    res.sendFile(path.join(__dirname, 'static', 'avator.jpg'), (err) => {
        if (err) {
                throw err;
        }
        console.log('OK');
    });
    
  • res.status(code).end(message) 设置响应码

Express web 开发框架模块化开发实战

  1. app.js模块负责启动服务
    // 1.加载模块
    const express= require('express');
    // 加载config配置模块
    const config = require('./config.js');
    // 加载router路由模块
    const router = require('./router.js');
    
    // 2.创建 app 对象
    app = express();
    
    // 3.注册路由
    app.use(router); // 默认路径'/'
    // app.use('/', router);
    
    // 4.启动服务
    app.listen(config.port,() => {
            console.log('Server is listening at http://localhost:'+config.port);
    });
    
  2. router.js 负责处理路由
    // 1.创建一个 router 对象
    const express = require('express');
    const router = express.Router();
    // 加载handler业务处理模块
    const handler = require('./handler.js');
    
    // 2.router对象挂载路由
    router.get('/', handler.home);
    router.get('/index', handler.index);
    router.get('/submit', handler.submit);
    router.get('/details', handler.details);
    ...
    
    // 3.暴露 router 对象
    module.exports = router;
    
  3. config.js 负责存储配置信息
    module.exports = {
            port: 8080
            ...
    };
    
  4. handler.js 负责处理业务
    const path = require('path');
    module.exports.index = (req, res) => {
            res.send('index 页面欢迎你!');
    };
    module.exports.home = (req, res) => {
            res.send('home 页面欢迎你!');
    };
    ...
    ...
    
  5. 项目目录结构
|-app
|   |--node_modules
|   |--package.json
|   |--static
|   |   |--images
|   |   |--css
|   |   |--data
|   |--views
|   |   |--home.html
|   |   |--details.html
|   |   |--...
|   |--app.js
|   |--router.js
|   |--handler.js
|   |--config.js
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容