博客
关于我
Express路由是如何实现的?
阅读量:208 次
发布时间:2019-02-28

本文共 2550 字,大约阅读时间需要 8 分钟。

Express是一个极简的Node.js后端开发框架,它最强大的地方在于它的路由实现,那么它的路由是如何实现的呢?下面给大家分享两段代码,希望大家能够有个简单的认识。

首先是封装的路由模块

var url = require('url');// 封装res.send()方法function changeRes(res) {    res.send = function (data) {        res.writeHead(200, { "Content-Type": "text/html;charset='utf-8'" });        res.end(data);    }};// 定义主服务方法var Server = function () {    var G = this;    // 处理GET和POST请求    this._get = {};    this._post = {};    var app = function (req, res) {        changeRes(res);        // 获取路由        var pathname = url.parse(req.url).pathname;        // 处理URL路由,将结尾加上'/',与注册方法统一        if (!pathname.endsWith('/')) {            pathname = pathname + '/';        };        // 获取请求的方式,GET和POST请求        var method = req.method.toLowerCase();        // 判断方法是否存在        if (G['_' + method][pathname]) {            // 执行POST请求            if (method == 'post') {                var postStr = '';                req.on('data', function (chunk) {                    postStr += chunk;                });                req.on('end', function (err, chunk) {                    req.body = postStr;                    G['_' + method][pathname](req, res);                });                // 执行GET请求            } else {                G['_' + method][pathname](req, res);            };        } else {            res.end('no router');        };    };    // 定义一个GET方法为所有的GET请求注册    app.get = function (string, callback) {        // 将请所有注册路由前后加上'/'        if (!string.endsWith('/')) {            string = string + '/';        };        if (!string.startsWith('/')) {            string = '/' + string;        };        G._get[string] = callback;    };    // 定义一个POST方法为所有的POST请求注册    app.post = function (string, callback) {        // 将请所有注册路由前后加上'/'        if (!string.endsWith('/')) {            string = string + '/';        };        if (!string.startsWith('/')) {            string = '/' + string;        };        G._post[string] = callback;    };    return app;}module.exports = Server();

下面是引入路由并使用。

var http=require('http');var ejs=require('ejs');// 引入封装的路由var app=require('express-route.js');http.createServer(app).listen(3000);// 注册首页的路由(方法)app.get('/',function(req,res){    var msg='这是数据库的数据'    ejs.renderFile('views/index.ejs',{msg:msg},function(err,data){        res.send(data);    })});// 注册login的路由(方法)app.get('/login',function(req,res){    console.log('login');    ejs.renderFile('views/form.ejs',{},function(err,data){        res.send(data);    })});// 注册dologin的路由(方法)app.post('/dologin',function(req,res){    console.log(req.body);      res.send("");})

 

转载地址:http://hgip.baihongyu.com/

你可能感兴趣的文章
NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南002---大数据之Nifi工作笔记0069
查看>>
NIFI集群_内存溢出_CPU占用100%修复_GC overhead limit exceeded_NIFI: out of memory error ---大数据之Nifi工作笔记0017
查看>>
NIFI集群_队列Queue中数据无法清空_清除队列数据报错_无法删除queue_解决_集群中机器交替重启删除---大数据之Nifi工作笔记0061
查看>>
NIH发布包含10600张CT图像数据库 为AI算法测试铺路
查看>>
Nim教程【十二】
查看>>
Nim游戏
查看>>
NIO ByteBuffer实现原理
查看>>
Nio ByteBuffer组件读写指针切换原理与常用方法
查看>>
NIO Selector实现原理
查看>>
nio 中channel和buffer的基本使用
查看>>
NIO_通道之间传输数据
查看>>
NIO三大组件基础知识
查看>>
NIO与零拷贝和AIO
查看>>
NIO同步网络编程
查看>>
NIO基于UDP协议的网络编程
查看>>
NIO笔记---上
查看>>
Vue3.0中的响应式原理(第九课)
查看>>
NIO蔚来 面试——IP地址你了解多少?
查看>>
NISP一级,NISP二级报考说明,零基础入门到精通,收藏这篇就够了
查看>>
NISP国家信息安全水平考试,收藏这一篇就够了
查看>>