zoukankan      html  css  js  c++  java
  • nodejs使用express4框架默认app.js配置说明

    var express = require('express');   //引入express模块
    var path = require('path');  //引入path模块,该模块包括了一些处理文件路径的功能
    var favicon = require('serve-favicon'); //图标缓存服务中间件
    var logger = require('morgan');  //HTTP请求日志中间件
    var cookieParser = require('cookie-parser'); //cookie操作中间件
    var bodyParser = require('body-parser');
    //body-parser插件用于post参数的解析,最常用的是其中的json和urlencoded的parser,可分别对以JSON格式的post参数和urlencoded的post参数进行解析,均可获得一个JSON化的req.body
    
    var routes = require('./routes/index');
    var users = require('./routes/users');//自定义路由模块的引用
    
    var app = express(); //创建一个 Express 应用。express()是一个由express模块导出的入口(top-level)函数。
    
    // view engine setup
    app.set('views', path.join(__dirname, 'views')); //设置views的目录,__dirname全局变量表示当前执行脚本所在的目录
    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')); //日志设置,使用参见https://github.com/expressjs/morgan
    app.use(bodyParser.json()); //解析JSON格式的post参数
    app.use(bodyParser.urlencoded({ extended: false })); //解析urlencoeded编码的post参数,URLEncoded编码中,所有的字符均为ANSCII码
    app.use(cookieParser()); //cookie设置
    app.use(express.static(path.join(__dirname, 'public'))); //静态目录设置
    
    //路由
    app.use('/', routes);
    app.use('/users', users);
    
    //捕捉404错误并进行错误处理
    app.use(function(req, res, next) {
      var err = new Error('Not Found');
      err.status = 404;
      next(err);
    });
    
    // error handlers
    
    //开发环境错误处理
    // will print stacktrace
    if (app.get('env') === 'development') {
      app.use(function(err, req, res, next) {
        res.status(err.status || 500);
        res.render('error', {
          message: err.message,
          error: err
        });
      });
    }
    
    //生产环境错误处理
    // no stacktraces leaked to user
    app.use(function(err, req, res, next) {
      res.status(err.status || 500);
      res.render('error', {
        message: err.message,
        error: {}
      });
    });
    
    
    module.exports = app;
  • 相关阅读:
    学习Vue.js
    Xmind思维导图
    Webpack 入门教程
    Vscode 使用介绍
    jdk,jre下载安装
    Java JDK下载
    FileZilla FTP下载
    notepad++下载
    windows环境搭建Vue开发环境
    SecureCRTPortable的安装和使用(图文详解)
  • 原文地址:https://www.cnblogs.com/fhen/p/5257467.html
Copyright © 2011-2022 走看看