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