引入npm 第三方mongoose包连接mongoDb本地数据库todolist
const mongoose = require('mongoose');
mongoose.connect('mongodb://localhost:27017/todolist',{
useNewUrlParser: true ,
useUnifiedTopology: true
});
//导出数据库连接文件
module.exports=mongoose; //导入连接数据库文件
const mongoose=require('./connect')
const Schema = mongoose.Schema;
这里直接用mongoose schema 建模
const userSchema=new Schema({
name:{type:String},
password:{type:String}
}) const todoContentSchema=new Schema({
data:{type:String},
isV:{type:Number,default:1} ,
com:{type:String,default:1},
th:{type:String,default:0} }) //实例化模型
const todoContent = mongoose.model('todoContent', todoContentSchema);
const User = mongoose.model('User', userSchema);
// const login= mongoose.model('login', userShema);
// const Cat = mongoose.model('Cat', catSchema);
module.exports={
User,todoContent
} //后台代码 用node js express 框架
const express=require('express')
const bodyParse=require('body-parser')
//这里用cors第三方包做了跨域处理
const cors=require('cors')
//导入连接数据库的文件
const { User,todoContent}=require('./model/index')
//导入token 文件
const {verifyToken,createToken}=require('./token') const app=express()
app.use(express.json())
app.use(cors())
// app.use(express.urlencoded({extended:false}))
// var urlencodedParser = bodyParse.urlencoded({ extended: false })
const PORT=8220
//注册用户接口
app.post("/regist",(req,res)=>{
//console.log(req.body);
const UserDate = req.body;
const name=req.body.name;
const password=req.body.password;
const user=new User(UserDate)
user.save().then((data)=>{
console.log(data);
res.send({
status:200,
msg:"添加数据成功",
data:{
name,
password
}
})
})
}) //登录用户接口
app.post('/login',(req,res)=>{
const {name,password}=req.body;
User.findOne({name}).then((UserDate)=>{
// console.log(UserDate);
if(password===UserDate.password){
const token=createToken(UserDate)
res.send({
status:300,
msg:"登录成功",
data:{
name,
password,
token
}
})
}else{
res.send({
status:303,
msg:"用户名或者密码错误" })
}
}) })
//添加数据接口
app.post('/todo',(req,res)=>{
const data=req.body;
console.log(data);
// res.send(data)
const todolist=new todoContent(data)
todolist.save().then((data)=>{
res.send({
status:203,
msg:"添加数据成功",
data:{
data
}
})
})
})
//修改数据接口
app.patch("/todo/:id", (req, res) => {
console.log(req.params.id);
console.log(req.body);
todoContent.updateOne({ _id: req.params.id }, req.body).then((updata) => {
todoContent.find({ _id: req.params.id }).then((data) => {
res.send({
status: 400,
msg: "更新成功",
data
});
});
});
})
//删除数据接口
app.delete("/todo/:id", (req, res) => {
const id = req.params.id;
todoContent.updateOne({ _id: id }, { com: 0 }).then((data) => {
res.send({
status: 500,
msg: "删除成功",
data,
});
});
});
//拿到当前用户名
app.get("/todo",vv,(req,res)=>{
//return res.send(req.body.usertoken)
const id = req.params.id;
const data=req.body.usertoken.data
console.log(data);
console.log(id)
res.send({
status:410,
msg:"获取用户名成功",
data:{
user: req.body.usertoken.data
}
})
})
//拿到所有代办事项数据
app.get("/data",(req,res)=>{
todoContent.find({com:"1"}).then((data)=>{
res.send({
status:306,
msg:"获取数据成功",
data:{
data
}
})
}) })
//完成数据 app.put('/data/:id',(req,res)=>{
const id = req.params.id;
todoContent.updateOne({_id:id}, {$set:{th:1}} ).then((data)=>{
res.send({
status:400,
msg:"更新成功"
}) } ) }) //手写中间件验证token
function vv(req, res, next) {
const token = req.headers.authorization.split(" ")[1];
const usertoken = verifyToken(token);
// console.log(usertoken);
if(!usertoken){
res.sendStatus(401)
}else{
req.body.usertoken=usertoken;
next()
}
} app.listen(PORT,()=>{
console.log(`服务运行在${PORT}`);
})

简单做了一个代办事项列表系统 ,增删改查。 前台页面用 jquery 后台用nodejs ,数据库用的是mongdoDB 。的更多相关文章

  1. 列表的初识,列表的索引切片,列表的增删改查,列表的嵌套,元组的初识,range

    1 内容总览 列表的初识 列表的索引切片 列表的增删改查 列表的嵌套 元组的初识(了解) 元组的简单应用(了解) range 2 具体内容 列表的初识 why: str: 存储少量的数据.切片出来全都 ...

  2. Python列表的增删改查排嵌套特殊输出格式

    Python列表的增删改查排嵌套特殊输出格式 一.列表的样子: a = ['q' , 'w' , 'e ', 'r','t'] a为列表名,[ ]为列表内容,' '为列表内的元素,'q'为a[0] 二 ...

  3. Python(二)列表的增删改查

    一,列表的增删改查 列表中增加元素: 1,从列表的末尾增加一个元素:append("") 2,从列表中插入一个元素:insert(下标位置,插入的元素) 合并列表: 1,name. ...

  4. python列表的增删改查和嵌套

    列表 python常用的数据类型 可承载任意的数据类型 列表是有序的,可索引.切片(步长) 列表的创建 list1 = [1, 2, 'whll'] #1. list2 = list() #2. #3 ...

  5. day5 列表的增删改查

    1,列表的增删改查,其他操作.2,元祖.3,列表的嵌套操作.4,开一点dict. 昨日内容回顾: 字符串的方法:1,find通过元素找索引,可切片,找不到返回-12,index,找不到报错.3,spl ...

  6. ABP教程(四)- 开始一个简单的任务管理系统 - 实现UI端的增删改查

    接上一篇:ABP教程(三)- 开始一个简单的任务管理系统 – 后端编码 1.实现UI端的增删改查 1.1添加增删改查代码 打开SimpleTaskSystem.sln解决方案,添加一个“包含视图的MV ...

  7. 004_Python的列表切片,增删改查,常用操作方法,元组,range,join

    列表 列表是Python中的基础数据类型之一,它是以[]括起来,每个元素以逗号隔开,而且他里面可以存放各种数据类型比如: li = ['kevin',123,True,(1,2,3,'wusir'), ...

  8. 基于SpringBoot开发一个Restful服务,实现增删改查功能

    前言 在去年的时候,在各种渠道中略微的了解了SpringBoot,在开发web项目的时候是如何的方便.快捷.但是当时并没有认真的去学习下,毕竟感觉自己在Struts和SpringMVC都用得不太熟练. ...

  9. 元组,列表的增删改查, for,range 循环

    1. list(增删改查) 列表可以装大量的数据. 不限制数据类型. 表示方式:[] 方括号中的每一项用逗号隔开 列表和字符串一样.也有索引和切片 常用的功能: 1. 增: append() 2. 删 ...

随机推荐

  1. 团队作业4-Day6

    团队作业4-Day6 项目git地址 1. 站立式会议 2. 项目燃尽图 3. 适当的项目截图 4. 代码/文档签入记录(部分) 5. 每人每日总结 吴梓华:今日修复了图片显示BUG,补充了排位模式出 ...

  2. asp.net在线人数限制

    1.网站启动初始化在线人数变量 Application["WebsiteCount"] = 0; 2.新的会话进来 只有在全新的会话进来的时候,该方法才会执行.可以过滤掉某些不需要 ...

  3. STL——容器(Set & multiset)编译器提供的16种构造(挖个坑)

    Set & multiset 在vs2019编译器中提供了16种构造方法 1.默认的无参构造 2.比较容器内容,key_comp()函数返回一个比较key的函数. 3.使用迭代器的区间拷贝,拷 ...

  4. docker 批量删除已经停止的容器

    长期操作导致大量的容器堆积,如何对这些没有用的容器进行批量删除: 命令如下 : Docker rm `docker ps -a |awk '{print $1}' | grep [0-9a-z]`

  5. Elastic Search 学习之路(二)——inverted index(反向索引)

    这是篇翻译文,图画的挺有意思. Elastic使用非常特殊的数据结构,称作反向索引.反向索引中,包括了一组document中出现的唯一的单词,和对应的单词,所出现的位置.反向索引是在ES中,docum ...

  6. 揭开DRF序列化技术的神秘面纱

    在RESTful API中,接口返回的是JSON,JSON的内容对应的是数据库中的数据,DRF是通过序列化(Serialization)的技术,把数据模型转换为JSON的,反之,叫做反序列化(dese ...

  7. css 02-CSS属性:背景属性

    02-CSS属性:背景属性 #background 的常见背景属性 css2.1 中,常见的背景属性有以下几种:(经常用到,要记住) background-color:#ff99ff; 设置元素的背景 ...

  8. pandas的学习4-处理丢失数据

    import pandas as pd import numpy as np ''' 有时候我们导入或处理数据, 会产生一些空的或者是 NaN 数据,如何删除或者是填补这些 NaN 数据就是我们今天所 ...

  9. B. Navigation System【CF 1320】

    传送门 题目:简单理解就是,我们需要开车从s点到t点.车上有一个导航,如果当前点为x,则导航会自动为你提供一条从x到t的最短的路线(如果有多条,则随机选一条),每走到下一个点则会实时更新最短路线,当然 ...

  10. 悉数 Python 函数传参的语法糖

    TIOBE排行榜是程序开发语言的流行使用程度的有效指标,对世界范围内开发语言的走势具有重要参考意义.随着数据挖掘.机器学习和人工智能相关概念的风行,Python一举收获2018年年度语言,这也是Pyt ...