今天尝试使用express + mongoose,构建了一个简单的Hello world,实现以下功能:

  1. 定义mongodb使用的Schema,一个User
  2. 访问/输出Hello world
  3. 访问/init向mongodb插入初始化数据
  4. 访问/users从mongodb中取数据,并以json方式发送到浏览器

各功能都是极简单的试用,没有用到复杂的功能,但也有一定的参考价值,希望对大家有所帮助。

本次使用到的模块如下:

  1. mongoose 

    http://mongoosejs.com/ 

    一个在nodejs中使用的对mongodb进行建模的工具,可以定义一些Schema(定义每个doc里的字段名、类型、初始值、验证条件等),增删改查等,功能比较贴心。
  2. express 

    http://expressjs.com 

    nodejs环境中的web framework,提供了比nodejs的原始api高一级的抽象,方便进行web编程,如router、request/response的处理等,有很多基于它的模块或框架
  3. express-mongoose 

    https://github.com/LearnBoost/express-mongoose 

    让express中的某些方法,如res.send等,支持mongoose返回的查询,减少嵌套

在开始之前,先在项目目录的根目录下安装各模块:

npm install mongoose

npm install express

npm install express-mongoose

项目代码放在这里,可供参考:https://github.com/freewind/express-mongoose-demo

一、使用express创建一个Hello, world

创建一个app.js,内容如下:

var express = require("express");

var app = express.createServer();

app.get(‘/’, function(req, res) { 

res.send(‘Hello, world’); 

});

app.listen(3000);

短短几行代码,创建了一个app server。它监听于端口3000,并且访问/时,会向客户端发送Hello world.

二、试用/

启动该程序:

node app.js

如果没有提示错误,说明启动成功。

打开浏览器,访问:http://localhost:3000

显示如下:

三、定义Models

创建一个models.js,用于定义程序中使用的model(主要是Schema)。内容如下:

var mongoose = require(‘mongoose’);

var Schema = mongoose.Schema;

// Define User schema 

var _User = new Schema({ 

    email : String, 

    name : String, 

    salt : String, 

    password : String 

});

// export them 

exports.User = mongoose.model(‘User’, _User);

这里定义了两个Schema,一个User。为了简便好认,我在Schema前面加了一个下划线,当然你也可以使用其它命名,如UserSchema等。

在定义Schema时,还可以设一些默认值、验证什么的,但这里先忽略,毕竟是极简试用。

mongoose.model(‘User’, _User);

这一句中,第一个参数相当重要,它是给User这个schema,定义了一个名字。其它地方如果想使用这个model,可以这样:

var User = mongoose.model(‘User’)

但在这里,我们直接把它放在exports里了,更方便:

exports.User = mongoose.model(‘User’, _User);

四、/init

现在要把models.js导入到app.js中,并且定义一个/init,访问它时将会向数据库中插入一些数据。代码如下:

var express = require("express"); 

var mongoose = require(‘mongoose’);

var models = require(‘./models’);

var User = models.User;

mongoose.connect(‘mongodb://localhost/express-mongoose-demo’);

var app = express.createServer();

// init data. Use "get" to simplify 

app.get(‘/init’, function(req, res) { 

    var user = new User({ 

        email : ‘nowind_lee@qq.com’, 

        name : ‘Freewind’ 

    }); 

    user.save(); 

    res.send(‘Data inited’); 

});

app.listen(3000);

首先导入了mongoose模块,以前之前定义的models.js。然后将models.User取出来供下面使用。

下面这句话用于连接mongodb,这里使用express-mongoose-demo

mongoose.connect(‘mongodb://localhost/express-mongoose-demo’);

接着定义/init,为了演示方便起见,这里使用http get,可直接在浏览器中访问该url。如果在真实程序中,应该使用app.post(‘/init’, …)

打开浏览器,访问:http://localhost:3000/init

提示数据已经初始化。使用mongodb的控制台,查询结果如下:

看到数据的确已经插入到mongodb中了。

五、/users

接着实现/users,查询User数据,并以json格式返回到浏览器端。代码很简单,如下:

app.get(‘/users’, function(req, res) { 

    User.find(function(err, doc) { 

        res.json(doc); 

    }); 

});

打开浏览器,访问http://localhost:3000/users

果然看到json数据过来了。

但看看这段代码,里面有两个嵌套。如果数据再复杂一些的话,可能嵌套更多,就不易读了。能不能想办法让它简化一点呢?

下面就该express-mongoose出场了。

六、express-mongoose

express-mongoose项目就是为了简化express和mongoose。首先导入它:

require(‘express-mongoose’);

然后将/users方法改写成:

app.get(‘/users’, function(req, res) { 

    res.send(User.find()); 

});

看这里,直接用res.send就直接发送了,不用传回调函数了,代码简单了很多。

重启app.js,再访问:http://localhost:3000/users,截图如下:

果然效果一样。

如果去掉express-mongoose,会是什么效果呢?让我们先去掉:

require(‘express-mongoose’);

再访问:

现在返回的就是User.find()这个query的值,而不是查询结果。

今天就到这里,以后将慢慢加入更多的功能。

Express + Mongoose 极简入门的更多相关文章

  1. Git 极简入门教程学习笔记

    Git 极简入门教程  http://rogerdudler.github.io/git-guide/index.zh.html 测试用 https://github.com/xxx/BrnShop. ...

  2. .Net Core in Docker极简入门(下篇)

    Tips:本篇已加入系列文章阅读目录,可点击查看更多相关文章. 目录 前言 开始 Docker-Compose 代码修改 yml file up & down 镜像仓库 最后 前言 上一篇[. ...

  3. ElasticSearch极简入门总结

    一,目录 安装es 项目添加maven依赖 es客户端组件注入到spring容器中 es与mysql表结构对比 索引的删除创建 文档的crud es能快速搜索的核心-倒排索引 基于倒排索引的精确搜索. ...

  4. Spring Security极简入门三部曲(上篇)

    目录 Spring Security极简入门三部曲(上篇) 写在前面 为什么要用Spring Security 数据库设计 demo时刻 核心代码讲解 小结 Spring Security极简入门三部 ...

  5. Spring Security极简入门三部曲(中篇)

    目录 Spring Security极简入门三部曲(中篇) 验证流程 Authentication接口 过滤器链 AuthenticationProvider接口: demo时刻 代码讲解 小结 Sp ...

  6. Express4+Mongodb极简入门实例

    一.准备工作: 1.启动mongodb:bin目录下运行 2.在test数据库里插入一条数据: 二.正式开始: 1.通过应用生成器工具 express 快速创建一个应用的骨架,参考Express中文网 ...

  7. Spring Boot 如何极简入门?

    Spring Boot已成为当今最流行的微服务开发框架,本文是如何使用Spring Boot快速开始Web微服务开发的指南,我们将创建一个可运行的包含内嵌Web容器(默认使用的是Tomcat)的可运行 ...

  8. Nginx 极简入门教程!

    上篇文章和大家聊了 Spring Session 实现 Session 共享的问题,有的小伙伴看了后表示对 Nginx 还是很懵,因此有了这篇文章,算是一个 Nginx 扫盲入门吧! 基本介绍 Ngi ...

  9. 【Java杂货铺】用Security做权限极简入门

    原来大多数单体项目都是用的shiro,随着分布式的逐渐普及以及与Spring的天生自然的结合.Spring Security安全框架越受大家的青睐.本文会教你用SpringSecurity设计单项目的 ...

随机推荐

  1. Hadoop学习之 HIVE 多用户模式安装

    一.启动hadoop 集群 1.启动zookeeper 集群   zkServer.sh start 2.在master.hadoop 机器上 ./start-all.sh 由于 start-all命 ...

  2. vue iview面包屑

    简单看一下vue,iview的面包屑怎么写呢? 简单的思路:1.获取到路由记录$route.matched 2.渲染 效果: 一.$route.matched 官网地址:https://router. ...

  3. Vue初始化一个项目

    @1 npm install -g @vue/cli-init vue init webpack projectName @2 cnpm install -g @vue/cli vue create ...

  4. Go项目目录管理

    在Go的官网文档How to Write Go Code中,已经介绍了Go的项目目录一般包含以下几个: src 包含项目的源代码文件: pkg 包含编译后生成的包/库文件: bin 包含编译后生成的可 ...

  5. python cv2截取不规则区域图片

    知识掌握 cv2.threshold()函数: 设置固定级别的阈值应用于多通道矩阵,将灰度图像变换二值图像,或去除指定级别的噪声,或过滤掉过小或者过大的像素点. Python: cv2.thresho ...

  6. 抗D十招:十个方法完美解决DDoS攻击防御难题

    可以说,DDoS是目前最凶猛.最难防御的网络攻击之一.现实情况是,这个世界级难题还没有完美的.彻底的解决办法,但采取适当的措施以降低攻击带来的影响.减少损失是十分必要的.将DDoS防御作为整体安全策略 ...

  7. 仿造email后缀自动添加功能(1)

    <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...

  8. 在centos7上kvm网卡桥接

    系统环境准备 [root@linux-node1 ~]# cat /etc/redhat-release CentOS Linux release (Core) [root@linux-node1 ~ ...

  9. 【转载】C++ 11中的右值引用

    本篇随笔为转载,原博地址如下:http://www.cnblogs.com/TianFang/archive/2013/01/26/2878356.html 右值引用的功能 首先,我并不介绍什么是右值 ...

  10. 最长回文子序列LCS,最长递增子序列LIS及相互联系

    最长公共子序列LCS Lintcode 77. 最长公共子序列 LCS问题是求两个字符串的最长公共子序列 \[ dp[i][j] = \left\{\begin{matrix} & max(d ...