简单做了一个代办事项列表系统 ,增删改查。 前台页面用 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. 删 ...
随机推荐
- LeetCode初级算法之数组:122 买卖股票的最佳时机 II
买卖股票的最佳时机 II 题目地址:https://leetcode-cn.com/problems/best-time-to-buy-and-sell-stock-ii/ 给定一个数组,它的第 i ...
- CSP-S 2020 题解
赛后我重拳出击,赛场上我却爆零.哎. 题解本人口胡.有错请各位大佬们指出. A. 儒略日 这题是大型模拟题. 介绍两种写法:一种代码量致死(赛 场 自 闭),一种是非常好写的. 写法 1 我在赛场的思 ...
- 如何建一个SAM
部分改编自OI WIKI 先从一个简单的问题入手: 给定一个串,构造一个图,使其能够表示它的所有子串. 显然一个子串就是一个后缀的前缀.所以一个很显然的方式就是把所有后缀扔进trie里. 比如当前串是 ...
- 【题解】「SP867」 CUBES - Perfect Cubes
这道题明显是一道暴力. 暴力枚举每一个 \(a, b, c, d\) 所以我就写了一个暴力.每个 \(a, b, c, d\) 都从 \(1\) 枚举到 \(100\) #include<ios ...
- PHP表白墙网站源码
PHP表白墙网站源码,可以做校园内的,也可以做校区间的,可封装成APP.告别QQ空间的表白墙吧. 安装简单,上传程序安装,然后设置账号密码,登陆后台切换模板手机PC都要换开启插件访问前台. 安装完成后 ...
- react项目中的一些配置
react中事件优化使用babel插件 npm install babel-plugin-react-scope-binding --save-dev react中绝对路径引入文件:在根目录下增加js ...
- 【面试专栏】ArrayList 非线程安全案例并提供三种解决方案
1. 复现问题 import java.util.ArrayList; import java.util.List; import java.util.UUID; /** * 复现问题 * * @au ...
- 安卓 Android Studio 下载
http://www.android-studio.org/ 下载地址 https://blog.csdn.net/qq_41976613/article/details/91432304 ...
- Ajax相关基础知识总结
URL:统一资源定位符 网络的七层协议:网卡 驱动 网络层(ip) 传输层(tcp udp) 会话层( ) 应用层(http.) restful表征状态转移(一种表征架构) CURD 增删改查 ...
- 使用pdfobject.js
一.下载pdfobject.js 二.CSS样式 <style type="text/css"> html, body, #pdf_viewer { width: 10 ...