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

服务器代码(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. Python 基础教程之包和类的用法

    Python 基础教程之包和类的用法 建立一个文件夹filePackage 在filePackage 文件夹内创建 __init__.py 有了 __init__.py ,filePackage才算是 ...

  2. jmeter - DBC Request之Query Type

    工作中遇到这样一个问题: 需要准备10W条测试数据,利用jmeter中的JDBC Request向数据库中批量插入这些数据(只要主键不重复就可以,利用函数助手中的Random将主键的ID末尾五位数随机 ...

  3. Js学习第十天----函数

    函数 什么是函数?函数是由事件驱动的或者当他被调用时运行的可反复使用代码块.预计没明确,个人觉得函数就是能完毕一个功能的代码块. 看个案例: <!DOCTYPE html> <htm ...

  4. unity视频播放,

    PC端视频播放: Unity中实现PC端播放视频,非常easy用到MovieTexture属于贴图Texture的子类. 在播放视频之前.我们得记得下载quicktime插件,仅仅有导入了quickt ...

  5. PowerDesigner逆向工程,从SQL Server数据库生成Physical Model

    提前声明:这种方式貌似只能是Power Designer安装在数据库服务器的时候才可以,因为我按照成功的这个再去从本机逆向连接远程服务器的时候,一直提示:test failed......不讲了,尴尬 ...

  6. 3531: [Sdoi2014]旅行

    3531: [Sdoi2014]旅行 Time Limit: 20 Sec  Memory Limit: 512 MB Submit: 1731  Solved: 772 [Submit][Statu ...

  7. chmod|chown|chgrp和用法和区别

    1.chgrp(改变文件所属用户组) chgrp 用户组   文件名   ###就是这个格了.如果整个目录下的都改,则加-R参数用于递归. 如:chgrp -R   user smb.conf 2.c ...

  8. 该项目不在c:\ 请确认该项目的位置

    该项目不在c:\ 请确认该项目的位置 - CSDN博客https://blog.csdn.net/feilong1lantern/article/details/50388414 在删除不掉的文件夹目 ...

  9. 使用Microsoft Office 2007将文档转换为PDF

    点击帮助 输入关键词PDF后搜索 点击进入Save or convert to PDF or XPS 点击进入2007 Microsoft Office Add-in: Microsoft Save ...

  10. React创建组件的三种方式比较和入门实例

    推荐文章: https://www.cnblogs.com/wonyun/p/5930333.html 创建组件的方式主要有: 1.function 方式 2.class App extends Re ...