【Node.js】二、基于Express框架 + 连接MongoDB + 写后端接口
在上节,我们讲了如何搭建express环境,现在我们说说如何通过node.js写服务接口给前端调用
1. 首先通过MongoDB建好数据库与表格
例如,我的数据库名字为db_demo,数据库表格为goods
表goods中的数据结构如下:
- 'productId': {type: String}, // 商品id
- 'productName': String, // 商品名称
- 'salePrice': Number, // 商品价格
- 'productImage': String // 商品图片
mongodb创建表goods,命令如下:
- // 创建mongodb数据库表
- db.createCollections("goods")
- // 把一条数据插入到该goods表当中
- db.goods.insert({"id": "100001", "name": "自行车", "salePrcie": 500})
新开一个cmd命令行,直接输入下面这行代码,不要在mongo环境下执行
- mongoimport --db db_name --collection goods --file json文件路径(可以把json文件直接拖进来)
2. 安装Mongoose来驱动、操作MongoDB
- npm install mongoose
3.在server文件夹下,创建一个新的文件夹,models,里面创建一个关于商品接口的js文件,文件结构如下:
goods.js里面的内容如下:
- var mongoose = require('mongoose')
- var Schema = mongoose.Schema
- var productSchema = new Schema({
- 'productId': {type: String},
- 'productName': String,
- 'salePrice': Number,
- 'productImage': String
- })
- module.exports = mongoose.model('Good', productSchema)
4. 在server/routes/文件夹下面新建一个专门写后端接口逻辑的js文件 goods.js,代码如下:
- var express = require('express')
- var router = express.Router()
- var mongoose = require('mongoose')
- var Goods = require('../models/goods')
- // 连接MongoDB数据库
- mongoose.connect('mongodb://127.0.0.1:27017/db_demo')
- mongoose.connection.on('connected', () => {
- console.log('MongoDB connected success.')
- })
- mongoose.connection.on('error', () => {
- console.log('MongoDB connected fail.')
- })
- mongoose.connection.on('disconnected', () => {
- console.log('MongoDB connected disconnected.')
- })
- // 查询商品列表数据
- router.get("/", (req, res, next) => {
- // 接受前端传来的参数
- let page = parseInt(req.param('page'))
- let pageSize = parseInt(req.param('pageSize'))
- let sort = req.param("sort")
- let skip = (page-1)*pageSize
- let params = {};
- let goodsModel = Goods.find(params).skip(skip).limit(pageSize)
- goodsModel.sort({'salePrice': sort})
- goodsModel.exec((err, doc) => {
- if (err) {
- res.json({
- status: '1',
- msg: err.message
- })
- } else {
- res.json({
- status: '0',
- msg: '',
- result: {
- count: doc.length,
- list: doc
- }
- })
- }
- })
- })
- module.exports = router;
5. 最后在app.js配置路由地址访问/router/goods.js接口
6. 打开浏览器,效果如下:
成功调用后台接口,后台接口调用MongoDB数据库,最后返回json数据!
--end--
【Node.js】二、基于Express框架 + 连接MongoDB + 写后端接口的更多相关文章
- Node.js下基于Express + Socket.io 搭建一个基本的在线聊天室
一.聊天室简单介绍 采用nodeJS设计,基于express框架,使用WebSocket编程之 socket.io机制.聊天室增加了 注册登录模块 ,并将用户个人信息和聊天记录存入数据库. 数据库采用 ...
- NODE 基于express 框架和mongoDB的cookie和session认证 和图片的上传和删除
源码地址 https://gitee.com/zyqwasd/mongdbSession 本项目的mongodb是本地的mongodb 开启方法可以百度一下 端口是默认的27017 页面效果 1. 注 ...
- Node.js中的express框架,修改内容后自动更新(免重启),express热更新
个人网站 https://iiter.cn 程序员导航站 开业啦,欢迎各位观众姥爷赏脸参观,如有意见或建议希望能够不吝赐教! 以前node中的express框架,每次修改代码之后,都需要重新npm s ...
- Node.js中的express框架获取http参数
最近本人在学习开发NodeJs,使用到express框架,对于网上的学习资料甚少,因此本人会经常在开发中做一些总结. express获取参数有三种方法:官网介绍如下 Checks route para ...
- 配置node.js中的express框架
玩node.js,不玩后台那就是杀鸡牛刀,今天没事整理一下以前开发node.js后台的心得 1.首先安装node.js以及cnpm,在这儿我就不说了,看我node.js中的另一篇文章node.js的安 ...
- node.js环境安装,及连接mongodb测试
1.node.js环境安装 npm config set python python2.7npm config set msvs_version 2013npm config set registry ...
- KoaHub平台基于Node.js开发的Koa的连接MongoDB插件代码详情
koa-mongo MongoDB middleware for koa, support connection pool. koa-mongo koa-mongo is a mongodb midd ...
- node.js安装使用express框架
官网:http://www.expressjs.com.cn/ 使用方式(如果后面需要添加路由等推荐第二种方式,不然需要需要手动添加):一.自己动手搭建 1. 新建项目文件夹,如test,并在命令行中 ...
- nodejs之使用express框架连接mongodb数据库
var express = require('express');var router = express.Router();var app = express();var MongoClient = ...
随机推荐
- Tomcat7在centos7.3上正常运行,在centos7.2就不行了
我在jdk1.7的环境下,把一个tomcat7从一台centos7.3的服务器迁移到7.2,理论上讲 迁移完成之后只要端口没有被占用,环境变量配置完成,Tomcat是可以正常启动的(空的Tomcat ...
- Hive 本地调试方法
关键词:hive, debug 本地调试(local debug) Hive 可分为 exec (hive-exec,主要对应源码里的ql目录) 和 metastore 两部分,其中exec对外有两种 ...
- 邮件服务器 postfix
背景介绍 邮件服务器普遍需要一个主机名来使得mail from 以"账号@主机名"方式显示.由于外网上垃圾邮件太多,现在已不使用ip发邮件,很多网络供应商都会对来源不明的邮件进行限 ...
- 初始化git库并配置自动部署
1.初始化库 git init --bare wap.git 2.配置wap.git/config文件 [core] repositoryformatversion = 0 filemode = tr ...
- Hadoop集群搭建过程中ssh免密码登录(二)
一.为什么设置ssh免密码登录 在集群中,Hadoop控制脚本依赖SSH来执行针对整个集群的操作.例如,某个脚本能够终止并重启集群中的所有守护进程.所以,需要安装SSH,但是,SSH远程登陆的时候,需 ...
- Vue v-for循环添加表单v-model不重复变动的注意事项!
正常添加,v-model,修改所有循环会得到一样的结果! 定义一个users[]的数组,不要定义全局的user,而是要在Vue里面的方法里定义局部的变量添加.
- Web测试入门:Selenium+Chrome+Python+Mac OS
一.环境配置 Chromedriver 下载及环境配置 url:使用WebDriver在Chrome浏览器上进行测试时,需要从http://chromedriver.storage.googleapi ...
- [FPGA] 1、Artix-7 35T Arty FPGA 评估套件学习 + SiFive risc-v 指令集芯片验证
目录 1.简介 2.深入 3.DEMO 4.SiFive基于risc-v指令集的芯片验证 LINKS 时间 作者 版本 备注 2018-10-09 08:38 beautifulzzzz v1.0 到 ...
- SDL 开发实战(四): SDL 事件处理
在前面学习SDL的例子运行时,我们发现我们的窗口只停留了几秒,但是如果设置更长时间显然也有其他的弊端. 那么有没有一种好的办法可以解决这个问题呢?例如:能不能让窗口一直显示,直到检测到用户用鼠标点击关 ...
- [Swift]LeetCode48. 旋转图像 | Rotate Image
You are given an n x n 2D matrix representing an image. Rotate the image by 90 degrees (clockwise). ...