2016-09-02 25 views
0

私の/router/index.jsファイルがひどく混雑し始めています。グループ(ユーザルート、ポストルート、ギアルート)別のルートを/router/routes/に自分のファイルに分割したいと考えていました。ここで私は、現在の作業を持っているものです。タイプ別にノード/エクスプレスルートを別々のファイルにグループ化するにはどうすればいいですか?

app.js私はすべて入れてのいくつかの異なる方法を試してみました

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

// database connection 
require('./models/posts'); 
require('./models/Comments'); 
require('./models/Users'); 
require('./models/Gear'); 
//mongoose.Promise = global.Promise; 
mongoose.connect('mongodb://localhost/news'); 

var router = require('./router'); 
var app = express(); 

app.use('/', router); 

// login setup 
require('./config/passport'); 
app.use(passport.initialize()); 

// logger 
// create a write stream (in append mode) 
var accessLogStream = fs.createWriteStream(__dirname + '/access.log', {flags: 'a'}) 
// setup the logger 
app.use(logger('combined', {stream: accessLogStream})) 
app.use(logger('dev')); 

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

// TODO: add favicon 
//app.use(favicon(path.join(__dirname, 'public', 'favicon.ico'))); 
app.use(bodyParser.json()); 
app.use(bodyParser.urlencoded({ extended: false })); 
app.use(cookieParser()); 
app.use(express.static(path.join(__dirname, 'public'))); 

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

// 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 
// don't print stacktraces for user 
app.use(function(err, req, res, next) { 
    res.status(err.status || 500); 
    res.render('error', { 
    message: err.message, 
    error: {} 
    }); 
}); 


module.exports = app; 

/router/index.js

var express = require('express'); 
var fs = require('fs'); 
var router = express.Router(); 
var mongoose = require('mongoose'); 
var Post = mongoose.model('Post'); 
var Comment = mongoose.model('Comment'); 
var Gear = mongoose.model('Gear'); 
var passport = require('passport'); 
var jwt = require('express-jwt'); 


var User = mongoose.model('User'); 
var auth = jwt({secret: 'SECRET', userProperty: 'payload'}); 

/* GET home page. */ 
router.get('/', function(req, res, next) { 
    res.render('index', { title: 'Express' }); 
}); 

/* 
* Posts routes 
*/ 

/* GET all posts */ 
router.get('/posts', function(req, res, next) { 
    Post.find(function(err, posts) { 
    if (err) return next(err); 
    res.json(posts); 
    }) 
}); 

/* POST add new post */ 
router.post('/posts', auth, function(req, res, next) { 
    var post = new Post(req.body); 
    post.author = req.payload.username; 

    post.save(function(err, post) { 
    if (err) return next(err); 
    res.json(post); 
    }) 
}); 

/* preload post */ 
router.param('post', function(req, res, next, id) { 
    var query = Post.findById(id); 

    query.exec(function(err, post) { 
    if(err) return next(err); 
    if (!post) return next(new Error('can\'t find post')); 

    req.post = post; 
    return next(); 
    }) 
}); 

/* GET single post */ 
router.get('/posts/:post', function(req, res, next) { 
    req.post.populate('comments', function(err, post) { 
    if (err) { return next(err); } 

    res.json(post); 
    }); 
}); 

/* PUT upvote a post */ 
router.put('/posts/:post/upvote', auth, function(req, res, next) { 
    req.post.upvote(function(err, post) { 
    if (err) return next(err); 
    res.json(post); 
    }) 
}); 

/* PUT downvote a post */ 
router.put('/posts/:post/downvote', auth, function(req, res, next) { 
    req.post.downvote(function(err, post) { 
    if (err) return next(err); 
    res.json(post); 
    }) 
}); 

/* 
* Comment routes 
*/ 

/* POST comment on single post */ 
router.post('/posts/:post/comments', auth, function(req, res, next) { 
    var comment = new Comment(req.body); 
    comment.post = req.post; 
    comment.author = req.payload.username; 

    comment.save(function(err, comment){ 
    if(err){ return next(err); } 

    req.post.comments.push(comment); 
    req.post.save(function(err, post) { 
     if(err){ return next(err); } 

     res.json(comment); 
    }); 
    }); 
}); 

/* preload comment */ 
router.param('comment', function(req, res, next, id) { 
    var query = Comment.findById(id); 

    query.exec(function(err, comment) { 
    if(err) return next(err); 
    if (!comment) return next(new Error('can\'t find comment')); 

    req.comment = comment; 
    return next(); 
    }) 
}); 

/* GET single comment */ 
router.get('/posts/:post/comments/:comment', function(req, res) { 
    res.json(req.comment); 
}); 

/* PUT upvote comment on a post */ 
router.put('/posts/:post/comments/:comment/upvote', auth, function(req, res, next) { 
    req.comment.upvote(function(err, comment) { 
    if (err) return next(err); 
    res.json(comment); 
    }) 
}); 

/* PUT downvote a comment on a post */ 
router.put('/posts/:post/comments/:comment/downvote', auth, function(req, res, next) { 
    req.comment.downvote(function(err, comment) { 
    if (err) return next(err); 
    res.json(comment); 
    }) 
}); 

/* 
* User routes 
*/ 

/* POST Create User */ 
router.post('/register', function(req, res, next) { 
    if(!req.body.username || !req.body.password) { 
    return res.status(400).json({message: "Please fill out all fields"}); 
    } 

    var user = new User(); 
    user.username = req.body.username; 
    user.setPassword(req.body.password); 

    user.save(function(err) { 
    if (err) return next(err); 

    return res.json({token: user.generateJWT()}) 
    }); 
}); 

/* POST login page */ 
router.post('/login', function(req, res, next){ 
    if(!req.body.username || !req.body.password){ 
    return res.status(400).json({message: 'Please fill out all fields'}); 
    } 

    passport.authenticate('local', function(err, user, info){ 
    if(err){ return next(err); } 

    if(user){ 
     return res.json({token: user.generateJWT()}); 
    } else { 
     return res.status(401).json(info); 
    } 
    })(req, res, next); 
}); 

/* 
* Gear routes 
*/ 

/* GET all gear */ 
router.get('/gear', function(req, res, next) { 
    Gear.find(function(err, gear) { 
    if (err) return next(err); 
    res.json(gear); 
    }) 
}); 

/* preload gear item */ 
router.param('item', function(req, res, next, id) { 
    var query = Gear.findById(id); 

    query.exec(function(err, item) { 
    if(err) return next(err); 
    if (!item) return next(new Error('can\'t find item')); 

    req.item = item; 
    return next(); 
    }) 
}); 

/* GET single gear item */ 
router.get('/gear/:item', function(req, res, next) { 
    req.item.populate('item', function(err, item) { 
    if (err) { return next(err); } 

    res.json(item); 
    }); 
}); 

/* POST add new gear */ 
router.post('/gear', auth, function(req, res, next) { 
    var gear = new Gear(req.body); 
    gear.owner = req.payload.username; 

    gear.save(function(err, gear) { 
    if (err) return next(err); 
    res.json(gear); 
    }) 
}); 

/* DELETE single gear item */ 
router.delete('/gear/:item/delete', auth, function(req, res, next) { 
    var query = Gear.findById(req.item, function(err, item) { 
    if (err) { return next(err) }; 
    item.remove(); 
    }).exec(); 

    return res.json(); 
}); 

module.exports = router; 

は、 posts/router/routes/post-routes.jsのルートは次のようになります。

var express = require('express'); 
var router = express.Router(); 
var jwt = require('express-jwt'); 
var auth = jwt({secret: 'SECRET', userProperty: 'payload'}); 

/* 
* Posts routes 
*/ 

/* GET all posts */ 
router.get('/posts', function(req, res, next) { 
    Post.find(function(err, posts) { 
    if (err) return next(err); 
    res.json(posts); 
    }) 
}); 

/* POST add new post */ 
router.post('/posts', auth, function(req, res, next) { 
    var post = new Post(req.body); 
    post.author = req.payload.username; 

    post.save(function(err, post) { 
    if (err) return next(err); 
    res.json(post); 
    }) 
}); 

/* preload post */ 
router.param('post', function(req, res, next, id) { 
    var query = Post.findById(id); 

    query.exec(function(err, post) { 
    if(err) return next(err); 
    if (!post) return next(new Error('can\'t find post')); 

    req.post = post; 
    return next(); 
    }) 
}); 

/* GET single post */ 
router.get('/posts/:post', function(req, res, next) { 
    req.post.populate('comments', function(err, post) { 
    if (err) { return next(err); } 

    res.json(post); 
    }); 
}); 

/* PUT upvote a post */ 
router.put('/posts/:post/upvote', auth, function(req, res, next) { 
    req.post.upvote(function(err, post) { 
    if (err) return next(err); 
    res.json(post); 
    }) 
}); 

/* PUT downvote a post */ 
router.put('/posts/:post/downvote', auth, function(req, res, next) { 
    req.post.downvote(function(err, post) { 
    if (err) return next(err); 
    res.json(post); 
    }) 
}); 

module.exports = router; 
に以下と

module.exports = function(app) { 
    var routeFiles = fs.readdirSync(__dirname) 

    routeFiles.forEach(function(file) { 
     if (file === "index.js" || file.substr(file.lastIndexOf('.') + 1) !== 'js') 
      return; 
     var name = file.substr(0, file.indexOf('.')); 
     require('./' + name)(app); 
    }); 
} 

この時点で、私はちょうど私が行方不明ですか分かりません。それはあなたの/router/index.jsであれば、あなたは

var path = require('path') 

// ... 

var routeFiles = fs.readdirSync(path.join(__dirname, 'routes')) 

代わりの

var routeFiles = fs.readdirSync(__dirname) 

そうでなければ、あなたがなりが必要になり

app.js 
/router 
    - index.js 
    /routes 
     - post-routes.js 
     - user-routes.js 
     - comment-routes.js 

答えて

1

:私の目標のファイル構造はこのことでしょう間違ったディレクトリリスト(/ router/routesの代わりに/ router)を読んでください。

また、経路が正しくなるように('./routes/' + name)、経路のrequire()を適切に変更する必要があります。

最後に、./router/routes/ファイルはルータをエクスポートするだけで、appという機能をエクスポートするものではなく、./router/index.jsが期待していないものです。

  • 変更appにそのルータを追加する機能をエクスポートするために、各./router/routes/ファイルのエクスポート:

    module.exports = function(app) { 
        app.use(router); 
    }; 
    
  • 変更ですから、2つのいずれかを行うことができます。機能として、モジュールの輸出を呼び出す代わりにappに輸出をマウントしないように/router/index.jsファイル:

    app.use(require('./routes/' + name)); 
    
+0

よろしく!正しい方向への移動。私はそれを変更し、 'require( './' name)(app);をrequire( './ routes /' + name(app)) 'に変更しました。 私は今 未定義例外TypeErrorの「適用」 '' 'プロパティを読み取ることができませんを取得しています:/ユーザー/ grahamlutz /ドキュメント/個人/練習/私の仮想パック/で未定義 のプロパティを読み取ることができません。「適用」 node_modules/express/lib/router/index.js:618:14 ... '' ' – BigBadBigBad

+0

これ以外の何かをapp.jsで行う必要はありますか? 'var router = require( './ router'); app.use( '/'、router); ' – BigBadBigBad

+0

私の回答を更新しました – mscdex

関連する問題