nodejs框架koa常用配置

文章目录

  1. nodejs基础
  2. express
  3. koa
    1. hello world
    2. koa路由
    3. nodemon 监控文件修改
    4. koa中间件
    5. 设置静态目录
    6. 获取请求参数
    7. 使用模板
    8. 跨域配置
    9. 使用vscode调试接口

nodejs基础(参考菜鸟教程的nodejs教程 )

  1. JavaScript语法
  2. 创建服务器模块http
  3. 文件读取模块fs
  4. 路径path
  5. 模块系统 require、module.exports
  6. es6语法(新版本的nodejs除了模块外全部支持

nodejs框架-express

文档地址:http://www.expressjs.com.cn/

nodejs框架-koa

中文文档地址:https://koa.bootcss.com/
node模块仓库地址:https://www.npmjs.com/

koa之hello world

  1. 初始化package.json

    新建目录koademo,执行 npm init,一路回车

  2. 创建一个简单的koa应用(hello world)

    安装koa模块 npm install koa --save
    在项目根目录新建app.js,app.js代码如下:

const Koa = require('koa');
const app = new Koa();

app.use(async ctx => {
  ctx.body = 'Hello World';
});

app.listen(3000);
3. 执行node app.js
4. 用浏览器访问 http://localhost:3000

服务器自动重新部署

我们发现没修改一次代码,都必须重启才能生效,这显然不方便,我们希望修改了文件服务能自动重启.nodemon能实现这样功能

  1. 全局安装npm i nodemon -g
  2. 启动服务的时候用nodemon app.js 代替node app.js

koa路由(一) koa-simple-router

https://www.npmjs.com/package/koa-simple-router
安装 koa-simple-router模块,然后修改上面的app.js代码,变成下面这个样子

const Koa = require('koa')
const router = require('koa-simple-router')
const app = new Koa()
 
app.use(router(_ => {
  _.get('/', (ctx, next) => {
    ctx.body = 'hello world';
  })
  _.post('/path', (ctx, next) => {
 
  })
  // 同时支持get和post请求
  _.all('/login', (ctx, next) => {
    ctx.body = {
        code: 666,
        msg: '登录成功'
    }
  })
  _.all('/regester', (ctx, next) => {
    ctx.body = {
        code: 666,
        msg: '注册成功'
    }
  })
}))

app.listen(3000,()=>{
    console.log('服务已启动,在 http://localhost:3000/');
});

启动服务,用浏览器访问
http://localhost:3000/login
http://localhost:3000/register

为了让代码结构性更好,我们可以把路由这部分单独放在一个文件里

kao路由(二) koa-router(我目前用这个)

  1. 创建新文件夹koa-app作为项目的跟目录

  2. 使用终端(命令提示符或者powershell)进入根目录,初始化package.json

    npm init -y
    
  3. 安装koa和koa-router

    npm i koa koa-router --save-dev
    
  4. 新建app.js,代码如下

    const Koa = require('koa')
    const Router = require('koa-router')
    const app = new Koa()
    const router = new Router();
    
    router.get('/', ctx => {
      ctx.body = 'hello world'
    })
    router.get('/demo1', ctx => {
      ctx.body = 'demo1'
    })
    router.post('/demo1', ctx => {
      ctx.body = 'demo1'
    })
    router.all('/demo2', ctx => {
      ctx.body = 'demo2'
    })
    
    app.use(router.routes());
    
    app.listen(3000, () => {
      console.log('服务已启动,在 http://localhost:3000/');
    });
    
  5. 启动服务,用浏览器访接口即可

  6. 封装router,我们一般会把router单独放到一个文件,然后倒入到app.js使用

    const Router = require('koa-router')
    const router = new Router();
    
    router.all('/', ctx => {
      ctx.body = 'hello world'
    })
    router.all('/add', ctx => {
      ctx.body = 'add'
    })
    router.all('/getList', ctx => {
      ctx.body = 'demo1'
    })
    router.all('/del', ctx => {
      ctx.body = 'del'
    })
    router.all('/edit', ctx => {
      ctx.body = 'edit'
    })
    
    module.exports = router;
    

    app.js里的代码变成这样

    const Koa = require('koa')
    const app = new Koa()
    const router = require('./router');
    
    app.use(router.routes());
    
    app.listen(3000, () => {
      console.log('服务已启动,在 http://localhost:3000/');
    });
    
  7. 配置父路由

    const Router = require('koa-router');
    
    const router = new Router({
      // 配置前缀
      prefix: '/city'
    })
    
    router.get('/add',(ctx,next)=> {
     ctx.body = '增加';
    })
    
    router.get('/del',ctx=> {
     ctx.body = '删除';
    })
    router.get('/edit',ctx=> {
     ctx.body = '编辑';
    })
    router.get('/list',ctx=> {
     ctx.body = '查询';
    })
      
    module.exports = router;
    

    浏览器访问http://localhost:3000/city/add(或其他) 即可

koa中间件

一个请求从发出到返回数据,如果我们想在这个过程里做一些统一的操作,可以使用中间件来完成.

  1. 中间件是个函数

  2. 使用中间件的方式, app.use(中间件)

    app.use((ctx, next) => {
     // 在ctx上放入username,后面的所有请求的ctx里都会有username这个变量
      ctx.username = '我是老胡';
      // 处理完之后放行,不使用next()的话,程序会被挂起来不动了
      next();  // 在vue路由守卫里曾使用过next
    })
    
  3. 中间件有顺序

获取请求参数

给刚才的demo.html添加axios用来发送请求,代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
  <script src="https://cdn.bootcss.com/axios/0.19.0-beta.1/axios.js"></script>
</head>
<body>
  <h3>
    测试koa静态资源目录
  </h3>

  <script>
    let url = 'http://localhost:3000/add';
    let data = {
      params: {
        username: 'laohu',
        phone: 13800000000
      }
    }
    axios.get(url, data).then(res => {
      console.log(res);
    })

  </script>
</body>
</html>

  1. 获取get请求参数
    在router.js的add接口里加入如下代码
router.all('/add', ctx => {
  // 获取get请求参数
  const username = ctx.query.username;
  const phone = ctx.query.phone;
  // 把拿到的数据放入ctx.body
  ctx.body = {
    module: 'add',
    username,
    phone
  }
})
  1. 获取post请求
    获取post请求需要使用koa-body模块
    安装koa-body npm i koa-body --save

    npm i koa-body --save
    

    在app.js里加入如下代码:

const koaBody = require('koa-body');
app.use(koaBody());

获取post请求参数的代码如下

ctx.request.body.xxx
  1. 使用中间件封装请求参数

    // 把get请求参数和post请求参数都放入params对象
    app.use((ctx, next) => {
      ctx.params = {
        ...ctx.query,
        ...ctx.request.body
      }
      next();
    });
    

设置静态目录

  1. 在目录中创建目录static,在public下创建文件demo.html,访问http://localhost:3000/public/demo.html是无法访问得到,因为我们还没有设置静态资源目录,设置静态资源目录要用到koa-static模块

  2. 安装koa-static

    npm i koa-static --save-dev
    
  3. 在app.j是里加入如下代码

const koaStatic = require('koa-static');
app.use(koaStatic(__dirname + '/public'));

再来访问 http://localhost:3000/demo.html 就可以访问了,ps: 路径不用加public

使用模板

一般请求一个接口返回的是一坨数据,然而有时候我们希望返回的是一个html网页或者一段html代码(上周分享的服务器渲染)
我们试用koa-swig模块来向前端返回一个html

  1. 安装koa-swig
npm i koa-view --save-dev

在根目录创建views目录,在views目录下创建tpl.html,代码如下

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
</head>

<body>
  <h3><%=title %></h3>
  <ul>
    <%
      list.forEach(item=>{
    %>
    <li><%=item.username %> => <%=item.age %></li>
    <%
    })
    %>
  </ul>
</body>

</html>
  1. 在app.js添加如下代码:
const views = require("koa-views");
app.use(views(path.join(__dirname, "views"), {
  map: {
    html: 'underscore'
  }
}));
   
// 在路由中使用   
router.all('/', async ctx => {
  const list = [{
      username: '约书亚',
      age: 22
    },
    {
      username: '亚伯拉罕',
      age: 100
    },
    {
      username: '挪亚',
      age: 500
    }
  ]

  await ctx.render('tpl', {
    title: 'kao-框架实战',
    list
  });
})
  1. 访问 http://localhost:3000,就可以看到一个html页面

ps: 要访问一个接口,吐出一个页面你还可以直接在js里使用反引号``拼接模板,当然也可以使用vue来渲染

vue服务器渲染

  1. 安装vue和vue服务器渲染插件

    npm install vue vue-server-renderer --save
    
  2. 创建渲染vue实例

    // 第 1 步:创建一个 Vue 实例
    const Vue = require('vue')
    const app = new Vue({
      template: `<div>Hello World</div>`
    })
    // 第 2 步:创建一个 renderer
    const renderer = require('vue-server-renderer').createRenderer();
    
    // 第 3 步:将 Vue 实例渲染为 HTML
    renderer.renderToString(app, (err, html) => {
      if (err) throw err
      console.log(html)
      // => <div data-server-rendered="true">Hello World</div>
    })
    
    

跨域配置

自己编写一个中间件即可,代码如下

app.use((ctx, next) => {
  ctx.set("Access-Control-Allow-Origin", "*");
  ctx.set("Access-Control-Allow-Methods", "PUT, POST, GET, DELETE, OPTIONS");
  // 请求头设置
  ctx.set(
    "Access-Control-Allow-Headers",
    `Content-Type, Content-Length, Authorization, Accept, X-Requested-With , yourHeaderFeild,x-token,sessionToken,token`
  );
  if (ctx.method == "OPTIONS") {
    ctx.body = 200;
  } else {
    next();
  }
})

访问刚才的demo.html文件, http://localhost:3000/demo.html,你会发现你的请求的响应头上添加了Access-Control-Allow-Origin: *,说明服务器跨域设置已经成功了.

demo地址
(未完待续)
相关文章:
mongoose常用操作

egg+mongodb 配置
koa+mogodb创建简单的增删改查项目(待更新)

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

推荐阅读更多精彩内容