Ошибка: настройка заголовка после его отправки - помогите понять почему? - PullRequest
0 голосов
/ 25 ноября 2018

Я не понимаю, как установить заголовок после его отправки клиенту?

код: Во время отправки формы запрос post ajaxсделано, ответом является объект json, который возвращается клиенту.

Я закомментировал большую часть кода, чтобы выяснить, почему, на данный момент я делаю только один res.json ()после отправки запроса .Я не понимаю, в какой момент я переустанавливаю заголовок / или возвращаю ответ дважды?

ДА Я получаю эту ошибку:

Error [ERR_HTTP_HEADERS_SENT]: Cannot set headers after they are sent to the client
    at ServerResponse.setHeader (_http_outgoing.js:470:11)
    at ServerResponse.header (/home/shahyan/Videos/FrontendProject-masters/notes-js/beginner/js-fundamentals-functional/todoApp/node_modules/express/lib/response.js:767:10)
    at ServerResponse.send (/home/shahyan/Videos/FrontendProject-masters/notes-js/beginner/js-fundamentals-functional/todoApp/node_modules/express/lib/response.js:170:12)
    at done (/home/shahyan/Videos/FrontendProject-masters/notes-js/beginner/js-fundamentals-functional/todoApp/node_modules/express/lib/response.js:1004:10)
    at Object.exports.renderFile (/home/shahyan/Videos/FrontendProject-masters/notes-js/beginner/js-fundamentals-functional/todoApp/node_modules/pug/lib/index.js:412:12)
    at View.exports.__express [as engine] (/home/shahyan/Videos/FrontendProject-masters/notes-js/beginner/js-fundamentals-functional/todoApp/node_modules/pug/lib/index.js:455:11)
    at View.render (/home/shahyan/Videos/FrontendProject-masters/notes-js/beginner/js-fundamentals-functional/todoApp/node_modules/express/lib/view.js:135:8)
    at tryRender (/home/shahyan/Videos/FrontendProject-masters/notes-js/beginner/js-fundamentals-functional/todoApp/node_modules/express/lib/application.js:640:10)
    at Function.render (/home/shahyan/Videos/FrontendProject-masters/notes-js/beginner/js-fundamentals-functional/todoApp/node_modules/express/lib/application.js:592:3)
    at ServerResponse.render (/home/shahyan/Videos/FrontendProject-masters/notes-js/beginner/js-fundamentals-functional/todoApp/node_modules/express/lib/response.js:1008:7)

index.js

var express = require('express');
var router = express.Router();

let users = [];



/* GET home page. */
router.get('/', function(req, res, next) {

  res.render('index', { title: 'Express' });
});

router.post('/', function(req, res, next) {
  // check post valued are true
  if(req.body.fname && req.body.list_name && req.body.list_date) {
    // try {
       addNewUser(req.body);
       res.json({
         "message":"Successfully signed up!",
         "userName": req.body.fname,
         "userDate": req.body.list_date
        });
    // } catch(e){
      // signup failed
      // res.json(res.status(status).json(obj), "Sign up failed...");
    // }
   }
  //  if(req.body.list_item) {
  //    console.log(req.body.list_item);
  //  }
   console.log(body.req);

});
module.exports = router;

function addNewUser(data) {
  try {
    users.push(
      {
        "fname":data.fname,
        "list_name": data.list_name,
        "list_date": data.list_date
      }  
    );  
  } catch(e) {
    console.log("Failed to add user ", e);
      throw e;
  }

}

myscript.js --- клиентский клиент переднего плана

document.getElementById("createNewList").addEventListener('submit', function(e) {
    e.preventDefault();

    // serialize form to convert into JSOn object
    let form_data = formSerialize(document.getElementById("createNewList"));

     // AJAX fetch()
    fetch('/', {
        method: 'POST',
        headers: {
            "Content-Type": "application/json; charset=utf-8",
            // "Content-Type": "application/x-www-form-urlencoded",
        },
        body: form_data
    })
    .then(function(response) {      
         if(response.ok)
            return response.json();
    })
    .then(function(user_json) {
        console.log(user_json);

        console.log(user_json);
        create_todays_todo_list(user_json);
    });
});

// add event listener of the to do list i.e. adding tasks deleting tasks, completed tasks
// document.getElementById("toDoList_form").addEventListener('submit', function(e) {
    // e.preventDefault();
    // console.log("clikeddddddddd");
    // // AJAX send added task to server
    // let list_item = document.getElementById("list_item").innerHTML;
    // let user = document.getElementById("user_name_heading").innerHTML;
    // let data = {"user": user, "list_item": list_item}
    // console.log(data);
         // AJAX fetch()
        //  fetch('/', {
        //     method: 'POST',
        //     headers: {
        //         "Content-Type": "application/json; charset=utf-8",
        //         // "Content-Type": "application/x-www-form-urlencoded",
        //     },
        //     body: data
        // })
        // .then(function(response) {
        //      if(response.ok)
        //         return response.json();
        // })
        // .then(function(retrievedItemsFromServer) {
        //     console.log(retrievedItemsFromServer);
        // });

    //
// });


/// functionssss
// serialize form function
function formSerialize(form) {
    var input = form.getElementsByTagName("input");
    var formData = {};
    for (var i = 0; i < input.length; i++) {
      formData[input[i].name] = input[i].value;
    }
    return formData = JSON.stringify(formData);
  }
function create_todays_todo_list(user_json) {
    // 1. hide the create list form  form
    document.getElementById("createNewList").style.display="none";

    // 2. display the to do list div
    document.getElementById("toDoList").style.display="flex";

    // 3. display the user's name and date as logged in on the page
    document.getElementById("user_name_heading").innerHTML = user_json.userName;
    document.getElementById("user_date_signup_heading").innerHTML = user_json.userDate;

}

1 Ответ

0 голосов
/ 27 ноября 2018

console.log(body.req); это неправильно.Это должно быть console.log(req.body);.Обычно это происходит при выходе из программы, но, тем не менее, в стеке есть функция обратного вызова.Это должно исправить вашу проблему.Если это не так, пожалуйста, поделитесь журналом консоли, если напечатано любое

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...