【问题标题】:Cannot get / Error in MEAN stack application在 MEAN 堆栈应用程序中无法获取/错误
【发布时间】:2019-07-29 12:18:51
【问题描述】:

我正在关注 Heroku 的教程:https://devcenter.heroku.com/articles/mean-apps-restful-api 我在没有部署到 Heroku 服务器的情况下执行了每一步,并在我的本地主机中工作。 因此,当我使用端口 localhost/8080 打开我的应用程序时,我发现了 (Cannot Get / ) 的错误。 这是我的服务器代码:

var express = require("express");
var bodyParser = require("body-parser");
var mongodb = require("mongodb");
var ObjectID = mongodb.ObjectID;

var CONTACTS_COLLECTION = "contacts";

var app = express();
app.use(bodyParser.json());

// Create link to Angular build directory
var distDir = __dirname + "/dist/";
app.use(express.static(distDir));

// Create a database variable outside of the database connection callback to reuse the connection pool in your app.
var db;

// Connect to the database before starting the application server.
mongodb.MongoClient.connect(process.env.MONGODB_URI || "mongodb://localhost:27017/test", { useNewUrlParser: true }, function (err, client) {
  if (err) {
    console.log(err);
    process.exit(1);
  }

  // Save database object from the callback for reuse.
  db = client.db();
  console.log("Database connection ready");

  // Initialize the app.
  var server = app.listen(process.env.PORT || 8080, function () {
    var port = server.address().port;
    console.log("App now running on port", port);
  });
});

// CONTACTS API ROUTES BELOW

// Generic error handler used by all endpoints.
function handleError(res, reason, message, code) {
  console.log("ERROR: " + reason);
  res.status(code || 500).json({"error": message});
}

/*  "/api/contacts"
 *    GET: finds all contacts
 *    POST: creates a new contact
 */

app.get("/api/contacts", function(req, res) {
  db.collection(CONTACTS_COLLECTION).find({}).toArray(function(err, docs) {
    if (err) {
      handleError(res, err.message, "Failed to get contacts.");
    } else {
      res.status(200).json(docs);
    }
  });
});



app.post("/api/contacts", function(req, res) {
  var newContact = req.body;
  newContact.createDate = new Date();

  if (!req.body.name) {
    handleError(res, "Invalid user input", "Must provide a name.", 400);
  } else {
    db.collection(CONTACTS_COLLECTION).insertOne(newContact, function(err, doc) {
      if (err) {
        handleError(res, err.message, "Failed to create new contact.");
      } else {
        res.status(201).json(doc.ops[0]);
      }
    });
  }
});

/*  "/api/contacts/:id"
 *    GET: find contact by id
 *    PUT: update contact by id
 *    DELETE: deletes contact by id
 */

app.get("/api/contacts/:id", function(req, res) {
  db.collection(CONTACTS_COLLECTION).findOne({ _id: new ObjectID(req.params.id) }, function(err, doc) {
    if (err) {
      handleError(res, err.message, "Failed to get contact");
    } else {
      res.status(200).json(doc);
    }
  });
});

app.put("/api/contacts/:id", function(req, res) {
  var updateDoc = req.body;
  delete updateDoc._id;

  db.collection(CONTACTS_COLLECTION).updateOne({_id: new ObjectID(req.params.id)}, updateDoc, function(err, doc) {
    if (err) {
      handleError(res, err.message, "Failed to update contact");
    } else {
      updateDoc._id = req.params.id;
      res.status(200).json(updateDoc);
    }
  });
});

app.delete("/api/contacts/:id", function(req, res) {
  db.collection(CONTACTS_COLLECTION).deleteOne({_id: new ObjectID(req.params.id)}, function(err, result) {
    if (err) {
      handleError(res, err.message, "Failed to delete contact");
    } else {
      res.status(200).json(req.params.id);
    }
  });
});

PS:当我运行命令 ng serve: 主页显示但与数据库没有连接它只是一个静态页面..请帮助 我是这种卑鄙语言的初学者。

【问题讨论】:

  • 您没有任何与/匹配的路由。
  • 我知道我想将我的主路由添加到我运行 ommand ng serve 时显示的页面,但我不知道如何

标签: node.js angular express mean-stack


【解决方案1】:

它似乎遗漏了您的服务器代码中的一部分。 你已经配置了你的 API 部分,它可以被你的 Angular 应用调用,但是你没有为你的 Angular 应用提供服务。

您应该收听所有 GET 请求并将您的 index.html 仅作为文件发送,该文件实际上应该包含您的 Angular SPA。 像这样的:

app.get('*', (req, res) => {
  res.sendFile(path.join(__dirname, 'index.html'));    
});

您可以查看 Express 文档:http://expressjs.com/fr/api.html#res.sendFile

【讨论】:

  • 我的 Friedn 怎么样,我完全是初学者,我应该为明天之后的演示准备这项工作:/
猜你喜欢
  • 2017-03-09
  • 2020-01-19
  • 2019-11-24
  • 2021-02-25
  • 1970-01-01
  • 1970-01-01
  • 2017-03-18
  • 1970-01-01
  • 2015-10-29
相关资源
最近更新 更多