1

私は単純なログアプリを構築しており、コードを読みやすくするためにモジュール性を実装しようとしました。ただし、アプリを起動すると問題が発生します。私は 2 つのファイルindex.jsを持っています。ここにサーバー構成がroutes.jsあり、ルーティング ロジックがある場所があります。私がルートを書いた方法は、hapi apiにある API ドキュメントに従っています。

次のエラーが発生する理由を誰かが理解してくれることを願っています:

/Users/mario/projects/loGym/node_modules/hapi/node_modules/hoek/lib/index.js:425
    throw new Error(msgs.join(' ') || 'Unknown error');
          ^
Error: Missing or undefined handler: /
    at Object.exports.assert (/Users/mario/projects/loGym/node_modules/hapi/node_modules/hoek/lib/index.js:425:11)
    at new module.exports.internals.Route (/Users/mario/projects/loGym/node_modules/hapi/lib/route.js:36:10)
    at /Users/mario/projects/loGym/node_modules/hapi/lib/router.js:110:25
    at Array.forEach (native)
    at /Users/mario/projects/loGym/node_modules/hapi/lib/router.js:107:17
    at Array.forEach (native)
    at internals.Router.add (/Users/mario/projects/loGym/node_modules/hapi/lib/router.js:104:13)
    at internals.Server._route (/Users/mario/projects/loGym/node_modules/hapi/lib/server.js:471:18)
    at internals.Server.route (/Users/mario/projects/loGym/node_modules/hapi/lib/server.js:465:10)
    at Object.<anonymous> (/Users/mario/projects/loGym/index.js:10:8)

モジュールを正しくエクスポートしていませんか?

これが私のコードですroutes.js

var path = require('path');
var _ = require('underscore');
var couchbase = require('couchbase');

//Connect to database.

var db = db || new couchbase.Connection({host: 'localhost:8091', bucket: 'default'}, function(err) {
    if (err) {
      console.log('Connection Error', err);
    } else {
      console.log('Connected!');
  }
 });
console.log(db);


module.exports = [
    {method: 'GET', path: '/static/{param*}', config: { handler: { directory: { path: 'static'}}}},
    {method: 'GET', path:'/', config: landingPage},
    {method: 'GET', path:'/workouts', config: getWorkouts},
    {method: 'GET', path:'/workouts/musclegroup', config: getMusclegroup},
    {method: 'POST', path:'/addworkout', config: addWorkout}
];



var landingPage = {
    handler: function(req, reply) {
        reply.file('index.html');
    }
};

var getWorkouts = {
    handler: function (req, reply) {
        // set options for databse query
        var q ={
          descending: true,
          stale: false
        };

        // show multiple exercises - db.view(designDocument, viewName, options)
        db.view('workout', 'exercise', q).query(function(err, values){
            // use pluck method from underscore to retrieve data
            var keys = _.pluck(values, 'id');
            console.log("Keys: " + keys);

            //fetch multiple documents based on the 'keys' object
            db.getMulti(keys, null, function(err, results){
                console.log('Results: ' + results);

                var workouts = [];
                for (var prop in results) {
                  workouts.push(results[prop].value);
                }
                reply(workouts);
            });
        });
    }
};


var getMusclegroup = {
  handler: function (req, reply) {
        var q = {
          descending: true,
          stale: false
        };

        db.view('workout', 'exercise', q).query(function(err, values){

            var keys = _.pluck(values, 'id');

            db.getMulti(keys, null, function(err, results){

                var muscleGroups = [];
                for (var prop in results) {
                    console.log(typeof results);
                    console.log(results[prop].value.workout);
                    muscleGroups.push(results[prop].value.workout);
                }
                reply(muscleGroups[0]);
            });
        });
    }
};


var addWorkout = {
    handler: function(req, reply){

      var d = new Date();
      var cd = d.getDate() + "-" + (d.getMonth()+1) + "-" + d.getFullYear();

      // sets schema for workout
      var payload = {
          "personId": "personId", //to later be replaced with actual username
          "date": cd,
          "workout": [
              {
                "exercise": req.query.exercise,
                "musclegoup": req.query.musclegroup,
                "sets": [
                  {
                    "reps": req.query.reps,
                    "kg": req.query.kg
                  }
                ]
              }
          ]
      };

      // defines unique key for data
      var key = payload.personId + payload.date;
      console.log(key);

      // adds payload to database
      db.add(key, payload, function(error, results){
          if (error) {
              console.log(error);
              reply(error + "\n");
          }
          console.log(results);
          reply(payload);
      });
    }
};

そして、これは私のコードですindex.js:

var Hapi = require('hapi');
var path = require('path');
var Joi = require('joi');
var rs = require('./lib/modules/routes.js');


var config= { };
var server = Hapi.createServer(process.env.PORT || 8080, config);

server.route(rs);

server.start(function(){
  console.log("Server started: " + server.info.uri);
});

module.exports = server;
4

1 に答える 1

1

landingPage、、、および変数が定義される前にgetWorkouts使用しようとしています。したがって、この問題を解決するには、単純に順序を変更し、最初にそれらの変数を定義してからルートを作成します。getMusclegroupaddWorkout

var landingPage = {
    ...
};

var getWorkouts = {
    ...
};

var getMusclegroup = {
    ...
};

var addWorkout = {
    ...
};

module.exports = [
    {method: 'GET', path: '/static/{param*}', config: { handler: { directory: { path: 'static'}}}},
    {method: 'GET', path:'/', config: landingPage},
    {method: 'GET', path:'/workouts', config: getWorkouts},
    {method: 'GET', path:'/workouts/musclegroup', config: getMusclegroup},
    {method: 'POST', path:'/addworkout', config: addWorkout}
];
于 2014-09-29T20:30:38.670 に答える