POST Route к END Route - PullRequest
       13

POST Route к END Route

0 голосов
/ 05 сентября 2018

Я создаю веб-сайт Node.JS и мне нужно изменить текущий маршрут GET на POST. Как мне успешно сделать преобразование. Моя текущая ошибка: «Cannot GET /». Тогда мне нужно, чтобы POST Route достиг маршрута GET.

const express = require('express');
const path = require('path');
const hbs = require('express-handlebars');

// Moment.js
var moment = require('moment');

// Init App
const app = express();

// Json File
const json = require("./data.json");

// Javascript Files
const welcomeTime = require('./public/javascript/welcomeTime');

// Load View Engine
app.engine('hbs', hbs({extname: 'hbs', defaultLayout: 'layout', 
layoutsDir: __dirname + '/views/layouts/'}));
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'hbs');
app.use(express.static(__dirname+'/public'));

// GET Route
// app.get('/', function(req, res){
//     res.render('index', {
//         title: 'NodePark',
//         hotel: 'NodePark',
//         firstName: json.payload.data.Source_FirstName,
//         lastname: json.payload.data.Source_LastName,
//         date: moment().format('ll'),
//         time: moment().format('LT'),
//         currentHour: welcomeTime.dayTime()
//     });
// });

// POST Route
app.post('/', function(req, res){
    res.render('index', {
        title: 'NodePark',
        hotel: 'NodePark',
        firstName: json.payload.data.Source_FirstName,
        lastname: json.payload.data.Source_LastName,
        date: moment().format('ll'),
        time: moment().format('LT'),
        currentHour: welcomeTime.dayTime()
    });
});

// Start Server
app.listen(5000, function(){
    console.log('Port 5000 open for business.');
});

Я включил мой рабочий маршрут GET и попытку POST Route. Я не понимаю, почему это не работает.

layout.hbs ниже

<!doctype HTML>
<html lang="en">
<head>
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta charset="UTF-8">
    <title>{{ title }}</title>
    <link href="https://fonts.googleapis.com/css?family=Fanwood+Text:400i" rel="stylesheet">        
    <link href="https://fonts.googleapis.com/css?family=Lora" rel="stylesheet">
    <link rel="stylesheet" href="/stylesheets/style.css">
    <style>li span { position: relative; left: -8px; }</style>
</head>
<body>
    {{{ body }}}
</body>
</html>

index.hbs ниже

    <div id="body-container">
    <div id="header">
        <div id="logo-content">
            <div id="logo"></div>
        </div>
        <div id="welcome">
            <p>Good {{ currentHour }} {{ firstName }} {{ lastname }}. We hope your stay is comfortable & relaxing.</p>
        </div>
        </div>
        {{!-- <div id="time-side">
            <div id="time-content">
                <p> {{ date }} <br> {{ time }} </p>
            </div>
        </div> --}}
    </div> 
    {{!-- end of header --}}

    <div id="background">
        <img src="images/villaView.jpg" alt="villaView">
    </div>

    <div id="footer">
        <p> <br> &copy; 2018 NodePark </p>
    </div>

Моя цель - создать конечную точку, в которой будет идти от маршрута POST к маршруту GET.

1 Ответ

0 голосов
/ 05 сентября 2018

В вашем обработчике сообщений позвоните res.redirect("<new-url>"), чтобы перенаправить пользователя на <new-url>.

// POST Route
app.post('/', function(req, res){
    // store the incoming data somewhere, e.g. in a cookie-based session
    res.redirect('/');
});

// GET Route
app.get('/', function(req, res){
    // retrieve the posted data from somewhere, e.g. from a cookie-based session
    res.render('index', { ... });
});
...