不知不觉,在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只会作为转载,更新会延迟,望见谅。