看到一个Node.JS + MongoDB的小样例,分享给大家。魔乐科技软件学院(www.mldnjava.cn)的讲座

Node.JS + MongoDB技术讲座

         云计算 +大数据 = 未来。

在中国的云计算上基本上是一个概念,个人感觉与当初的SOA没有太大的差别,空泛的理论。

中小型开发的未来 = Node.JS + MongoDB解决,并非说Java就没用了。

1、在前面的话

Java技术始终作为高端软件用户的首选,仅仅要从事大型的软件开发,那么Java都是必需要使用的技术,尤其是在中国的相关项目之中,Java是会作为不二的选择。

全部的server端技术本质上没有太多差别,都须要WEB Server,都须要一些主要的server端开发代码。都须要操作数据库。或者增加一些其它的操作支持。

开发之中你们最大的难关:server端代码是写完了,但是假设在修饰界面有问题的时候。往往出面的还是你。缺少不同平台的交流。

2003年之后開始流行的WebService彻底的改变了这一个现状。

发现,JSON作为数据的传输,以及前后台都採用JavaScript应该能够方便的进行开发。

个人对JavaScript看法:

1、   最早的时候我们常常会纠结于一个问题:数据的验证是在前台做还是在后台做?在这段时间之内,加上浏览器的战争,导致了JavaScript无用论;

2、   2005年開始中国流行的AJAX技术開始。JavaScript能够操作异步处理。并且使用DOM解析也能够动态的操作HTML页面。基于XML的传输数据。

3、   JQuery技术包装了一系列的DOM解析操作,简化了JavaScript的操作;

可是无论怎样改变,在之前。JavaScript能够做的工作仅仅是在client执行。那么把JavaScript是否能改动一下,加强其功能,让其能够变成适合server端的开发。就造就了Node.JS。

今天的目的不是解说Node.JS的相关语法。仅仅是感受Node.JS的开发方便。

个人猜測:在PHP +MySQL逐步萎靡的今天,代替它们的应该就是Node.JS + MongoDB。

2、使用Node.JS开发WEB应用

2.1、搭建开发环境

Node.JS是一个平台,并且这个平台使用的C++开发,基于JavaScript作为前台的表现语言。

它是server端的语言。可是真的不须要去配置server。

Node.js下载完毕后须要首先进行安装。

在使用Node.JS过程之中一定须要始终连接网络。总须要从网上下载对应的开发包。

安装完毕之后会出现对应的可运行命令,而如今这些命令不属于windows,所以须要将文件夹配置到path环境属性之中。不同路径之间要使用“;”分隔。

Express是整个Node.js之中最为经常使用的一个框架(开发包),使用它能够方便的高速构建起一个WEB项目。

首先Express是一个Node.js最为经常使用的一个开发包,那么应该首先将其下载,并且下载的方式分为两种:仅仅针对于一个项目进行开发包的下载,或者是针对于整个Node.js开发环境。

如今下载开发包:

npm install -g express

之后会出现很多的提示信息,提示用户的相关下载的进度。

下载完毕之后,全部的全局包都保存在一个固定的文件夹:

C:\Documents and Settings\Administrator\Application Data\npm

仅仅要是开发项目,那么肯定须要一个保存项目的文件文件夹,此时的文件夹就将其定义为mldnnodedemo。

mkdir mldnnodedemo

而后进入到此文件夹之中(就想象为Eclipse的工作区,一个工作区之中能够定义多个项目。

cd mldnnodedemo

以下是一个很重要的步骤,须要创建一个express项目(有明白的目录要求)。

express -e myproject

此时就表示项目建立完毕了,就算你使用Eclipse的相关插件,也必须依照此步骤进行操作。

而创建的项目之中存在

了一个app.js文件,那么这个文件就作为了整个程序执行的主文件出现,即:仅仅须要执行它。就能够执行HTTP Server。

http.createServer(app).listen(app.get('port'), function(){

console.log('Express server listening on port ' + app.get('port')); 
è System.out.println()一样。直接后台输出

});

此时。http的服务将在3000port上监听用户的请求。

假设要想启动server。直接进入到myproject文件夹里面,输入:node app.js。

之前下载的express貌似有点问题,又一次在本项目里面下载一个:“npm install express”。此时在myproject文件夹下也存在了node_modules文件夹。同一时候保存了express程序包。

程序执行之后就会出现下面的提示信息:

Express server listening on port 3000

表示在3000的port监听。

随后打开浏览器输入:http://localhost:3000

继续安装ejs:npm install ejs。

这个就是默认显示界面。这个界面的内容保存在views文件夹下。

可是如今有一个小小的问题出现了,假设要想执行Node.js程序。则如今仅仅能够使用“node app.js”,而这种执行方式。假设在app.js文件改动之后往往须要又一次启动才干够载入新的内容,这对于开发是很不方便的, 为此。能够使用一个supervisor组件包,它能够动态的载入改动之后的开发程序。

下载:supervisor

npm install -g supervisor

随后直接利用supervisor方式执行程序:

supervisor app.js

以后项目之中,每一次文件的改变,那么都能够及时的监听到,同一时候也能够及时载入新的代码文件,对于开发是很方便,可是有一点不方便:每一次改动的时候假设代码有错。后台会一直报错。

2.2、编写代码

以下要进行正规的开发了,本次要开发一个简单的登录程序,而这个用户登录程序,也分为两个开发步骤完毕:第一步:是固定的username和password完毕、第二步:是基于MongoDB进行的登录开发。

之前通过代码能够发现。全部用户须要保存的页面都应该保存在views文件夹下。可是此时index.ejs是一个html页面,而有的人不习惯于使用ejs。习惯于使用html。为了解决这种问题。则须要配置模板。

定义载入的项目模块

var ejs = require('ejs') ; // require()函数表示要载入的模块

须要添加一些相关的配置。

app.engine('html',ejs.__express) ;

app.set('view engine', 'html'); // 替换:app.set('view engine', 'ejs');

将views中的index.ejs文件改动为index.html文件,观察能否够改变。

以下编写一个用户的登录。登录的时候仅仅提供用户id(userid)和password,以下建立几个相关的操作页面:login.html、welcome.html。可是在建立这两个文件的时候。请一定要注意。文件的编码必须设置为UTF-8,否则无法操作中文。

范例:定义login.html

<!DOCTYPE html>

<html>

<head>

<title><%= title %></title>

<link rel='stylesheet' href='/stylesheets/style.css' />

</head>

<body>

  <h1><%= title %></h1>

<form method="post">

用户ID:<input type="text" name="userid" id="userid"><br>

密&nbsp;&nbsp;码:<input type="password" name="password" id="password"><br>

<input type="submit" value="登录">

<input type="reset" value="重置">

</form>

</body>

</html>

范例:定义欢迎页 —— welcome.html

<!DOCTYPE html>

<html>

<head>

<title>Welcome</title>

<link rel='stylesheet' href='/stylesheets/style.css' />

</head>

<body>

  <h1>欢迎<%=user.userid%>光临。</h1>

<h1><a href="logout">注销</a></h1>

</body>

</html>

范例:改动index.html页面,添加登录的链接地址

<!DOCTYPE html>

<html>

<head>

<title><%= title %></title>

<link rel='stylesheet' href='/stylesheets/style.css' />

</head>

<body>

<h1><%= title %></h1>

  <p><a href="login">用户登录</a></p>   

</body>

</html>

在每个页面之中并未定义直接的连接,由于Node.js依旧属于MVC设计模式的范畴,所以针对于MVC的实现。此处所编写的所有都属于映射名称。所有的映射路径都须要通过app.js进行对应的路由配置。

app.get('/', routes.index);

app.get('/login', routes.login); // 此处还须要routes/index.js改动

app.post('/login', routes.doLogin);   // 处理post请求。表单提交

app.get('/logout', routes.logout);      // 处理注销

app.get('/welcome', routes.welcome);                 // 进入到首页

而这5 个操作路径配置完毕之后。还须要找到routes/index.js文件进行相关的回调函数的配置操作。

范例:改动index.js文件

/*

* GET home page.

*/

exports.index = function(req, res){

res.render('index', { title: 'Express' });

};

exports.login = function(req, res){

res.render('login', { title: '用户登录' });

};

exports.doLogin = function(req, res){

var user = {userid:'mldnadmin' , password:'hellojava'} ;      // 固定数据

// 假设要想接收请求,通过req对象

if (req.body.userid==user.userid && req.body.password==user.password) {

res.redirect("/welcome?uid=" + req.body.userid) ;      // 地址重写

}

res.redirect("/login") ;

};

exports.logout = function(req, res){

res.render('login', { title: '用户注销' });

};

exports.welcome = function(req, res){

// 假设是地址栏參数使用req.query.參数名称接收

var user = {

userid : req.query.uid   }

res.render('welcome', { title: '程序首页' , user:user });

};

那么在整个的基础过程之中,最为重要的步骤就配置app.js中的路由。当然,路由的终于控制是通过index.js文件完毕的。在这个文件就相当于Java中的Servlet功能,负责跳转。

3、利用MongoDB来解决数据库的登录问题

MongoDB能够说是在以后未来发展之中。在中小型数据库的市场上一定是具备发展优势的数据库。并且与Node.js的结合也很的方便。并且多种多样。

MongoDB和Oracle数据库全然是不一样的操作结构:MongoDB使用的是文档存储。而Oracle採用的是表存储。

列名称

列名称

列名称

列名称

列名称

sdf

fsd

fsda

fsda

fsda

fdsa

fsdafdsa

fdsa

fsad

fsda

fsda

af

324

dsf

2342

3.1、搭建好开发环境

SQL:作为整个数据库的开发标准已经存在了几十年了。但是NoSQL技术最早的提出指的是不使用SQL使用。但是后来发现不可以离开SQL,所以NoSQL又被翻译为:Not Only SQL(不仅SQL)。

下载MongoDB:http://www.mongodb.org/

下载下来的MongoDB是一个*.zip文件,直接将其解压缩后就能够使用了。可是在使用之前,还须要为其进行path环境的配置:D:\mongodb\bin。

以后使用mongodb临时将其定义为在d盘上。所以如今须要在d盘上建立一个data/db的文件文件夹。

随后打开一个新的命令行窗体,让路径设置在d盘路径下,首先启动mongodb服务:mongod.exe;

Wed Aug 14 16:13:19.739 [initandlisten] MongoDB starting : pid=4344 port=27017 dbpath=\data\db\ 32-bit host=cab34d4eb860431

Mongodb服务启动之后。以下也相同须要打开一个新的命令行窗体,使用mongo进行操作。

打开命令行窗体输入:mongo.exe命令。启动mongodb的命令窗体。

范例:创建一个新的数据库(mongodb里没有数据库):

use mldndb

范例:设置一个users文档

db.users.insert({userid:'mldn',name:'lixinghua',password:'hello'}) ;

db.users.insert({userid:'mldnjava',name:'mole',password:'nodejs'}) ;

此时能够通过showtables查看所有的集合。已经发现存在了users集合。以下查询所有:

db.users.find();

此处为了方便,所以全部的password并没有採用加密的处理方式。

但是假设如今直接利用node.js提供的mongodb操作不方便使用。

所以在处理mongodb的时候建议使用express-mongoose组件。

npm install express-mongoose

此组件能够和express组件完美的搭档。

还须要下载一个mongoose的组件。:npm install mongoose

3.2、实现数据库验证

当mongodb配置完毕之后,以下就首先须要定义一个与Users集合有关的新的组件。类似于VO类的概念,仅仅只是如今这个类须要通过*.js文档描写叙述。在routes文件夹下创建models.js文件。

范例:创建models.js文件

var mongoose = require('mongoose') ;     // 定义使用组件

var Schema = mongoose.Schema ;  // 创建模式

var UserSchema = new Schema({

userid : String ,

name : String ,

password : String

}) ;    // 定义了一个新的模式,可是此模式还未和users集合有关联

exports.User = mongoose.model('User',UserSchema) ;       // 与Users表关联

范例:改动index.js文件,使用新的组件模块

var mongoose = require('mongoose') ;     // 导入组件

var models = require('./models') ;    // 导入自己定义组件

var User = models.User ;       // 使用User模型,相应的users表

mongoose.connect('mongodb://localhost/mldndb') ;    // 连接数据库

如今最须要改变的就是doLogin操作,由于此处须要使用数据库验证。

假设要想完毕登录验证,仅仅须要依据username和password取得数据量就可以。

db.users.count({userid:'mldn',password:'hello'}) ;

仅仅须要依据返回的数量就能够确定username和password是否正确。

exports.doLogin = function(req, res){

// 如今拼凑出了一个主要的字符串

var query_doc = {userid:req.body.userid , password:req.body.password} ;    // 固定数据

User.count(query_doc,function(err,doc){// 直接利用mongodb的命令进行操作

if(doc == 0) {      // 输入错误。没有此信息

res.redirect("/login") ;

} else {       // 成功

res.redirect("/welcome?uid=" + req.body.userid) ;      // 地址重写

}

}) ;

};

并且最为关键的是整个过程之中,不再去考虑数据库的关闭问题。极大的方便了用户开发。

4、总结

能够发现。假设要实现Node.JS+ MongoDB开发,最为痛苦的地方就是各个组件包的管理,并且最麻烦的是Node.JS之中有上万个组件包。

使用这样的轻量的开发方式绝对要比PHP + MySQL更加强大。

 

 

Node.JS + MongoDB技术浅谈的更多相关文章

  1. Node.js:Buffer浅谈

    Javascript在客户端对于unicode编码的数据操作支持非常友好,但是对二进制数据的处理就不尽人意.Node.js为了能够处理二进制数据或非unicode编码的数据,便设计了Buffer类,该 ...

  2. .net中对象序列化技术浅谈

    .net中对象序列化技术浅谈 2009-03-11 阅读2756评论2 序列化是将对象状态转换为可保持或传输的格式的过程.与序列化相对的是反序列化,它将流转换为对象.这两个过程结合起来,可以轻松地存储 ...

  3. 《Node.js+MongoDB+AngularJS Web开发》读书笔记及联想

    总体介绍 <Node.js+MongoDB+AngularJS Web开发>,于2015年6月出版,是一本翻译过来的书,原书名为<Node.js,MongoDB and Angula ...

  4. 8 步搭建 Node.js + MongoDB 项目的自动化持续集成

    任何事情超过 90 秒就应该自动化,这是程序员的终极打开方式.Automating shapes smarter future. 这篇文章中,我们通过创建一个 Node.js + MongoDB 项目 ...

  5. AngularJS + Node.js + MongoDB开发

    AngularJS + Node.js + MongoDB开发的基于位置的通讯录(by vczero) 一.闲扯 有一天班长说了,同学们希望我开发一个可以共享位置的通讯录,于是自己简单设计了下功能.包 ...

  6. node.js + mongodb

    node.js + mongodb 这次内容是结合bootstrap把登陆注册做好,还有就是express的中间件等问题. 看这篇博客之前建议先看我上篇写的那篇博客http://www.cnblogs ...

  7. [技术]浅谈OI中矩阵快速幂的用法

    前言 矩阵是高等代数学中的常见工具,也常见于统计分析等应用数学学科中,矩阵的运算是数值分析领域的重要问题. 基本介绍 (该部分为入门向,非入门选手可以跳过) 由 m行n列元素排列成的矩形阵列.矩阵里的 ...

  8. 用Node.JS+MongoDB搭建个人博客(页面模板)(五)(结束)

    <差不多先生> 我是差不多先生,我的差不多是天生.也代表我很天真,也代表我是个闲人.这差不多的人生,总是见缝插针. 求学的道路上总是孤独的,即使别人不理解我,认为我是奇葩!但没关系,我会坚 ...

  9. node.js+mongodb 爬虫

    demo截图: 本demo爬瓜子二手车北京区的数据 (注:需要略懂 node.js / mongodb 不懂也没关系 因为我也不懂啊~~~) 之所以选择爬瓜子二手车网站有两点: 一.网站无需登录,少做 ...

随机推荐

  1. 线程 (detach的作用)

      线程状态在一个线程的生存期内,可以在多种状态之间转换.不同操作系统可以实现不同的线程模型,定义许多不同的线程状态,每个状 态还可以包含多个子状态.但大体说来,如下几种状态是通用的:       就 ...

  2. jquery压缩图片插件

    imageCompress 只有图片压缩功能,比较简单jquery.imageCompress.js 使用说明: el:为上传框 quality:压缩图片质量,单位为% onloadStart:读取图 ...

  3. ARM体系结构_DAY2

    程序状态寄存器(CPSR) Mode位[4:0]:处理器模式为 USER模式不能直接切换到特权模式,在特权模式下可以直接修改mode位[4:0]为10000,切换到USER模式. T bit位[5]: ...

  4. DropDownList绑定数据

    DDLName.DataSource = myRd;DDLName.DataTextField = "name";//要绑定的字段DDLName.DataValueField = ...

  5. 0301——SearchController

    创建显示的页面 SearchViewController * searchVC = [[SearchViewController alloc]init]; 告诉搜索控制器将结果显示在创建的页面上 se ...

  6. VC++ try catch (转)

    VC++ try catch (转)   以前都是用try{} catch(-){}来捕获C++中一些意想不到的异常, 今天看了Winhack的帖子才知道,这种方法在VC中其实是靠不住的.例如下面的代 ...

  7. 多线程中遇到ASSERT(pMap->LookupPermanent(hWndOrig) == NULL);怎么解决

    XP下用VC开发的程序,在一个主线程调用3   个线程,线程之间要共享数据,结果总出现wincore.cpp   line   980   ASSERT(pMap-> LookupPermane ...

  8. oracle 10g RAC psu过程

    1 升级crs 至10.2.0.5.2 1) 升级opatch 程序,PSU对opatch的版本有要求,详见readme文件,此步操作共涉及到每个节点的ORACLE_HOME和ORA_CRS_HOME ...

  9. Avro基础

    一.Avro的基本功能 1.定义了数据模式文件的语法,一般使用json文件.以及一些数据基本类型与复杂类型. 2.定义了数据序列化到文件后的数据格式,此格式可供各种语言进行读取. 3.为部分语言定义了 ...

  10. Strange Grid

    def main(): r,c = map(int, raw_input().split(' ')) if r % 2 != 0: base = 5*(r-1) else: base = 5*(r-2 ...