基于Node开发的独立博客系统~~上线啦
? ? ? ? 不知不觉,在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只会作为转载,更新会延迟,望见谅。