json接口的开发是日常最多的开发需求。分三步走,router层定义路由。将路由映射为controller,controller控制器层调用service业务逻辑层,来完成业务逻辑。node
module.exports = (app) => { const Router = app.router Router.get("/api/users", app.controller.user.getUsers) }
// app/controller/user.js const {Controller} = require('egg') class User extends Controller { async getUsers() { const {pageNum, pageSize} = ctx.query ctx.body = this.ctx.service.userService.queryUser(pageNum, pageSize) } } module.exports = User
// app/service/user_service.js const {Service} = requrie('egg') class UserService extends Service { async queryUser(pageNum, pageSize) { // 具体的业务逻辑,分页参数处理。数据库查询等。返回User列表 } } module.exports = UserService
上面三步能够完成一个基本的http+json接口的开发。下面是须要注意的几点数据库
如/api/users?pageNum=1&pageSize=10
中的pageNum
和pageSize
json
经过ctx.query
能够获取查询字符串对象参数,上面的例子中能够拿到对象segmentfault
const { pageNum, pageSize } = ctx.query
经过ctx.request.body
获取请求对象api
const {userName} = ctx.request.body