webdevqa.jp.net

Node.jsのapp.jsとindex.jsの違い

私はNodejsの初心者です。 routeディレクトリ内にapp.jsとindex.jsがあります。 app.use(multer....)があります。また、ファイルの内容を実際にサーバーにアップロードするapp.post('filter-reports')を定義しました。

実行するビジネスロジックがあり、routes/index.jsルートを構成する予定の/filter-reportsファイル内にルートを構成しました。私がどこで間違っているのか理解するのを手伝ってください。 multerを使用してファイルをアップロードする必要があります。また、index.jsファイルにあるビジネスロジックも実行します。

app.jsソースコード:

var express = require('express');
var path = require('path');
var favicon = require('static-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
var _ = require('underscore');
var cache = require('js-cache');
var multer  = require('multer');

var routes = require('./routes/index');
var users = require('./routes/users');

var app = express();

app.all('*', function(req, res, next) {
  res.header("Access-Control-Allow-Origin", "*");
  res.header("Access-Control-Allow-Headers", "X-Requested-With");
  next();
});


// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');

app.use(favicon());
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded());
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

app.use('/', routes);
app.use('/users', users);
var done=false;

app.use(multer({ dest: './uploads/',
rename: function (fieldname, filename) {
  return filename+Date.now();
},
onFileUploadStart: function (file) {
  console.log(file.originalname + ' is starting ...')
},
onFileUploadComplete: function (file) {
  console.log(file.fieldname + ' uploaded to  ' + file.path)
  done=true;
}
}));

// catch 404 and forward to error handler
app.use(function(req, res, next) {
  var err = new Error('Not Found');
  err.status = 404;
  next(err);
});

app.post('filter-reports',function(req,res){
console.log('Working on the filtered reports....');
  if(done==true){
    console.log(req.files);
    res.end("File uploaded.");
  }
});

/// 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);
    res.render('error', {
        message: err.message,
        error: err
    });
});
}

// 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: {}
  });
});


module.exports = app;





var express = require('express');
var request = require("request");
var _ = require('underscore');
var jscache = require('js-cache');
var schedule = require('node-schedule');
var filename;

Index.jsファイル内

var router = express.Router();

router.post('/filter-reports', function(req, res) {
  console.log('Came inside the Node js router.. Now.. its all up to me to format the data....');
    // console.log(req.files);
    //  console.log('Came insode the filter-reports app url >>>>');
    // if(done==true){
    // console.log(req.files);
    // console.log('Files uploaded succesfully ....');
    //res.end("File uploaded.");
    //  }
});

私のパッケージ構造は次のとおりです。

app.js  bin  node_modules  package.json  public  routes  views

私のpackage.jsonは

{
  "name": "nodetest1",
  "version": "0.0.1",
  "private": true,
  "scripts": {
  "start": "node ./bin/www"
 },
  "dependencies": {
  "express": "~4.2.0",
  "static-favicon": "~1.0.0",
  "morgan": "~1.0.0",
  "cookie-parser": "~1.0.1",
  "body-parser": "~1.0.0",
  "debug": "~0.7.4",
  "multer": "~0.1.6",
  "jade": "~1.3.0"
  }
}

よろしくお願いします、プラディープ

9
zilcuanu

フォルダをノードのrequire()に渡すと、エンドポイントのpackage.jsonがチェックされます。それが定義されていない場合は、index.jsをチェックし、最後にindex.node(C++拡張フォーマット)をチェックします。したがって、index.jsは、モジュールを要求するためのエントリポイントである可能性が最も高いです。

ここで確認できます http://nodejs.org/api/modules.html#modules_folders_as_modules

通常、アプリケーションのメインエントリポイントにはapp.jsを使用します。

6
DucDigital

私は解決策を見つけました。 router.useファイルでapp.useの代わりにindex.jsを使用しました。

2
zilcuanu