NodeJS+Express+Mongoose搭建网站系统

原创 2016年09月08日 14:30:13

简介

想开发一个API文档查看系统,主要就是为了比较方便的编写接口文档,正好最近也在研究NodeJS和前端的知识。后续会把接口文档查看系统的源代码,分享出来,写的不好之处,多多批评

Express简介

  1. Express 是一个基于 Node.js 平台的极简、灵活的 web 应用开发框架,它提供一系列强大的特性,帮助你创建各种 Web 和移动设备应用。
  2. [路由]:Express对NodeJS的Http模块的封装,能很快速的创建API,
  3. 可使用 express.Router 类创建模块化、可挂载的路由句柄,降低代码耦合度。
  4. [DEBUG]:Express自身提供了DEBUG模式,对开发来说是一件好事。

Express路由分析

路由是指如何定义应用的端点(URIs)以及如何响应客户端的请求。路由是由一个 URI、HTTP 请求(GET、POST等)和若干个句柄组成。

假如不用Express,提供路由

那么就要使用Nodejs创建服务端,当客户端向服务端发送请求,那么也就只能用callback的request中的信息来获取客户端需要请求的URL,Method(get or post?),Http请求出错怎么办,404? 500?怎么办

var http = require('http');

http.createServer(function (request, response) {
console.log(request.url);
console.log(request.method);
if (request.url=='/') {
    if (request.method=='GET') {
            // 发送 HTTP 头部 
    // HTTP 状态值: 200 : OK
    // 内容类型: text/plain
    response.writeHead(200, {'Content-Type': 'text/plain'});
//处理其他业务
console.log("处理其他业务中...");
    // 发送响应数据 "Hello Users"
    response.end('Hello World Node base\n');
    }
}

if (request.url=='/user') {
    if (request.method=='GET') {
    // 发送 HTTP 头部 
    // HTTP 状态值: 200 : OK
    // 内容类型: text/plain
    response.writeHead(200, {'Content-Type': 'text/plain'});

    // 发送响应数据 "Hello World"

//处理其他业务
console.log("处理其他业务中...");
    response.end('Hello Users\n');
    }
};

}).listen(8888);

// 终端打印如下信息
console.log('Server running at http://127.0.0.1:8888/');

然而这样写代码就感觉代码屎烦屎烦的。

Express提供路由

Express框架就帮我们封装了http(ex:request_Url,request_Method,request_Err)处理

var express = require('express');
var app = express();

// respond with "hello world" when a GET request is made to the homepage
app.get('/', function(req, res) {
  res.send('hello world');
});

// POST method route
app.post('/', function (req, res) {
  res.send('POST request to the homepage');
});

这样看起就清爽一些了 哈哈 一切为了向我这种懒人的人性化设计 哈哈哈哈 先让我笑会儿….
咳咳..吐了一口老血!

NodeJS项目骨架:

//这样就会形成一个以Express为框架的项目骨架,默认是jade模版引擎
express projectName
//生成ejs模版引擎
express -e projectName

想了解更多信息请点击→_→ Express官网

这里写图片描述

骨架目录分析

框架:使用express框架.

服务端环境:Nodejs ,利用NodeJS中强大的V8和libuv

数据库:mongodb

数据层:models

数据访问层:mongoose

控制层(路由控制层):routes 使用express支持的中间件

视图层:Views,jade模版引擎

测试:test

数据库配置与连接:db.js

程序入口:app.js

www: Express的Debug功能

package.json

这样也就搭建了一个比较简易的开发骨架,接下来来分析一下app.js

var express = require('express');
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');

//获取路由
var routes = require('./routes/index');
var users = require('./routes/users');
var adminIndex=require('./routes/admin/adminIndex');

var app = express();

// view engine setup
app.set('views', path.join(__dirname, 'views'));//设置模版路径位置
app.set('view engine', 'ejs');//设置模版引擎

// uncomment after placing your favicon in /public
//app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));
//使用各种中间件
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(cookieParser());

app.use(express.static(path.join(__dirname, 'public')));//设置静态文件存放位置,比如js,css

//设置路由
app.use('/', routes);
app.use('/users', users);
app.use('/admin',adminIndex);

// catch 404 and forward to error handler
//如果在前面找不到路由,执行这一步
app.use(function(req, res, next) {
  var err = new Error('Not Found ');
  err.status = 404;
  next(err);
  //如果为next(),方法 就会执行下面代码中的express.use(function(req,res.next)),回调函数为function(req,res,next)的方法
});
/*
app.use(function(err,req,res,next){//express会执行use(function(err,req,res,next)),回调函数为function(err,req,res,next)的方法 express.use()
  res.send("报错了哈");
});
*/
// error handlers 

// development error handler
// will print stacktrace
if (app.get('env') === 'development') {//如果为开发环境
  app.use(function(err, req, res, next) {
    res.status(err.status || 500);

    console.log(res.statusCode);
   res.render('error', {
      message: err.message,
      error: err
    });
//res.send("报错了,兄弟");
  });
}

// production error handler
// no stacktraces leaked to user
app.use(function(err, req, res, next) {
  res.status(err.status || 500);
  res.render('error', {
    message: err.message,
    error: {}
  });
//res.send('aaaaa');
});

var server=app.listen(2333,function(){
 var host = server.address().address;
  var port = server.address().port;

  console.log('sky app listening at http://%s:%s', host, port);
})
module.exports = app;

需要注意的几方面

设置模版引擎:

app.set('views', path.join(__dirname, 'views'));//设置模版路径位置
app.set('view engine', 'ejs');//设置模版引擎

设置静态文件存放位置:

app.use(express.static(path.join(__dirname, 'public')));//设置静态文件存放位置,比如js,css

获取路由:

//设置路由
var routes = require('./routes/index');
var users = require('./routes/users');
var adminIndex=require('./routes/admin/adminIndex');

设置路由:

app.use('/', routes);
app.use('/users', users);
app.use('/admin',adminIndex);

express中的next(),next(err):
next():

//如果为next()方法 就会执行下面代码中的express.use(function(req,res.next)),回调函数为function(req,res,next)的方法 ex:

app.use(function(req,res,next){
next();
})
//就会执行这个方法
app.use(function(req,res,next){
})

next(err):

//如果为next(err),express会执行use(function(err,req,res,next)),回调函数为function(err,req,res,next)的方法 
app.use(function(req,res,next){
next(err);
})

app.use(function(err,req,res,next){
})

最后

哈哈,写完了哈,大致的流程和操作就这么多,后续也尝试着把自己写的接口文档系统分享出来。。也算是对自己有一个交代。

先放上来洋盘一哈:
这里写图片描述

版权声明:来啊,互相伤害,O(∩_∩)O

react前端+node后台+mongoose+express框架搭建

初衷:之前在学习react的时候自己随便写了一个宿舍管理系统的出行demo,把基本的学生的操作页面基本都写好了,但是一直都没有写后台的东西,本来想找个人搞搞后台方面的,但是想到之前自己也学过一点nod...

Node.js利用Express框架搭建小型网站(上)

一、Express环境搭建 Express是Node.js下的一个轻量级W

Express + Mongoose 极简入门

今天尝试使用express + mongoose,构建了一个简单的Hello world,实现以下功能: 定义mongodb使用的Schema,一个User访问/输出Hello world访问/...

Express + MongoDB 搭建一个多人博客(node.js实战)

搭建多人博客的前置条件 Node.js: 6.9.1 MongoDB: 3.2.10 Express: 4.14.0 4.2.1 目录结构 我们停止 supervisor 并删除 my...

nodejs + express + ejs + mongodb 一个非常简单的前后端开发的实例3

CREATE OUR DB AND READ STUFF FROM IT  创建数据库并从中读取数据    A: 安装MongoDB数据库      We're leaving our text ed...

Node.js开发入门——MongoDB与Mongoose

介绍MongoDB的安装、mongo shell使用,以及如何在Node.js中使用Mongoose来访问MongoDB……...
  • foruok
  • foruok
  • 2015年08月18日 07:23
  • 35080

基于Express+mongoose搭建的学生管理系统

上一周学了下mongoose,虽然学了点皮毛,但还是想写写总结总结,这也是我的第一篇技术博客。还是蛮开心的,happy~~来,切入正题!项目源码我会放在github上。 github 地址代码...

nodejs+express+ejs+mongoose实例

http://www.cnblogs.com/flyoung2008/archive/2012/07/22/2603791.html nodejs学得异常痛苦,在这里将学的东西做一番整理,算...

nodejs+express+ejs+mongoose实例

nodejs学得异常痛苦,在这里将学的东西做一番整理,算是自我安慰吧。根据网上todo示例,用express和mongoose重写了部分代码,主要是业务逻辑这块(CRUD),这个没什么难度。目前尚未解...

node+express+mongoose快速搭建电影网站

本文主要是学习了Scott老师的建站攻略一的学习笔记。  1.搭建环境        使用node的npm工具进行安装前后端需要使用到的框架或类,搭建电影网站需要用到的框架如下:      ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:NodeJS+Express+Mongoose搭建网站系统
举报原因:
原因补充:

(最多只允许输入30个字)