用koa2+mysql搭建后端服务器

前言

    近段时间在学习react,想做个小项目,奈何没有后端,故自己上网查找一些资料,并通过自己的理解搭建后端服务器。在此特别感谢 http://www.imooc.com/article/80671 给我的支持。下面是个人一些见解:

一  安装环境要求

    node版本需求:必须在 7.6.0 以上,版本低的请到 node官网 下载最新版本。

二  创建项目

    1、使用 koa-generator 搭建项目:  通过win+R进入管理窗口,输入 npm install koa-generator -g 进行全局安装koa-generator

     注意: 由于npm太慢,建议使用淘宝npm镜像:

永久使用: npm config set registry https://registry.npm.taobao.org

   2、 进入相应的目录下,使用 koa-generator 生成koa2项目 命令: koa2 “项目名称”

   3、 进行项目,然后通过 npm install 安装依赖

   4、输入 npm start 启动服务。

打开浏览器,在地址框输入 http://localhost:3000/,看到“Hello Koa 2!” 说明启动成功了。

注意:由于react脚手架搭建出来的端口也是3000,可能会造成端口被占用情况。可以在/bin/www下修改端口。修改完之后重启项目。

三  安装mysql数据库

   到官网 https://www.mysql.com/downloads 下载对应版本,并安装数据库。安装教程可参考:https://blog.csdn.net/qq_37350706/article/details/81707862

四  安装Sequelize

    Sequelize类是引用sequlize模块后获取一个顶级对象,我们通过它来创建sequlize实例,也可以通过该对象来获取模内其它对象的引用,如:Utils工具类、Transaction事务类等。创建实例后,可以通过实例来创建或定义Model(模型)、执行查询、同步数据库结构等操作。

安装sequelize

    npm install sequelize --save

安装 mysql , mysql2模块

   npm install mysql mysql2 --save

五 使用 Sequelize 初始化连接池

   在根目录创建 config/db.js 文件:(注意: 所连接的数据库必须存在,若不存在先创建数据库,创建数据库命令: CREATE DATABASE blogs DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

sequelize选项配置

六  梳理项目结构

项目基本结构目录

七  创建数据表模型

    新建 schema 文件夹,该文件夹用来创建数据库的模型。举个例子: 创建一个文章的数据模型。在schema文件夹下创建一个article.js文件:

创建article模型

八  应用数据表模型

    创建modules/article.js 用于schema文件夹内的模型使用。主要代码为:

     const db = require('../config/db')         // 引入配置文件

     const Sequelize = db.sequelize;

     const Article = Sequelize.import("../schema/article");     // 引入文章数据表模型文件

     Article.sync({ force: false });    // 自动创建表 (加force:true, 会先删掉表后再建表)

源代码如下:

article model使用

九  数据表控制器

    主要负责功能处理部分: 收集前端所传过来的数据,将数据保存到数据库,将结果返回给前端。

article 控制部分

十  路由

    在根目录下创建router/index.js 这文件可以理解为向外暴露API接口,实际上就是路由的访问,然后通过控制器=>模型处理=>返回数据

路由文件

十一  配置跨域

    引入 koa-cors ,安装依赖后,在app.js中加入下面代码:

const cors = require('koa-cors')

app.use(cors())

十二  服务启动

在cmd窗口下输入 npm start 启动项目,当看到 SHOW INDEX FROM 'article' 表示数据库创建且连接成功。

启动项目成功

十三  接口测试

使用 postman 在地址栏输入url地址,并输入相关参数即可完成测试。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 200,783评论 5 472
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,396评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 147,834评论 0 333
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,036评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,035评论 5 362
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,242评论 1 278
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,727评论 3 393
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,376评论 0 255
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,508评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,415评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,463评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,140评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,734评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,809评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,028评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,521评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,119评论 2 341