middleware模块开发和引入

准备

使用 $npm install [email protected] 进行安装之前版本,本篇在此基础上利用中间件的模式增加功能,对诸如LESS、jade、coffeeScript文件文本的动态解析输出。

添加依赖

middleware的一些模块, 我们使用开发依赖不在安装http-f2e-server的时候直接下载。
因此添加依赖的时候放在devDependencies参数上面。

"devDependencies": {
    "jade":">=1.7.0",
    "coffee-script": ">=1.8.0",
    "less": "2.0.0",
    "markdown":">=0.5.0"
  },

然后 npm install 安装所有中间件依赖模块

添加模块入口

因为中间件都是对字符串的操作,我将入口放在 mime.isTXT(pathname) 条件下。可以根据自己需求,放在跟handle模块同级或者内部判断, 原版 f2e-server 是和handle模块并行的,这版处理的时候使用在handle模块里面。

var compiled = _.template(str),
    result = compiled({require: require,request:req,response:resp}),
    mw;
if( mw = middleware[ req.url.match(/\b(\w+)$/)[1] ] ){
    mw(str,root,req,resp);
}else{
    return str;
}

在middleware内部

创建中间件模块,依次根据各种文件后缀名创建解析方法,在内部使用resp输出结果,首先创建最简单的markdown解析, 如下:

"use strict";
var mime = require("./mime");
module.exports = {
    md: function(str,root,req,resp){
        resp.writeHead(200,{"Content-Type": mime.lookup('html')});
        var output = require( "markdown" ).markdown.toHTML(str + '');
        resp.end( '' + output, "utf-8" );
    }
};

markdown模块相关的API可以查看github:https://github.com/evilstreak/markdown-js
这里完成后,直接从浏览器访问 http://localhost:8888/README.md 就能够获取到markdown解析结果HTML了

添加更多解析器

  • LESS
    因为LESS后缀在mime中不能获取到和css一样的type,我们需要去修改包装的mime对应方法lookup
var mime = require("mime");
module.exports = {
    isTXT: function(path){
        return /\b(text|xml|javascript|json)\b/.test( this.lookup(path) );
    },
    lookup: function(path){
        if( /\bless\b/.test(path) ){
            return mime.lookup("css");
        }else{
            return mime.lookup(path);
        }
    }
};

然后添加less解析器

less: function(str,root,req,resp){
        require("less").render(str, function (err, output) {
            if (err) { throw err }
            else{
                resp.end( output.css );
            }
        });
}

但是事实上,你去直接访问对应的less文件链接的时候服务端竟然返回空, 这是由于在主模块中...

else if( mime.isTXT(pathname) ){
        rs.on("end",function(){
                str = require("./lib/handle").execute(str, root, req, resp);  //将处理过程用一个新的模块实现
                resp.end( str );
        });
}

把handle模块的执行结果已经当作字符串输出到响应中,但是在LESS解析器模块中的处理过程是异步监听机制的,我们需要修改这里当没有数据返回的时候不要使用响应输出。

else if( mime.isTXT(pathname) ){
        rs.on("end",function(){
                str = require("./lib/handle").execute(str, root, req, resp);  //将处理过程用一个新的模块实现
                if(typeof str != "undefined") resp.end( str ); //只有返回结果不是undefined时,才直接输出
        });
}

然后再次测试,你对应的LESS资源, ! 妥妥的了 !

更多解析器

可以自行查看更多相关模块的API (查看各个模块的package.json中的git地址查看)

PS:

相关完整代码已经发布到了npm仓库中, 可以使用 $npm install [email protected] 进行安装或者更新。进入目录后使用 $node http-f2e-server.js 启动服务,并查看Demo。

你可能感兴趣的:(middleware模块开发和引入)