`
zhiweiofli
  • 浏览: 511670 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

基于NodeJs开发的独立博客系统~~上线啦

阅读更多

        不知不觉,在ITEye上“驻扎”已经三年多了。由于个人比较懒,三年间发表的文章加起来只有40多篇。本人愚钝,自知自己的写作水平有限,三年来未现佳作,只是本人一直坚信:分享才是互联网的本质。因而一直分享自己在工作中,技术上的一些愚见,在各位看官面前献丑了。

        最近闲来无事,热衷新技术的毛病发作,开始钻研NodeJs。刚好又赶上oschina的OSC应用开发大赛,本着项目驱动学习的心态,于是就开始了 Zhiweiofli‘s Blog 的开发。

开发Blog的初衷,只是想拥有自己的一个独立空间,所以初期的需求很简单:单用户的博客系统。

        Nodejs开发web很简单,貌似NodeJs天生就是为干这事的,下面是一段简单启动Server的代码,作用就是对于任何的请求都返回:Hello World:

 

var server,
    ip   = "127.0.0.1",
    port = 1337,
    http = require('http');

server = http.createServer(function (req, res) {
  res.writeHead(200, {'Content-Type': 'text/plain'});
  res.end('Hello World\n');
});

server.listen(port, ip);

console.log("Server running at http://" + ip + ":" + port);

     

      接着,对照实际的需求,扩展上面的代码,就可以快速搭建站点啦。哈哈,就这么简单?当然实际上,没这么简单。

      正式开始开发 Zhiweiofli‘s Blog 之前,我先对NodeJs进行了快速地入门:Node入门 ,然后陆续拜访一些相关的Blog,对Node也慢慢地熟悉起来了。

      其实开发Web应用,按照MVC模式,基本也还是几个概念:

  •   模板引擎
  •   路由控制
  •   持久化数据

      感谢Node强大的社区支持,Node发展到今天,其库已经算是比较完善了。对于上面MVC的实现,我选定了以下框架来简化我的开发工作:

  •   EJS,Html模板引擎,ejs没有定义很多标签,用起来比较自然,容易上手
  •   Express,强悍的web开发引擎,功能完善,适合REST协议
  •   Mongoose ,Node连接,操作MongoDB的应用层封装

     以上三个库,都可以通过npm(node package manager)获得,配置好环境后,Server启动的代码就变成下面那样子了:

 

var express = require('express')

function start(routes){                                 //router是map类型的数组,配置各种请求URL对应的处理模块
    var app = express();

    app.configure(function(){
        app.set('port', process.env.PORT || 8000);      //配置服务器监听的端口
        app.set('views', __dirname + '/views');         //配置view的目录
        app.set('view engine', 'ejs');                  //指定模板引擎为ejs
        app.use(express.favicon());
        app.use(express.logger('dev'));
        app.use(express.bodyParser());
        app.use(express.methodOverride()); 
        app.use(express.static(__dirname + '/public')); //public是静态资源
        app.use(app.router);                            //使用express内置的router,稍后进行配置
    });

    app.configure('development', function(){
        app.use(express.errorHandler());
    });

    app.engine('html', require('ejs').renderFile);      //配置模板引擎要处理的文件类型

    // 配置url路由
    var routerPost = routes["post"];
    for(var route in routerPost){
       app.post(route, routerPost[route]);
    }
    var routerGet = routes["get"];
    for(var route in routerGet){
        app.get(route, routerGet[route]);
    }
    var routerDetele = routes["delete"];
    for(var route in routerDetele){
        app.delete(route, routerDetele[route]);
    }
    //连接数据库
    db.connect(function(){

    });
    //启动应用服务器
    http.createServer(app).listen(app.get('port'), function(){
        console.log("Express server listening on port " + app.get('port'));
    });
}

    稍稍变得有点像样了,比起Java开发Web时SSH那种浩荡的工程,上面的简直是小巫见大巫了,哈哈。

    上面的代码基本确定了 Zhiweiofli‘s Blog  的开发架构了,接下来的工作就是,router的配置、各业务逻辑的封装、数据库操作以及各Html页面的实现了。

    
    

公告:

  Zhiweiofli‘s Blog 现在已经正式上线,今后将会作为本人的Blog独立运营,Iteye上的Blog只会作为转载,更新会延迟,望见谅。

  • 大小: 13.7 KB
分享到:
评论
1 楼 cainiao1923 2016-04-08  
上线毛啊,Bad request了

相关推荐

Global site tag (gtag.js) - Google Analytics