Перенаправление с использованием «чистого» Node.js из функции обратного вызова - PullRequest
0 голосов
/ 26 декабря 2018

Ниже приведен MCVE моего server.js кода:

let fs = require('fs');
let http = require('http');

http.createServer((req, res) => {
    // Handles GET requests
    if(req.method == 'GET') {
        let file = req.url == '/' ? './index.html': '/login.html'; // just an example
        fs.readFile(file, (err, data) => {
            res.writeHead(200, {'Content-Type': 'text/html'});
            res.end(data);
        });
    } 

    // Handles POST requests
    else {
        read(status => {
            if(status) {
                res.writeHead(302, {
                    'Location': 'http://localhost:8000/login.html',
                    'Content-Type': 'text/html'
                });
                res.end();
                console.log('Redirected!');
            }
        });
    }
}).listen(8000);

// In my actual script, the `read` function reads JSON files and sends data,
// so I've used the callback function
let read = callback => fs.readFile( './index.html', (err, data) => callback(true) );

И у меня есть два HTML-файла, упомянутых внутри кода.

index.html

<input type="submit" onclick='let xhr = new XMLHttpRequest(); xhr.open("POST", "http://localhost:8000"); xhr.send();'>

Я использовал встроенный скрипт, чтобы минимизировать трафик в моем MCVE.В целях разработки я буду использовать внешние скрипты на своем веб-сайте

login.html

<h1>Login</h1>

Теперь, когда я открываю http://localhost, index.html хорошо выглядит.Как вы заметили, index.html это просто кнопка.Итак, когда я нажимаю на эту кнопку, Ajax-запрос запускается успешно, и все работает нормально (без ошибок консоли), за исключением того, что страница не перенаправляет .Я не знаю, что идет не так или чего еще не хватает.

Я новичок в Node.js и читаю о перенаправлении в Nodejs - URL перенаправления и Какперенаправить URL браузера пользователя на другую страницу в Nodejs? , я много искал, но не смог получить подсказку по этому поводу.Спасибо за ваше время!

Также я знаю о экспрессе, но я не рассматриваю использование фреймворков, поскольку они скрывают основные понятия.

РЕДАКТИРОВАТЬ : Когда я пытаюсь перенаправить без концепции обратного вызова, он работает нормально, как это видео говорит нам.

Ответы [ 2 ]

0 голосов
/ 31 января 2019

Вы должны использовать экспресс при работе с веб-приложением узла js, если только у вас нет внутреннего понимания текущей версии узла, в которой вы используете предложение.

Экспресс прост, и ваш код будет выглядеть так (и перенаправить)

app.get('/index.html',function(req,res,next){
   res.redirect('/path/to/redirect/file')
}

ссылка: http://expressjs.com/en/4x/api.html#res.redirect

0 голосов
/ 26 декабря 2018

Это не проблема с node.js.Именно так ведут себя браузеры.

Ajax (XHR) не вызывает перенаправления в браузере.Когда браузеры внедрили браузер XHR, разработчики предположили, что вы хотите контролировать поведение обновления страницы.Поэтому они убедились, что XHR не запускает никаких действий по умолчанию.Все перенаправления будут молчать, и результирующие данные перенаправления будут переданы обратному вызову onreadystatechange вашего объекта XHR.

Если вы хотите, чтобы перенаправления вызывали обновление страницы, вы можете просто не использовать XHR.Вместо этого сделайте отправку формы:

<!-- index.html -->
<form action="http://localhost:8000" method="post">
    <input type="submit">
</form>

Если вместо этого вы хотите использовать AJAX, вам нужно будет выполнить перенаправление в браузере, как я упоминал выше:

// server.js

// ...

http.createServer((req, res) => {

    // ...

    // Handles POST requests
    else {
        read(status => {
            if(status) {
                res.writeHead(200, {'Content-Type': 'application/json'});
                res.end(JSON.stringify({
                    your_response: 'here'
                }));
            }
        });
    }
}).listen(8000);

Затем обработайте этоОтвет в браузере:

index.html

<input type="submit" onclick='let xhr = new XMLHttpRequest();xhr.addEventListener("load", function(){var response = JSON.parse(this.responseText);/* check response if you need it: */if (response.your_response === 'here') {window.location.href = 'http://localhost:8000/login.html';}});xhr.open("POST", "http://localhost:8000");xhr.send();'>

Но это безумие безобразно и почти невозможно прочитать.Я бы предложил рефакторинг этого HTML-кода примерно так:

<!-- index.html -->

<script>
    function handleSubmit () {
      let xhr = new XMLHttpRequest();
      xhr.addEventListener("load", function(){
        var response = JSON.parse(this.responseText);

        /* check response if you need it: */
        if (response.your_response === 'here') {
          window.location.href = 'http://localhost:8000/login.html'; // REDIRECT!!
        }
      });
      xhr.open("POST", "http://localhost:8000");
      xhr.send();
    }
</script>

<input type="submit" onclick="handleSubmit()">
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...