简单做了一个代办事项列表系统 ,增删改查。 前台页面用 jquery 后台用nodejs ,数据库用的是mongdoDB 。
引入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 。的更多相关文章
- 列表的初识,列表的索引切片,列表的增删改查,列表的嵌套,元组的初识,range
1 内容总览 列表的初识 列表的索引切片 列表的增删改查 列表的嵌套 元组的初识(了解) 元组的简单应用(了解) range 2 具体内容 列表的初识 why: str: 存储少量的数据.切片出来全都 ...
- Python列表的增删改查排嵌套特殊输出格式
Python列表的增删改查排嵌套特殊输出格式 一.列表的样子: a = ['q' , 'w' , 'e ', 'r','t'] a为列表名,[ ]为列表内容,' '为列表内的元素,'q'为a[0] 二 ...
- Python(二)列表的增删改查
一,列表的增删改查 列表中增加元素: 1,从列表的末尾增加一个元素:append("") 2,从列表中插入一个元素:insert(下标位置,插入的元素) 合并列表: 1,name. ...
- python列表的增删改查和嵌套
列表 python常用的数据类型 可承载任意的数据类型 列表是有序的,可索引.切片(步长) 列表的创建 list1 = [1, 2, 'whll'] #1. list2 = list() #2. #3 ...
- day5 列表的增删改查
1,列表的增删改查,其他操作.2,元祖.3,列表的嵌套操作.4,开一点dict. 昨日内容回顾: 字符串的方法:1,find通过元素找索引,可切片,找不到返回-12,index,找不到报错.3,spl ...
- ABP教程(四)- 开始一个简单的任务管理系统 - 实现UI端的增删改查
接上一篇:ABP教程(三)- 开始一个简单的任务管理系统 – 后端编码 1.实现UI端的增删改查 1.1添加增删改查代码 打开SimpleTaskSystem.sln解决方案,添加一个“包含视图的MV ...
- 004_Python的列表切片,增删改查,常用操作方法,元组,range,join
列表 列表是Python中的基础数据类型之一,它是以[]括起来,每个元素以逗号隔开,而且他里面可以存放各种数据类型比如: li = ['kevin',123,True,(1,2,3,'wusir'), ...
- 基于SpringBoot开发一个Restful服务,实现增删改查功能
前言 在去年的时候,在各种渠道中略微的了解了SpringBoot,在开发web项目的时候是如何的方便.快捷.但是当时并没有认真的去学习下,毕竟感觉自己在Struts和SpringMVC都用得不太熟练. ...
- 元组,列表的增删改查, for,range 循环
1. list(增删改查) 列表可以装大量的数据. 不限制数据类型. 表示方式:[] 方括号中的每一项用逗号隔开 列表和字符串一样.也有索引和切片 常用的功能: 1. 增: append() 2. 删 ...
随机推荐
- WEB安全漏洞挖掘向入坑指北
这个指北不会给出太多的网站和方向建议,因为博主相信读者能够从一个点从而了解全局,初期的时候就丢一大堆安全网址导航只会浇灭人的热情,而且我也不适合传道授业解惑hhh 安全论坛: 先知社区 freebuf ...
- C语言网络编程(Linux && Windows)(1)
和朋友一起做课程设计,同时学习C语言的网络编程,以前写的都是python网络编程,但python很多的库都是封装好的,大部分人在使用的时候不会去了解底层的实现,这样对长远的学习不太好,也改正自己这方面 ...
- 团队作业3_需求改进&系统设计
一.需求&原型改进 1.需求改进: (1)发现问题:通过发布问卷调查及收集整理的形式发现用户的新需求: (2)修改需求:考虑新增提醒用户未完成事件的功能. 附:用户调查问卷(如下) 调研途 ...
- 【自用】Notice
读题 不要把 \(\sum a \oplus b\) 看成异或和. 注意读完整,有可能对原有符号有新的约定,不要想当然. 注意模数的 0 数清楚. 卡常&时间 打题之前一般先搞个自己的缺省源. ...
- IIS-logfiles详解以及日志日期问题
IIS日志的含义IIS是Internet Information Server的缩写,意思是英特网信息服务,日志就是运行的记录 IIS日志的默认目录就是%systemroot%\system32\lo ...
- Day4 dict和set
dict -- dictionary 一组key的集合,包含key与value的对应. Python内置的字典,在其他语言中称为map,使用key-value存储,具有极快的查找 ...
- 架构师基础技能-搭建gitLab
前言 想要成为一名架构师,一定要有从无到有搭建环境的能力,这是作为架构师的基础技能,而gitLab服务器的搭建一定又是重中之重. 相信很多小伙伴的公司也在使用gitLab,但都是你们公司的架构师搭建好 ...
- Kubernetes【K8S】(一):Kubernetes组件
什么是Kubernetes Kubernetes 是一个可移植的.可扩展的开源平台,用于管理容器化的工作负载和服务,可促进声明式配置和自动化.Kubernetes拥有一个庞大且快速增长的生态系统. ...
- JVM虚拟机(二):字节码执行引擎
运行时栈帧结构 栈帧是用于支持虚拟机进行方法调用和方法执行背后的数据结构,它也是虚拟机运行时数据区中的虚拟机栈的栈元素.栈帧存储了方法的局部变量表.操作数栈.动态链接.和方法返回地址等信息. ...
- 解析SwiftUI布局细节(一)
前言 在前面的文章中谈了谈对SwiftUI的基本的认识,以及用我们最常见的TB+NA的方式搭建了一个很基本的场景来帮助认识了一下SwiftUI,具体的文章可以在SwiftUI分类部分查找,这篇我准备在 ...