1. 程式人生 > >koa2 簡單入門和 mongoose 使用

koa2 簡單入門和 mongoose 使用

1 構建專案

1.1 安裝koa-generator

$ npm install -g koa-generator

1.2 使用koa-generator生成koa2專案

$ koa2  -e project(專案名稱)   (-e 代表使用模板引擎ejs)

1.3 進入專案

$ cd project 
$ npm install

1.4 啟動專案,預設埠號是3000

$  DEBUG=koa2-learn:* npm start        (該方法在修改檔案時需要重新啟動服務。不建議使用)
$  npm  run dev  (該方法可以直接重新整理服務)

1.5 專案目錄

image

其中:dbs為後來建立的操作mongo的檔案目錄;middleware為後來建立的自定義中介軟體目錄

2. 中介軟體

koa是從第一個中介軟體開始執行,遇到 await next() 進入下一個中介軟體,一直執行到最後一箇中間件,在逆序,執行上一個中介軟體,一直到第一個中介軟體執行結束才發出響應。

2.1 自定義中介軟體

建立資料夾middleware存放各種自定義中介軟體;
建立檔案 koa-pv.js:

// 自定義中介軟體 koa-pv

function pv (ctx) {
    global.console.log('當前路由', ctx.path) // 列印當前路由,node中全域性不能用window,需要用global代替
}

module.exports = function () {
    return async function(ctx, next) {
        pv(ctx)
        await next() // 每個中介軟體都必須有這一句,用以執行下一個中介軟體
    }
}

然後,在app.js中引入中介軟體

const pv = require('./middleware/koa-pv')

app.use(pv())

3. mongoose的使用

3.1 判斷是否安裝了mongo:

$ which mongod

3.2 執行 MongoDB

$ sudo mongod  

<!--

首先建立一個數據庫儲存目錄 /data/db:

sudo mkdir -p /data/db

啟動 mongodb,預設資料庫目錄即為 /data/db

參考:http://www.runoob.com/mongodb/mongodb-osx-install.html

如果已經有程序27017,需要先停止:

停止程序:
    lsof -i :27017
    kill  -9 3243
-->

3.3 配置mongoose

在資料夾dbs中建立檔案 config.js:

// 配置mongo 地址
module.exports =  {
    dbs: 'mongodb://127.0.0.1:27017/dbs'
}

3.4 建立資料表

在檔案dbs 中建立資料夾models 用來存放不同的資料表。
建立檔案person.js, 檔名person即為資料表名稱。

person.js:

const mongoose = require('mongoose')

// 建立資料表模型,該檔案的名字,即person,就是資料表的名字
// 下面給 person 表宣告兩個欄位name和age

let personSchema = new mongoose.Schema({
    name: String,
    age: Number
})

// 通過建 model 給 person 賦予增刪改查等讀寫的功能
module.exports = mongoose.model('Person', personSchema)

3.5 連線koa2和mongoose

// 一、引入mongoose
const mongoose = require('mongoose')
const dbConfig = require('./dbs/config')


// 二、 連線資料庫的服務
mongoose.connect(dbConfig.dbs, {
  useNewUrlParser: true
})

3.6 通過mongoose進行資料的增刪改查

進入檔案 routes/uses.js:

const router = require('koa-router')()
// 引入mongo模型
const Person = require('../dbs/models/person')

router.prefix('/users')

router.get('/', function (ctx, next) {
  ctx.body = 'this is a users response!'
})

router.get('/bar', function (ctx, next) {
  ctx.body = 'this is a users/bar response'
})


/**
 *  一、 增加 內容 向person資料模型中
 *
 *     可以通過命令列執行:curl -d 'name=cck&age=27' http://localhost:3000/users/addPerson
 *     若返回: {
                "code": 0
              }
       證明新增資料成功。

       注意: save()方法是model自帶的寫入資料的方法, 通過例項 person 寫入
 */

router.post('/addPerson', async function (ctx) {
  // 建立例項
  const person = new Person({
    name: ctx.request.body.name,
    age: ctx.request.body.age
  })

  let code = 0 // 狀態碼

  try {
    await person.save()
    code = 0
  } catch(e) {
    code = -1
  }

  // 返回狀態(成功為0, 錯誤為-1)
  ctx.body = {
    code
  }
})

/**
 *  二、 讀取 內容 從person資料模型中
 *      命令列中輸入:curl -d 'name=cck' http://localhost:3000/users/getPerson
 *      返回:{
                "code": 0,
                "result": {
                  "_id": "5beb91bcd6e7060ffcca6a46",
                  "name": "cck",
                  "age": 27,
                  "__v": 0
                },
                "results": [
                  {
                    "_id": "5beb91bcd6e7060ffcca6a46",
                    "name": "cck",
                    "age": 27,
                    "__v": 0
                  }
                ]
              }
 *
 *    注意: findOne()和find()方法是model自帶的讀取資料的方法, 注意:這裡直接通過模型 Person 寫入 !!!
 *          findOne() 只是找到一條符合條件的內容
 *          find() 可以找到整個符合條件的集合(陣列)
 */

router.post('/getPerson', async function (ctx) {
  const result = await Person.findOne({
    name: ctx.request.body.name
  })

  const results = await Person.find({
    name: ctx.request.body.name
  })

  // 這裡沒有考慮異常,直接返回了結果
  ctx.body = {
    code: 0,
    result,
    results
  }
})

/**
 *  三、 修改 內容 從person資料模型中
 *      命令列中輸入:curl -d 'name=wy&age=19' http://localhost:3000/users/updatePerson
 *      返回:{
                "code": 0,
              }
 *
 *    注意: where()和update()方法是model自帶的讀取資料的方法, 注意:這裡直接通過模型 Person 寫入 !!!
 *          where() 找到符合條件的內容
 *          update() 修改該內容
 */

router.post('/updatePerson', async function (ctx) {
  // 找到符合條件的name,並修改其age
  const result = await Person.where({
    name: ctx.request.body.name
  }).update({
    age: ctx.request.body.age
  })

  // 這裡沒有考慮異常,直接返回了結果
  ctx.body = {
    code: 0
  }
})

/**
 *  四、 刪除 內容 從person資料模型中
 *
 *    注意: where()和update()方法是model自帶的讀取資料的方法, 注意:這裡直接通過模型 Person 寫入 !!!
 *          where() 找到符合條件的內容
 *          remove() 刪除該內容
 */

router.post('/removePerson', async function (ctx) {
  // 找到符合條件的name,並修改其age
  const result = await Person.where({
    name: ctx.request.body.name
  }).remove()

  // 這裡沒有考慮異常,直接返回了結果
  ctx.body = {
    code: 0
  }
})

module.exports = router