Skip to content

generator-naive:a Node.js generator based on yeoman!

Notifications You must be signed in to change notification settings

xingbofeng/generator-naive

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

12 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

generator-naive

generator-naive取名为naive的目的是让你明白膜法的力量,以至于你不总在Node.js项目开发过程中显得那么too young, too simple, sometimes naive.

开始

  • npm install -g yo
  • npm install -g generator-naive
  • mkdir myapp && cd myapp
  • yo naive

介绍

generator-naive是一个基于Koa2Node.js服务端MVC脚手架。方便我们快速完成服务端接口开发。

技术栈

  • Koa2
  • MySQL

开始使用

  • 在本地数据库导入示例sql文件,示例sqlsql/too_young_too_simple.sql
  • 更改config/local.js文件,设置本地sql用户名和密码。以保证成功连接数据库。
  • 打开浏览器localhost:3000/test,查看返回结果。

特点

通过函数名注册路由

不需要在通过JSON文件配置化注册路由,将routerhandler合二为一,你只需要更改router目录下的函数即可实现路由注册:

const Router = require('./../framework').Router;
const testService = require('./../service/test_service');
const joi = require('joi');
const schema = require('./../schema');

const PATH = '/test';

class TestRouter extends Router {
  /**
   * getTest -> { "path": `${PATH}/insert`, "method": "GET" }
   * @param  {Object} ctx
   */
  async getTest(ctx) {
    let data = await testService.test();
    console.log(data);
    ctx.ok(data);
  }

  /**
   * getInsert -> { "path": `${PATH}/insert`, "method": "POST" }
   * @param  {Object} ctx
   */
  async postInsert(ctx) {
    let { error } = joi.validate(ctx.request.body, schema.postInsert);
    if (error !== null) {
      return ctx.fail(error.name);
    }
    let { userXuming, userMobile } = ctx.request.body;
    let data = await testService.insert(userXuming, userMobile);
    console.log(data);
    ctx.ok({});
  }
}

// mount router to path: PATH
module.exports = new TestRouter().mount(PATH);

项目启动后,会在控制台打印对应的路由信息如下:

在启动本地数据库之后,可以测试对应的接口详情:

更便捷的SQL

使用generator-naiveSQL操作则更加简单,你不用关心MySQL连接等相关操作,只需要在service层调用你写的dao即可。通过在dao层传入DbUtil.queryEscape的参数即可完成SQL查询。

const BaseClass = require('./../framework').BaseClass;
const DbUtil = require('../util/db_util');

class testDao extends BaseClass {
  constructor(...args) {
    super(...args);
    // regis your table
    this.table = 'user_info';
  }

  getAllData() {
    return DbUtil.queryEscape(`
      SELECT
        *
      FROM
        ${this.table}
    `);
  }

  insertUser(name) {
    return DbUtil.queryEscape(`
      INSERT INTO
        ${this.table}
        (name)
      VALUES
        (:name)
    `, {
      name: name
    });
  }
};

module.exports = new testDao();

日志

generator-naive使用winston来进行日志打印,你只需要在任何需要打印日志的地方引入winston即可完成日志打印。

winston.info('too young too simple, sometimes naive');

参数校验

参数校验的目的是防止SQL注入,项目使用joi来进行参数校验。

  1. 首先需要在schema目录下书写joi校验规则如下:
const joi = require('joi');

module.exports = {
  postInsert: {
    userXuming: joi.number().integer().required(),
    userMobile: joi.number().integer().required(),
  }
}
  1. 然后在每个handler中对入参做对应的参数校验:
let {
  error
} = joi.validate(ctx.request.body, schema.postInsert);
if (error !== null) {
  return ctx.fail(error.name);
}

TODO

  • 日志打印记录完善
  • 防止SQL注入,使用joi校验参数
  • express 支持
  • 配置化yeoman

About

generator-naive:a Node.js generator based on yeoman!

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published