1、koa-router环境配置
npm i @koa/router --save
const Koa = require('koa');
var Router= require('@koa/router')(); //注意:引入的方式
const app = new Koa();
var router = new Router();
//配置中间件
//ctx 上下文context ,包含了request和response等信息
//中间件:表示访问所有路由都会触发
app.use(async(ctx, next)=>{
console.log("执行")
next();
})
// 配置路由
router.get('/', async(ctx)=>{
ctx.body="你好 我是首页"
})
router.get('/news', async(ctx)=>{
ctx.body="你好 我是新闻"
});
app
.use(router.routes())//启动路由
.use(router.allowedMethods()); // 这是官方文档的推荐用法,我们可以看到router.allowedMethods()用在了路由匹配router.routes()之后,所以在当所有路由中间件最后调用.此时根据ctx.status设置response响应头
app.listen(3000,()=>{
console.log('starting at port 3000');
})
这样接口就完成了,效果如下
http方法
1、get方法和delete都通过ctx.query
2、post方法和put方法则需要通过ctx.request.body
且需要借助中间件koa-bodyparser
-
koa-bodyparser中间件可以把koa2上下文的formData数据解析到ctx.request.body中
1】安装koa-bodyparser
npm install --save koa-bodyparser
2】引用
const bodyParser = require('koa-bodyparser')
3】配置中间件
app.use(bodyParser());
RESTFul Api Http请求类型 get post put delete
router.get("/user", async (ctx)=>{ ctx.body = ctx.query }) router.post("/add", async (ctx)=>{ console.log(ctx.request.body) // ctx.body = "接收表单传来的数据" ctx.body =ctx.request.body }) router.put("/user/edit", async (ctx)=>{ ctx.body =ctx.request.body }) router.delete("/user/delete", async (ctx)=>{ ctx.body =ctx.query })