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

服务器代码(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. 微信小程序 - 音频播放(1.2版本和1.2版本之后)

    不多说了,直接贴code // 1.2版本以后便不在维护 wx.getBackgroundAudioManager({ success:function(res){ var status =res.s ...

  2. Android 最新控件 Toolbar

    之前Android的ActionBar好像做项目从没用过.除了google自己,并没有多少人用,究其原因,主要是由于ActionBar不够灵活,不可以随心所欲的定制,后来Goole也发现了这一点,然后 ...

  3. Linux的SOCKET编程详解(转)

    Linux的SOCKET编程详解 1. 网络中进程之间如何通信 进 程通信的概念最初来源于单机系统.由于每个进程都在自己的地址范围内运行,为保证两个相互通信的进 程之间既互不干扰又协调一致工作,操作系 ...

  4. Cocoa root class

    问题来源: 常见面试问题之: NSObject和NSObject protocol有什么区别,为什么要有NSObject protocol, 有没有不继承自NSObject的类? 虽然在iOS开发过程 ...

  5. nextSibling和previousSibling

    <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content ...

  6. jQuery源代码框架思路

    開始计划时间读源代码,第一节jQuery框架阅读思路整理 (function(){ jQuery = function(){}; jQuery一些变量和函数和给jQuery对象加入一些方法和属性 ex ...

  7. ActiveMQ(二) 转

    package pfs.y2017.m11.mq.activemq.demo02; import java.util.concurrent.atomic.AtomicInteger; import j ...

  8. huawei校招测试题

    三道题两小时. 第一题,圈住所有点的长方形,很简单略过. 第二题:奇偶排序. 奇偶排序 描述: 输入若干(不超过1000个)非负整数数字,请先取出为奇数的数字按从大到小排序,再取出偶数从小到大进行排序 ...

  9. Linux fork函数具体图解-同一时候分析一道腾讯笔试题

    原创blog.转载请注明出处 头文件: #include<unistd.h> #include<sys/types.h> 函数原型: pid_t fork( void); (p ...

  10. ivy

    ivy https://ant.apache.org/ivy/ Apache Ivy™ is a popular dependency manager focusing on flexibility ...