Как сохранить данные, которые проходят через POST на некоторое время - PullRequest
0 голосов
/ 10 апреля 2020

У меня есть список продуктов, которые пришли из БД, все работает нормально, но мне нужно поймать идентификатор, когда кто-то нажимает «Купить» Я пытаюсь поймать de req.body, но сохранить невозможно.

Я пытался использовать SessionStorage и LocalStorage и не работает.

	carritoForm: (req, res) =>  {
		
		
		let obj = JSON.parse(JSON.stringify(req.body)); // req.body = [Object: null prototype] { title: 'product' }
		console.log(obj)
		res.redirect('index');
}	
<div class="container">
  <div class="row">
    <div class="col-sm-12 col-md-12 col-lg-12 bloques">
      <p>Incendios</p>
      <div class="imagen">
        <a href="" target="_blank"><img src="../images/fire.png" alt="" /></a>
      </div>
      <br>
      <p>Lorem ipsum dolor sit amet consectetur adipiscing elit elementum eget congue, tristique sollicitudin enim eu
        nisi ultrices iaculis justo scelerisque, phasellus vestibulum metus rhoncus sapien a integer odio ligula.
        Senectus parturient maecenas conubia netus pharetra felis placerat tincidunt, tortor fusce cras ligula nostra
        cursus augue duis lacinia, nascetur semper a habitasse euismod inceptos vivamus. Sociosqu ante neque morbi
        pulvinar habitasse enim himenaeos, ultrices per orci molestie nisi fames dignissim praesent, lacus iaculis class
        cursus mollis eros.</p>
    </div>

  </div>
  <div class="container">
    <div class="row">
      <br>
      <%  products.filter(function (el) { %>
      <%   return (el.prdCategId === 3); %>
      <% }).map(function(el) { %>
      <br>
      <div class="col-sm-12 col-md-12 col-lg-12 lista-productos">

        <div class="col-sm-4 col-md-4 imgcart">
          <img src="/images/prdImages/<%= el.image %>" alt="">
        </div>
        <br>
        <div class="col-sm-8 col-md-8 agregar-carrito">
          <br>
          <b>Descripcion:</b> <%=  el.description %> <br>
          <b>Precio: $</b> <%=  el.price %> <br> <br>
          
          <form name= 'compras' action="/products/incendios" method="POST" >
            <button name="incendios" value="<%=  el.id %>" type="submit">Buy</button>
          </form>
          <br>

          <br>
        </div>
      </div>

      <% }).sort(); %>

    </div>
  </div>
  
</div>

Когда я нажимаю 'Comprar', вывод правильный '{incend ios:' 2 '}', это соответствует кнопке, которую я нажимаю, но Я не знаю, как спасти это.

enter image description here

1 Ответ

0 голосов
/ 12 апреля 2020

Для контроллера:

	if (req.cookies.compra!=undefined) {
			console.log('Pisando datos')
			let contenidoCookie = JSON.parse(req.cookies.compra);  // Convierto el array en string para poder pushearle cosas
			contenidoCookie.push(req.body.item); // Le metés a ese array que recuperaste el contenido nuevo
			console.log(contenidoCookie)
			res.cookie('compra', JSON.stringify(contenidoCookie), { maxAge: (1000 * 60) * 10 }); // Volvés a setear la cookie
		} else {
			console.log('Creando datos por primera vez')
			let contenidoCookie =  [req.body.item]
			res.cookie('compra', JSON.stringify(contenidoCookie), { maxAge: (1000 * 60) * 10 }); // Seteo la cookie para que nunca mas sea undefined
		  }

И для промежуточного программного обеспечения:

function carrito(req, res, next) {
    let cookie = req.cookies.compra
    if(cookie != null) {
        console.log('La cookie ya existe')
    } else {
         // Crear la cookie
		let array=[];
		res.cookie('compra', JSON.stringify(array), { maxAge: (1000 * 60) * 5 });
		console.log('La Cookie fue creada')
	}
    next();
}
...