0

app.js ファイルのコードの詰め込みを少なくするために Express ルーターを使用しようとしていますが、正しい場所にルーティングするのに問題があります。

ルーティング先のページは localhost:5000/users/login ですが、代わりに localhost:5000/login をルーティングしています。

Brad Traversy の Udemy コースの Vidjot プロジェクトを参照して、同じ方法でセットアップしようとしましたが、コードは同じですが、うまくいかないようです。

以下は、ルーティングしようとしている app.js ファイルと私の users.js ファイルのコードです。

// Import and initialize express.
const express = require("express");
const app = express();

// Import necessary modules.
const mongoose = require("mongoose");
const path = require("path");
const exphbs = require("express-handlebars");

// Load routes.
// const gifs = require('./routes/gifs');
const users = require("./routes/users");

// Connect to mongoose.
mongoose
  .connect("mongodb://localhost/giphy-saver", {
    useMongoClient: true
  })
  .then(() => {
    console.log("MongoDB Connected...");
  })
  .catch(err => {
    console.log(err);
  });

// Static folder.
app.use(express.static(path.join(__dirname, "public")));

// Handlebars middleware.
app.engine(
  "handlebars",
  exphbs({
    defaultLayout: "main"
  })
);
app.set("view engine", "handlebars");

// Routes.

app.get("/", (req, res) => {
  res.render("index", { title: "Giphy Saver" });
});

app.get("/about", (req, res) => {
  res.render("about", { title: "About" });
});

// Use routes.
app.use("/users", users);

const PORT = process.env.PORT || 5000;

app.listen(PORT);

const express = require("express");
const mongoose = require("mongoose");
// Used for password encryption.
const bcrypt = require("bcryptjs");
// Used for authentication.
const passport = require("passport");
const router = express.Router();

// Load the User model.
require("../models/User");
const User = mongoose.model("users");

// User login route.
router.get("/login", (req, res) => {
  res.render("users/login", { title: "Login" });
});

// User registration route.
router.get("/register", (req, res) => {
  res.render("users/register", { title: "Register" });
});

module.exports = router;

予想される結果は、localhost:5000/users および localhost:5000/register ではなく、localhost:5000/users/login および localhost:5000/users/register にルーティングする必要があることです。表示されるエラー メッセージはありません。

4

1 に答える 1