由于学的是java,所以此框架多少有点java的影子,我觉得不必排斥语言,只要思想好,所有语言均可以通用。项目分以下几层

  • app.js项目启动入口,类似于main函数
  • controller-view层,此层主要处理输入和输出,与用户交互。node里偏爱叫route层,大致指的是同一个东西
    • 如果是传统的项目,则此层同时包含view+contrller
    • 如果前后端彻底分离,则只有controller
    • view单指视图层,一般是html,asp,jsp,php等
  • service业务逻辑层,此层既不直接操作数据库,也不接受用户的输入。纯粹的业务逻辑
  • dao数据持久层,用于直接与数据库打交道
    • db用于连接数据库操作
    • dbHelper封装操作数据层crud公共方法
  • pojo数据模型层,即实体类

后端

app.js

const Koa=require ('koa');
const Router = require('koa-router');
const koaBodyparser=require('koa-bodyparser');
const log=require('./util/log');
const app=new Koa();
const router=new Router();
const fs = require("fs"); //连接数据库
require('./dao/db') //自定义跨域处理中间件,这个没有封装为一个模块。那个log中间件我封装了,你可以对比一下,其实是一样的,就是看起来简洁些
app.use(async (ctx, next) => {
ctx.response.set('Access-Control-Allow-Origin', '*');
ctx.response.set('Access-Control-Allow-Methods', '*');
await next();
}); //加载所有路由
const routeList = fs.readdirSync('./controller/','utf-8');
routeList.forEach(item=> {
const routeName = item.substring(0,item.lastIndexOf('.'));
require('./controller/'+routeName)(router);
}) //加载中间件
app.use(koaBodyparser());//调用解析post请求参数的中间件
app.use(log);//调用自定义的日志打印中间件
app.use(router.routes())//调用路由中间件 //监听3000端口
app.listen(3000, () => {
console.log('[myapp]已经运行,端口为300')
})

controller>stuCtr.js

const stuSer=require('../service/stuSer')
module.exports=function (route) {
route
.get('/',ctx=>{
ctx.response.type = 'text/html';
ctx.response.body='<h1>瞅啥瞅,这是老子的服务器</h1>'
}) .post('/getStuList',async ctx=>{
let param=ctx.request.body;
let stuList=await stuSer.getStuList();
ctx.response.type = 'text/json';
ctx.response.body=stuList
})
}

service>stuSer.js

const stu=require('../dao/dbHelper')('stu');
module.exports={
getStuList:() => {
let stuList=stu.queryAll();
return stuList;
}
}

dao>db.js

//连接数据库
const mongoose = require('mongoose');
mongoose.connect('mongodb://47.93.52.112/myDb',function (err) {
if(err){
console.log('MongoDB 连接失败');
}else{
console.log('MongoDB 连接成功');
} });

dao>dbHelper.js

module.exports= function (pojoName) {
//引入model
const pojo=require('../pojo/'+pojoName); //创建通用数据库查询方法的对象
let dbHelper={};
dbHelper.queryAll =function () {
let result=pojo.find({});
return result;
}
return dbHelper;
}

pojo>stu.js

const mongoose = require('mongoose');
//创建实体骨架
let stuSchema = mongoose.Schema({
name: String,
age:Number
});
//将骨架映射到数据库表,也就是实体与表之间的映射虚拟模型/类(model)
let stu=mongoose.model('stu',stuSchema); module.exports=stu;

util>log.js

//其实中间件就相当于java的过滤器和拦截器,
// 一next函数为分水岭,执行路由内的方法
// 前边为请求前,可以修改request数据
// 后边为响应后,可以修改response数据
module.exports=async function (ctx,next) {
console.log('\n'+'请求信息:----------------start')
console.log('\n'+'地址:')
console.log(ctx.request.url)
console.log('\n'+'参数:')
console.log(ctx.request.body)
console.log('\n'+'请求信息:----------------end')
await next()
console.log('\n'+'\n'+'\n'+'\n'+'\n'+'返回信息:----------------start')
console.log('\n'+'返回值:',ctx.response.body)
console.log('\n'+'返回信息:----------------end')
}

package.json

{
"name": "after",
"version": "1.0.0",
"description": "",
"main": "app.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"author": "",
"license": "ISC",
"dependencies": {
"fs": "0.0.1-security",
"koa": "^2.5.1",
"koa-bodyparser": "^4.2.0",
"koa-router": "^7.4.0",
"mongoose": "^5.0.17"
}
}

前端

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div class="wrapp"></div>
<button>测试</button>
<script src="http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
<script>
let myser={
getStuList(param) {
let stuList= $.post('http://localhost:3000/getStuList',param)
return stuList;
}
} $('button').click( async function () {
let param={id:123};
let stuList=await myser.getStuList(param)
$('.wrapp').text(JSON.stringify(stuList))
})
</script>
</body>
</html>

数据库

{
"name" : "丁少华",
"age" : 20
} {
"name" : "王鑫",
"age" : 21
}

效果图

github地址

https://github.com/dingshaohua123/koa2Mongoose.git

koa2+mongoose搭建框架模型的更多相关文章

  1. Koa2 + Mongoose + Log4js 持久化日志

    代码地址如下:http://www.demodashi.com/demo/12466.html  之前做的项目是采用 Express 框架进行搭建的,其中的日志管理采用了 winston + Post ...

  2. 网络基础、ftp任务(进度条、计算文件大小、断点续传、搭建框架示例)

    一.网络基础 1.端口,是什么?为什么要有端口? 端口是为了将同一个电脑上的不同程序进行隔离. IP是找电脑:端口是找电脑上的应用程序: 端口范围:1 – 65535 :    1 - 1024 不要 ...

  3. Django框架-模型层

    Django框架-模型层 一.单表查询之必知必会13条 1.时间字段中的两个关键性参数 create_time = models.DateField() # 年月日 create_time = mod ...

  4. 【PSR规范专题(1)】PSR-0+namespace+spl_autoload_register实现框架模型

    了解命名空间 namespace是PHP5.3版本加入的新特性,用来解决在编写类库或应用程序时创建可重用的代码如类或函数时碰到的两类问题: 用户编写的代码与PHP内部的类/函数/常量或第三方类/函数/ ...

  5. 初学springMVC搭建框架过程及碰到的问题

    刚刚开始学spring框架,因为接了一个网站的项目,想用spring+springMVC+hibernate整合来实现它,现在写下搭建框架的过程及碰到的问题.希望给自己看到也能让大家看到不要踏坑. 一 ...

  6. ThinkPHP框架模型连贯操作(八)

    原文:ThinkPHP框架模型连贯操作(八) Thinkphp的连贯操作使用起来也是很灵活: *可能这里有的mysql函数没全部罗列出来,大家可以举一反三,形式雷同 一.常用连贯操作 1.where ...

  7. 从零开始搭建框架SSM+Redis+Mysql(二)之MAVEN项目搭建

    从零开始搭建框架SSM+Redis+Mysql(二)之MAVEN项目搭建 废话不说,直接撸步骤!!! 1.创建主项目:ncc-parent 选择maven创建项目,注意在创建项目中,packing选择 ...

  8. 从零开始搭建框架SSM+Redis+Mysql(一)之摘要

    从零开始搭建框架SSM+Redis+Mysql(一)之摘要 本文章为本人实际的操作后的回忆笔记,如果有步骤错漏,希望来信307793969@qq.com或者评论指出. 本文章只体现过程,仅体现操作流程 ...

  9. keras入门(三)搭建CNN模型破解网站验证码

    项目介绍   在文章CNN大战验证码中,我们利用TensorFlow搭建了简单的CNN模型来破解某个网站的验证码.验证码如下: 在本文中,我们将会用Keras来搭建一个稍微复杂的CNN模型来破解以上的 ...

随机推荐

  1. Android studio 添加admob googgle play services

    Android studio 添加admob googgle play services MainActivity import com.google.android.gms.ads.AdReques ...

  2. OOXML,XLSX分析

    07以上的xlsx是使用了OOXML和zip,将后缀修改为.zip,就可以看到文件,主要分析xl目录下的文件,如图: 主要数据文件在xl目录下面 styles.xml里面存放着excel的样式数据 很 ...

  3. you *might* want to use the less safe log_bin_trust_function_creators variable

    报错:you *might* want to use the less safe log_bin_trust_function_creators variable 解决方法如下: 1. mysql&g ...

  4. jenkins multijob 插件使用

    如果你想要停止对下游/上游工作链定义的混乱 当您想要添加具有层次结构的任务时,按顺序执行或并行执行 安装multijob插件可以让jenkins任务按照分组.顺序执行 jenkins版本:2.80 1 ...

  5. 离线微博工具Open Live Writer(Windows Live Writer)安装过程及server error 500错误解决

    必备条件: .net framework 3.5框架(大概是要求3.5或以上,不确定,好像没有人遇到和这个相关的问题) 2017年7月27日最新官方版0.6.2英文离线客户端网盘下载(官网的安装包无法 ...

  6. Django--20170905--笔记

    一.django的安装 1.先安装python 2.再安装django:pip install django 3.使用虚拟环境:pip install virtualenv 二.项目的创建 1.可以先 ...

  7. Bootstrap插件架构 基于元素自定义属性的布局规则

    w HTML布局规则 Javascript实现步骤 插件调用方法

  8. 虚拟网卡 TUN/TAP 驱动程序设计原理

    简介 虚拟网卡Tun/tap驱动是一个开源项目,支持很多的类UNIX平台,OpenVPN和Vtun都是基于它实现隧道包封装.本文将介绍tun/tap驱动的使用并分析虚拟网卡tun/tap驱动程序在li ...

  9. React中ref的用法

    在React数据流中,父子组件唯一的通信方式是通过props属性:那么如果有些场景需要获取某一个真实的DOM元素来交互,这时候就要用到React的refs属性. 1.可以给DOM元素添加ref属性 c ...

  10. git学习——<二>git配置文件

    一.git所有配置文件 <一>./etc/gitconfig全局配置文件 修改该配置文件,会对所有用户有影响. 使用git config --system来配置该文件 <二>. ...