app.js
const express=require('express')
const fs=require('fs')
const {getDb,saveDb} =require('./db')
const app=express()
app.use(express.json())
app.use(express.urlencoded({extended:false}))
app.get("/todos",async (req,res)=>{
try {
const db=await getDb()
res.status(200).json(db.todos)
}catch (err){
res.status(500).json({
error:err.message
})
}
})
app.get("/todos/:id",async (req,res)=>{
try {
const db=await getDb()
const todo=db.todos.find(v=>v.id===parseInt(req.params.id))
console.log(todo)
if(!todo){
return res.status(404).end()
}
res.status(200).json(todo)
}catch (err){
res.status(500).json({
error:err.message
})
}
})
app.post("/todos",async (req,res)=>{
try {
const todo=req.body
if(!todo.title){
return res.status(422).json({
error:'title字段必须传入'
})
}
const db=await getDb()
const lastTodo=db.todos[db.todos.length-1]
todo.id=lastTodo?lastTodo.id+1:1,
db.todos.push(todo)
await saveDb(db)
res.status(200).json(todo)
}catch (err){
res.status(500).json({
error:err.message
})
}
})
app.patch("/todos/:id",async (req,res)=>{
try{
const todo=req.body
const db=await getDb()
const ret=db.todos.find(v=>v.id===parseInt(req.params.id))
if(!ret){
res.status(404).end()
}
Object.assign(ret,todo)
await saveDb(db)
res.status(200).json(ret)
}catch (err){
res.status(500).json({
error:err.message
})
}
})
app.delete("/todos/:id",async (req,res)=>{
try{
const todoId=parseInt(req.params.id)
const db=await getDb()
const index=db.todos.findIndex(v=>v.id===todoId)
if(index===-1){
return res.status(404).end()
}
db.todos.splice(index,1)
await saveDb(db)
res.status(200).send("删除成功")
}catch (err){
}
})
app.listen(3000,()=>{
console.log("服务启动:http://localhost:3000/")
})
db.js
const fs=require('fs')
const {promisify}=require('util')
const readFile=promisify(fs.readFile)
const writeFile=promisify(fs.writeFile)
const path=require('path')
const dbPath=path.join(__dirname,'./db.json')
exports.getDb= async()=>{
const data=await readFile(dbPath,'utf-8')
return JSON.parse(data)
}
exports.saveDb=async db=>{
const data= JSON.stringify(db,null,' ')
await writeFile(dbPath,data)
}
db.json
{
"todos": [
{
"title": "intrwins",
"id": 4
},
{
"title": "intrwins",
"id": 5
},
{
"title": "intrwins",
"id": 6
},
{
"title": "intrwins",
"age": 35,
"id": 7
}
],
"users": []
}