利用nodejs实现商品管理系统(二)
下面实现商品管理系统
第一步:对应的ejs与数据交换的编写格式。
商品列表界面product.ejs
<% for(var i=0;i<list.length;i++){%>
<tr>
<td><%=i+1%></td>
<td><img width="100" src="<%=list[i].pic%>" alt=""/></td>
<td><%=list[i].title%></td>
<td><%=list[i].price%></td>
<td><%=list[i].fee%></td>
<td class="text-center">
<a href="/productedit?id=<%=list[i]._id%>" class="btn btn-success">修改</a>
<a href="/productdelete?id=<%=list[i]._id%>" class="btn btn-danger">删除</a>
</td>
</tr>
<%}%>
商品编辑页面
<form action="/doProductEdit" method="post" enctype="multipart/form-data">
<ul>
<input type="hidden" name="_id" value="<%=list._id%>"/> <input type="hidden" name="pic" value="<%=list.pic%>"/>
<li> 商品名称: <input type="text" name="title" value="<%=list.title%>"/></li> <li> 商品图片: <input type="file" name="pic"/>
<br/> <br/>
<img src="<%=list.pic%>" width="100"/>
<br/> <br/>
</li> <li> 商品价格: <input type="text" name="price" value="<%=list.price%>"/></li>
<li> 商品邮费: <input type="text" name="fee" value="<%=list.fee%>"/></li> <li>
商品描述:
<textarea name="description" id="" cols="60" rows="8"><%=list.description%></textarea>
</li> <li>
<br/>
<button type="submit" class="btn btn-default">提交</button>
</li>
</ul>
</form>
商品增加页面productadd.ejs
<form action="/doProductAdd" method="post" enctype="multipart/form-data">
<ul>
<li> 商品名称: <input type="text" name="title"/></li>
<li> 商品图片: <input type="file" name="pic"/></li>
<li> 商品价格: <input type="text" name="price"/></li>
<li> 商品邮费: <input type="text" name="fee"/></li>
<li>
商品描述:
<textarea name="description" id="" cols="60" rows="8"></textarea>
</li>
<li>
<br/>
<button type="submit" class="btn btn-default">提交</button>
</li>
</ul>
</form>
第二步:由于商品的增删改查都要用到数据库,所以第二步应该讲数据库封装起来,接着在app.js中引用相应的模块。
新建db.js,开始判断是否连接数据库成功。
var MongoClient=require('mongodb').MongoClient;
var DbUrl='mongodb://localhost:27017/productmanage';
var ObjectID = require('mongodb').ObjectID;
function __connectDb(callback){
MongoClient.connect(DbUrl,function(err,db){
if(err){
console.log('数据库连接失败');
return;
}
//增加 修改 删除
callback(db);
})
}
exports.ObjectID=ObjectID; //查找数据
exports.find=function(collectionname,json,callback){ __connectDb(function(db){ var result=db.collection(collectionname).find(json); result.toArray(function(error,data){ db.close();/*
关闭数据库*/
callback(error,data);/*拿到数据执行回调函数*/
}) }) } //插入数据
exports.insert=function(collectionname,json,callback){ __connectDb(function(db){ db.collection(collectionname).insertOne(json,function(error,data){ callback(error,data);
})
}) } //更新数据
exports.update=function(collectionname,json1,json2,callback){ __connectDb(function(db){
db.collection(collectionname).updateOne(json1,{$set:json2},function(error,data){ callback(error,data);
})
}) } //删除数据
exports.deleteOne=function(collectionname,json,callback){ __connectDb(function(db){
db.collection(collectionname).deleteOne(json,function(error,data){
callback(error,data);
})
}) }
第三步:编辑相应的路由
3.1商品增加路由
//商品列表
app.get('/product',function(req,res){ DB.find('product',{},function(err,data){ res.render('product',{ list:data
});
}) })
//显示增加商品的页面
app.get('/productadd',function(req,res){
res.render('productadd'); })
当点击增加商品时,跳转到doProductAdd路由上
<form action="/doProductAdd" method="post" enctype="multipart/form-data">
在第一篇的时候使用body-parser来接收用户密码和用户名,但是在商品增加编辑中存在图片上传问题,body-parser无法实现,所以改用multiparty模块。
先安装multiparty
npm install multiparty --save
在引入:
var multiparty = require('multiparty');
使用post获取商品增加提交的数据
app.post('/doProductAdd',function(req,res){
//获取表单的数据 以及post过来的图片
var form = new multiparty.Form();
form.uploadDir='upload' //上传图片保存的地址 upload目录必须存在
form.parse(req, function(err, fields, files) {
//获取提交的数据以及图片上传成功返回的图片信息
//fields获取表单的数据 files得到图片上传成功返回的信息
var title=fields.title[0];
var price=fields.price[0];
var fee=fields.fee[0];
var description=fields.description[0];
var pic=files.pic[0].path;
//在数据库中插入数据
DB.insert('product',{
title:title,
price:price,
fee,//效果与上面一致
description,
pic
},function(err,data){
if(!err){
res.redirect('/product'); /*上传成功跳转到首页*/
}
})
});
})
此时添加/upload路由获取图片信息,因为此时图片的地址是/upload/xxxxxxx.jpg,否则默认从public从查找资源。
app.use('/upload',express.static('upload'));
拓展:如果此时图片的地址是 /xxxxxxx.jpg,可以直接配置,注意路由!
app.use(express.static('upload'));
3.2商品编辑路由
注意:无论是商品编辑还是删除都是通过get传值来获取商品的数据库id号
<a href="/productedit?id=<%=list[i]._id%>" class="btn btn-success">修改</a>
<a href="/productdelete?id=<%=list[i]._id%>" class="btn btn-danger">删除</a>
app.js中
app.get('/productedit',function(req,res){
//获取get传值 id
var id=req.query.id;
console.log(id);
//去数据库查询这个id对应的数据 自增长的id 要用{"_id":new DB.ObjectID(id)
DB.find('product',{"_id":new DB.ObjectID(id)},function(err,data){
//console.log(data);
res.render('productedit',{
list:data[0]
});
});
})
在修改商品form表格上依然使用post来提交数据
<form action="/doProductEdit" method="post" enctype="multipart/form-data">
在编辑/doProductEdit路由的时候,如果并没有修改图片信息,此时我们需要作出判断,否则会在upload文件上存在一串非图片信息的字符串,最终返回/product界面时,没有出现并没有修改的商品图片。
最终在修改的商品信息返回到product页面
app.post('/doProductEdit',function(req,res) {
var form = new multiparty.Form();
form.uploadDir = 'upload' // 上传图片保存的地址
form.parse(req, function (err, fields, files) {
//获取提交的数据以及图片上传成功返回的图片信息
//console.log(fields);
console.log(files);
var _id = fields._id[0];
/*修改的条件*/
var title = fields.title[0];
var price = fields.price[0];
var fee = fields.fee[0];
var description = fields.description[0];
var originalFilename = files.pic[0].originalFilename;
var pic = files.pic[0].path;
if (originalFilename) { /*修改了图片*/
var setData = {
title,
price,
fee,
description,
pic
};
} else { /*没有修改图片*/
var setData = {
title,
price,
fee,
description
};
//删除生成的临时文件
fs.unlink(pic);
}
DB.update('product', {"_id": new DB.ObjectID(_id)}, setData, function (err, data) {
if (!err) {
res.redirect('/product');
}
})
});
})
3.3商品删除
app.get('/productdelete',function(req,res){
//获取id
var id=req.query.id;
DB.deleteOne('product',{"_id":new DB.ObjectID(id)},function(err){
if(!err){
res.redirect('/product');
}
})
})
最后的最后,奉上项目的源码地址:https://github.com/xinhua6/productManage.git
利用nodejs实现商品管理系统(二)的更多相关文章
- 利用nodejs实现商品管理系统(一)
一.界面分类:用户登录界面,商品管理界面(包含商品编辑,创建,删除,列表界面) 功能实现:1.用户输入用户名与密码,通过加密,与数据库校验,如果正确,则跳转到商品管理界面,否则一直停留在用户界面. 2 ...
- 利用 nodejs 解析 m3u8 格式文件,并下 ts 合并为 mp4
利用 nodejs 解析 m3u8 格式文件,并下 ts 合并为 mp4 以前看视频的时候,直接找到 video标签,查看视频地址,然后下载下来.. 后来发现,好多 video 标签打开元素审查,如下 ...
- 利用nodejs实现登录并转码视频(原创)
nodejs的出现让前端人员可以使用js打造后台,也许哪天就真的摆脱了对java或者php的依赖了. 今天跟大家分享一个利用nodejs接受前端post请求,并实现视频转码的这样一个例子.视频转码用到 ...
- 利用Nodejs快速构建应用原型
利用Nodejs快速构建应用原型 开发一个应用往往需要快速的构建原型,然后在此基础上设计和改进,前端可能立马能看到效果,但是后端业务逻辑不会那么快,这个时候其实我们需要额只是一些模拟数据,所以不需要真 ...
- 利用C#进行AUTOCAD的二次开发
众所周知,对AutoCAD进行二次开发用到的主要工具有:ObjectArx,VBA,VLisp.但它们的优缺点是显而易见的:ObjectArx功能强大,编程效率高,但它的缺点是编程者必须掌握VC++, ...
- php利用array_search与array_column实现二维数组查找
利用array_search与array_column实现二维数组查找,不用自己写个循环,减少工作量. <?php $userdb = array( 0 => array( 'uid' = ...
- windows下利用nodejs压缩.min文件
利用nodejs中的npm工具,压缩文件,必须在node环境下 压缩js文件 1.在全局中安装uglify-js模块 npm install uglify-js -g 2.可以直接使用uglifyjs ...
- 在nodeJS中操作文件系统(二)
在nodeJS中操作文件系统(二) 1. 移动文件或目录 在fs模块中,可以使用rename方法移动文件或目录,使用方法如下: fs.rename(oldPath,newPath,call ...
- 利用PHP QR Code生成二维码(带logo)
转自:http://www.cnblogs.com/txw1958/p/phpqrcode.html HP QR Code是一个PHP二维码生成类库,利用它可以轻松生成二维码,官网提供了下载和多个演示 ...
随机推荐
- 简单记录一下http请求的7个步骤
1.建立TCP连接 2.客户端发送请求命令 3.客户端发送请求头信息 4.服务端应答请求,返回版本号和状态码 5.服务端应答头信息 6.服务端向客户端发送数据 7.服务器关闭TCP连接(Connect ...
- LAMP环境基本配置
CentOS 7.0 LAMP环境搭建 Apache: 安装: yum -y install httpd 设为开机启动: systemctl start httpd.service systemctl ...
- POJ-1759 Garland---二分+数学
题目链接: https://cn.vjudge.net/problem/POJ-1759 题目大意: N个灯泡离地H_i,满足H1 = A ,Hi = (Hi-1 + Hi+1)/2 – 1,HN = ...
- darknet53 yolo 下的识别训练
[目录] 一. 安装Darknet(仅CPU下) 2 1.1在CPU下安装Darknet方式 2 1.2在GPU下安装Darknet方式 4 二. YOLO.V3训练官网数据集(VOC数据集/COCO ...
- ASP.NET MVC Cookie 身份验证
1 创建一个ASP.NET MVC 项目 添加一个 AccountController 类. public class AccountController : Controller { [HttpGe ...
- element 表单的input循环生成,并可单个input失去焦点单个验证并保存; (多个表单实例)
<div class="box_item"> <el-form ref="aList" :model="form" :ru ...
- iOS之网络请求及各类错误代码含义总结(包含AFN错误码大全)
转自http://blog.csdn.net/wangyanchang21/article/details/50932191 在很多时候都会遇到错误, 还会带有一些 Error Code , 比如在各 ...
- Hibernate知识点小结(二)
一.持久化对象和标识符 1.持久化类 配置完关系后,操作的实体对应的类,成为持久化类 (Customer) 2.持久化类标识符(oid:object id) 3.持久 ...
- MySQL提升课程 全面讲解MySQL架构设计-索引
索引是什么? 索引是帮助MySQL高效获取数据的数据结构. 索引能干什么? 提高数据查询的效率. 索引:排好序的快速查找数据结构!索引会影响where后面的查找,和order by 后面的排序. 一. ...
- c# 开发可替换的通用序列化库
开篇继续吹牛.... 其实没有什么可吹的了,哈哈哈哈哈 主要是写一个通用库,既可以直接用,又方便替换,我的序列化都是采用第三方的哈. 我不上完整代码了,只是给大家讲讲过程. 1.写一个序列化的类,我是 ...