国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

koa搭建node服務

biaoxiaoduan / 410人閱讀

摘要:介紹使用搭建服務并連接返回前端數據項目初始化首先保證你的環境已經就緒創建項目文件夾創建文件夾,在文件夾中右鍵在此處運行命令行運行安裝依賴創建服務在項目文件中創建一個文件在項目跟目錄運行瀏覽器地址輸入返回表示一次對話的上下文包括請求

介紹
使用koa搭建node服務 并連接mongodb返回前端數據
git https://gitee.com/wjj0720/koa...
項目初始化
首先保證你的node環境已經就緒

1、創建項目文件夾

創建文件夾test,在文件夾中shift+右鍵 在此處運行命令行
運行 npm init --y

2、 安裝依賴

npm i koa koa-body koa-static koa-cors

創建服務
// server.js
/*
 * 1、在項目文件中創建一個server.js文件
 * 2、在項目跟目錄運行 node server.js
 * 3、瀏覽器地址輸入 http://127.0.0.1:3001/  返回 your server run seccess
 */
const Koa = require("koa");

const app = new Koa();

// ctx表示一次對話的上下文(包括 HTTP 請求和 HTTP 回復)
app.use(ctx => {
  ctx.body = "your server run seccess"
})

// 監聽3001端口
app.listen(3001, () => {
  console.log("server run on 127.0.0.1:3001");
});
路由使用
/*
 * 1、創建routers文件夾 文件夾下的每個目錄都將是一個訪問的處理
 * 2、routers文件夾 創建一個demo文件夾并擁有index.js
 * 3、在routers文件夾下創建routers.js 用戶集中路由
 * 目錄結構
  -server.js
  -routers
    -routers.js
    -demo
      -index.js
  -router.js
*/

// ----server.js 文件 ----
const Koa = require("koa");
const koaBody = require("koa-body");
const static = require("koa-static")
//const cors = require("koa-cors")

// 引入router創建好的
let router = require("./router.js");

const app = new Koa();

// 解析post請求體
app.use(koaBody());

// 設置跨域 用不用插件都可
app.use(async (ctx, next) => {
  ctx.set("Access-Control-Allow-Origin", "*");
  return next();
});
// app.use(cors())

// 路由掛載
app.use(router.routes());

// 靜態文件處理
app.use(static(path.join(__dirname)))


// 監聽3001端口
app.listen(3001, () => {
  console.log("server run on 127.0.0.1:3001");
});
// -------server.js 結束----------

// ------- router.js -----
let Router = require("koa-router");
let routers = require("./routers/routers.js");

let router = new Router();

routers.forEach(r => {
  router.all(r.path, r.handle)
});

module.exports = router;
//  ------ server.js  結束 ------

// ------ routers/routers.js  start-----
let demo = require("./demo/index.js")
let test = require("./test/index.js")

module.exports = [
  demo,
  test
]
// ------ routers/routers.js  end -----


// ------ routers/demo/index.js  start -----

module.exports = {
  path: "/demo/returnsomething",
  async handle(ctx, next) {
    // 拿到請求輸入
    let params = ctx.request.body;
    
    // 業務邏輯處理
    console.log(params);

    // 返回前端數據
    ctx.body = { res: "SUCCESS", data: "", code: 2000 };
  }
};

// ------ routers/demo/index.js  end -----

// node server 訪問 http://127.0.0.1:3001//demo/returnsomething
mongodb 連接
  /*
   * 1、首先我們在server.js同級目錄創建utils目錄 并創建connect.js 用公共方法的封裝
  */
  // --- utils/connect.js---
  // 安裝依賴 npm i mongodb assert
  const MongoClient = require("mongodb").MongoClient;
  const assert = require("assert");

  // Connection URL mongo服務地址
  const url = "mongodb://localhost:27017";

  // Database Name 確保mongo中有test庫
  const dbName = "test";

  // 公共的連接方法
  const connect = (tableName, callback) => {
    MongoClient.connect(
      url,
      { useNewUrlParser: true },
      function(err, client) {
        assert.equal(null, err);

        const db = client.db(dbName);
        callback(db.collection(tableName));
        client.close();
      }
    );
  };
  // 封裝一個向mongo插入多條數據的方法
  exports.insertMany = (tableName, condition, params) => {
    return new Promise((resolve, reject) => {
      connect(tableName, collection => {
        collection.insertMany(condition, params, (err, result) => {
            if (err) {
              console.log(err);
              reject();
            } else {
              resolve(result);
            }
        });
      });
    });
  };
  // 封裝一個查找數據庫的方法
  exports.findMany = (tableName, condition) => {
    return new Promise((resolve, reject) => {
      connect(
        tableName,
        collection => {
          collection.find(condition).toArray((err, result) => {
            if (err) {
              console.log(err);
              reject();
            } else {
              resolve(result);
            }
          });
        }
      );
    });
  };
  // ------ end -------

  // 在路由中調用
  // ---- routers/dome/index.js ---- 
  const { findMany } = require("../../utils/connect");
  module.exports = {
    path: "/servers/addapi",
    async handle(ctx, next) {
      let params = ctx.request.body;
      
      // 查找數據庫 返回值 參數:表明, 條件
      let res = await findMany("user", {});
      console.log(res);

      ctx.body = { res: "SUCCESS", data: res, code: 2000 };
    }
  };

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/19349.html

相關文章

  • iKcamp團隊制作|基于Koa2搭建Node.js實戰項目教學(含視頻)? 環境準備

    安裝搭建項目的開發環境 視頻地址:https://www.cctalk.com/v/15114357764004 showImg(https://segmentfault.com/img/remote/1460000012470016?w=1214&h=718); 文章 Koa 起手 - 環境準備 由于 koa2 已經開始使用 async/await 等新語法,所以請保證 node 環境在 7.6...

    bang590 評論0 收藏0
  • 從零開始搭建React同構應用(四):搭建Koa Server & 完善SSR

    摘要:從零開始搭建同構應用四搭建完善上一篇我們使用了的方式測試了,這篇文章來講如何在前文的基礎上搭建一個,實現真正意義上的。至此,一個簡單的框架已經搭建完成,剩下的工作就是結合工作需要,在里面添磚加瓦啦。 從零開始搭建React同構應用(四):搭建Koa Server & 完善SSR 上一篇我們使用了CLI的方式測試了SSR,這篇文章來講如何在前文的基礎上搭建一個Koa Server,實現真...

    fizz 評論0 收藏0
  • Koa2微信公眾號開發(一) 本地開發調試環境搭建

    摘要:本篇是該系列的第一篇,本地開發環境搭建以及接入微信。若確認此次請求來自微信服務器,原樣返回參數內容,則接入生效,成為開發者成功,否則接入失敗。 一、簡介 關于微信公眾號的介紹就省略了,自行搜索。注冊過程也不說了。我們會直接注冊測試號來實現代碼。這將會是個全面講解微信公眾號開發的系列教程。本篇是該系列的第一篇,本地開發環境搭建以及接入微信。在開始之前最好去看看開發者文檔微信公眾平臺技術文...

    snifes 評論0 收藏0
  • iKcamp|基于Koa2搭建Node.js實戰(含視頻)? 視圖Nunjucks

    視頻地址:https://www.cctalk.com/v/15114923888328 showImg(https://segmentfault.com/img/remote/1460000012744407?w=1602&h=966); 視圖 Nunjucks 彩虹是上帝和人類立的約,上帝不會再用洪水滅人。 客戶端和服務端之間相互通信,傳遞的數據最終都會展示在視圖中,這時候就需要用到『模板引擎...

    whlong 評論0 收藏0
  • EDU_BOOK 開發總結

    摘要:開發總結整體框架搭建是目前世界最火的框架,無論從性能,還是流程控制上,和它的后宮中間件都是非常好的解決方案。 EDU_BOOK 開發總結 KOA2 + Mongodb 整體框架搭建API Koa2是目前Node.js世界最火的web框架,無論從性能,還是流程控制上,koa 2和它的后宮(中間件)都是非常好的解決方案。本文主要koa 2的文檔解讀和runkoa介紹,讓大家對koa 2有一...

    Yumenokanata 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<