目前实现了静态文件下载、根据地址导航到控制器相应的控制器方法,但视图模版功能目前还未实现。

服务器代码(httpserver.js):

var http = require("http"),
url = require("url"),
path = require("path"),
fs = require("fs"),
getContentType=function(type){
var type=type.indexOf(".")===0 ? type.substr(1) : type,
defType="application/octet-stream",
types={
html:"text/html",
js:"text/javascript",
css:"text/css",
gif:"image/gif",
jpg:"image/jpeg",
png:"image/png",
};
return typeof(types[type])!="undefined" ? types[type] : defType;
}; http.createServer(function(req, res) {
var pathname=url.parse(req.url).pathname;
if(pathname=="/"){
pathname+="index.html";
}
pathname=__dirname+pathname;
console.log(req.url); if(req.url.match(/^\/controller\//) || req.url.match(/^\/data\//)){ //禁止访问目录
res.writeHead(404, {"Content-Type" : "text/html"});
}else if(req.url.match(/^\/\w+\/\w+(\?.*)?$/)){ //控制器输出
var u=url.parse(req.url),
ca=u.pathname.substr(1).split("/"),
c=ca[0],a=ca[1],
cpath=__dirname + "/controller/"+c+".js",
controller;
if(fs.existsSync(cpath)){
res.writeHead(200, {"Content-Type" : getContentType("html")});
controller=require(cpath);
if(typeof(controller[a])!="undefined"){
controller[a](res,u);
}
//delete require.cache[cpath]; //是否清空脚本缓存
}else{
res.writeHead(200, {"Content-Type" : getContentType("html")});
res.end(path+" not exists!");
}
}else if(fs.existsSync(pathname)){//静态文件输出
res.writeHead(200, {"Content-Type" : getContentType(path.extname(pathname))});
fs.readFile(pathname, function(err, data) {
res.end(data);
});
}else{
res.writeHead(404, {
"Content-Type" : getContentType("html")
});
res.end("<h1>404 Not Found</h1>");
} }).listen(8080, "127.0.0.1"); console.log("Server running at http://127.0.0.1:8080/");

控制器代码(controller/project.js):

var tm=1,
mysql=require("mysql"),
conn = mysql.createConnection({
host: '127.0.0.1',
user: 'root',
password: '123456',
database:'dbname',
port: 3306
});
conn.connect(); var project={
show:function(res,url){
var paras={},tb="user";
console.log(url.query);
if(typeof(url.query)=="string"){
var ps=url.query.split("&"),pss;
for(var k in ps){
pss=ps[k].split("=");
paras[pss[0]]=pss[1];
}
}
res.write((tm++)+"<br/>"); conn.query(
'SELECT * from prefx_'+(typeof(paras.tb)!="undefined" ? paras.tb : tb )+' limit 0,3',
function(err, results, fields){
var field="",str="",fds=[];
if (results) {
for(var k in fields){
fds.push(fields[k]['name']);
}
for ( var i = 0; i < results.length; i++) {
str="";
for(var k in fds){
str+=results[i][fds[k]]+"\t";
}
res.write(str+"<br/>");
}
}
res.end("<br/>"+(new Date()).getTime());
}
);
}
} module.exports=project;

网站目录结构如下:

例如访问:http://127.0.0.1:8080/project/show,则访问project控制器中show方法

一个NodeJS写的基于MVC的服务器的更多相关文章

  1. 分享一个nodejs写的小论坛

    引言:作为一个前端小菜鸟,最近迷上了node,于是乎空闲时间,为了练练手写了一个node的小社区,关于微信小程序的,欢迎大家批评指导. 项目架构部分 一.前端架构 作为一个写样式也得无聊的前端狮,我偷 ...

  2. 分享一个以前写的基于C#语言操作数据库的小框架

    一:前言 这个是以前写的操作MySQL数据库的小型框架,如果是中小型项目用起来也是很不错的,里面提供Filter.ModelPart.Relationship等机制实现操作数据库时的SQL语句的拼接和 ...

  3. 分享一个自己写的基于TP的关系模型

    为了说明问题,假设现在有表test1,test1有从表test2:test1属于test3,test1和test4多对多,关联表test1_test4. 1.定义关系 class Test1Model ...

  4. 分享一个自己写的基于JQuery的一个Web背景切换的Demo

    这个效果主要有两个特点: 1. 背景切换的渐变 2. 背景大小自适应 3. 背景自适应保持比例同时, 相对居中 js源码: (function ($) { $.fn.bgChange = functi ...

  5. 分享一个自己写的基于canvas的原生js图片爆炸插件

    DEMO访问地址: https://bupt-hjm.github.io/BoomGo/博客地址: http://bupt-hjm.github.io/2016/07/10/boom/插件及使用方法地 ...

  6. 分享一个自己写的基于TP的关系模型(四)

    修复分页BUG,原有代码查询到最后一页就一只查询最后一页 $ ? $; $this->maxPage = ceil($this->total/$this->rows); //$thi ...

  7. 分享一个自己写的基于TP的关系模型(三)

    这段时间对模型做了升级和优化,并将版本更新到TP3.2. 下载 下载后请将目录放置TP的Library目录下 1.数据节点优化,原来的节点为模型的名称或者表名,现在更新为定义关系的方法名 public ...

  8. 分享一个自己写的基于TP的关系模型(2)

    1.增加多对多关系的处理 /** * 定义关系 * @return array */ public function test4(){ //参数说明 //关联的模型 //主表关联字段 //关联中间表 ...

  9. 服务器文档下载zip格式 SQL Server SQL分页查询 C#过滤html标签 EF 延时加载与死锁 在JS方法中返回多个值的三种方法(转载) IEnumerable,ICollection,IList接口问题 不吹不擂,你想要的Python面试都在这里了【315+道题】 基于mvc三层架构和ajax技术实现最简单的文件上传 事件管理

    服务器文档下载zip格式   刚好这次项目中遇到了这个东西,就来弄一下,挺简单的,但是前台调用的时候弄错了,浪费了大半天的时间,本人也是菜鸟一枚.开始吧.(MVC的) @using Rattan.Co ...

随机推荐

  1. [转]c中按位分配int的方法

    从网上看到这样一段c代码,让我发觉我的C基本功还是不行啊~~ typedef struct xp { int a:2; int b:2; unsigned int c:1; } xp; 不知道大家对i ...

  2. SolidEdge 装配体中如何快速的搞定一个面上所有螺丝 如何在装配体上进行阵列

    1 点击"规则排列" 选择要排列的螺丝   2 选择被规则排列的架子   3 选择所有的圆孔(鼠标滑到任意圆孔位置,左键单击即可选中所有圆孔)   4 选择参考的基准孔(已经上了螺 ...

  3. Dynamics CRM 2015中的SSRS Report集成配置

    大家应该都知道.Dynamics CRM能集成SSRS Report,而且我也在之前的博文中讨论过怎样制作一个简单的SSRS Report并部署到Dynamics CRM中.今天我们来看看一些比較有用 ...

  4. android-----JNI中的log打印

    1. 导入log头文件 在你使用的 .c/ .cpp 文件中 导入 log.h 头文件 #include<android/log.h> 2.在Android.mk 中 加上 LOCAL_L ...

  5. jQuery Ajax Post Data Example

    http://www.formget.com/jquery-post-data/ jQuery Ajax Post Data Example Fugo Of FormGet jQuery $.post ...

  6. 使用 C# 开发智能手机软件:推箱子(四)

    这是"使用 C# 开发智能手机软件:推箱子"系列文章的第四篇. 在这篇文章中,介绍 Common/FindPath.cs 源程序文件. using System; using Sy ...

  7. DoubleViewPager

    https://github.com/eltld/DoubleViewPager https://github.com/eltld/DoubleViewPagerSample

  8. Spark-1.5.2之改动源代码后的自己定义打包编译

    Spark-1.5.2之自己定义打包编译,基于当前最新版本号的spark源代码1.5.2版本号. 自己编译spark是改动spark源代码的必备条件,改动的源代码自己定义打包生效后才干公布到生产环境中 ...

  9. 在MVC中使用泛型仓储模式和工作单元来进行增删查改

    原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/crud-operations-using-the-generic-repository-pat ...

  10. 【读书笔记】iOS-GCD-用法

    代码: -(void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event { dispatch_async(dispatch_get_gl ...