使用express框架开发API。无数据库
- mkdir demo2-express-api
- cd demo2-express-api
- npm init -y
- npm install express
- 新建app.js
const express = require('express')
const app = express()
app.get('/',(req,res) => {
res.send('hello')
})
app.listen(3000,() => {
console.log('http://localhost:3000');
})
- 使用命令nodemon app.js (nodemon需安装 安装后不用重启服务器)
1.get:展示数据
2.post:增加新资源 通常带有请求体 需要解析json格式 所以使用中间件(中间件:扩展express功能,在请求/响应前做特定操作
)
app.post('/',(req,res) => {
console.log('收到请求体:',req.body);
res.status(201).send() //201代表资源创建成功
})
使用postman测试 选择raw 及 json 。填写json格式的数据
3.put:更新资源(一般根据数据库id更新)
app.put('/:id',(req,res) => {
console.log('收到请求参数:',req.params.id);
console.log('收到请求体:',req.body);
res.status(200).send()
})
4.delete:删除资源
app.delete('/:id',(req,res) => {
console.log('收到请求参数:',req.params.id);
res.status(204).send()
})
模拟子路由
以文章post为例,在根目录下创建文件夹routes>post.js
app.js
const post = require('./routes/post')
app.use('/post',post)
post.js
const express = require('express')
const router = express.Router();
router.get('/',(req,res) => {
res.send({id:1,title:'第一篇文章'})
})
router.post('/',(req,res) => {
console.log('保存文章',req.body);
res.status(201).send({id:2,...req.body})
})
router.put('/:id',(req,res) => {
console.log('收到请求参数,文章id为:',req.params.id);
console.log('收到请求体,新的文章内容为:',req.body);
res.status(200).send()
})
router.delete('/:id',(req,res) => {
console.log('收到请求参数,文章id为:',req.params.id);
res.status(204).send()
})
module.exports = router