php多维会话数组

时间:2014-05-12 19:26:25

标签: php forms

我正在尝试在数组上设置会话,但如果我离开页面并返回到它,我将得到错误,看起来我的会话没有保留数据。

  

警告:在第75行的/home5/onlinepc/public_html/action/subs/custompcorder.php中为foreach()提供的参数无效

     

注意:未定义的索引:第75行的/home5/onlinepc/public_html/action/subs/custompcorder.php中的数量   警告:在第75行的/home5/onlinepc/public_html/action/subs/custompcorder.php中为foreach()提供的参数无效....

 <?php
 session_start();
 ?>

 <?php

 foreach (array('part_id', 'quantity', 'price') as $pos) {
 foreach ($_POST[$pos] as $id => $row) {
$_POST[$pos][$id] = mysqli_real_escape_string($con, $row);
 }
}
$ids = $_POST['part_id'];
$quantities = $_POST['quantity'];
$prices =  $_POST['price'];

$_SESSION["cart_array"] = array();

$size = count($ids);

for($i = 0 ; $i < $size ; $i++){
// Check for part id
if (empty($ids[$i]) || empty($quantities[$i]) || empty($prices[$i])) {
continue;
}
$_SESSION["cart_array"][] = array(
"part_id"     => $ids[$i], 
"quantity"    => $quantities[$i],
"price"       => $prices[$i]
);
}

if (!empty($_SESSION["cart_array"])) {
$values = array();
foreach($_SESSION["cart_array"] as $item){
$values[] = "('{$item['part_id']}', '{$item['quantity']}',    '{$item['price']}','$orderid')";
}

$values = implode(", ", $values);

$sql = "INSERT INTO oz2ts_custompc_details (part_id, quantity, price,order_id) VALUES   {$values}    ;
" ;
$result = mysqli_query($con, $sql );
if ($result) {
echo 'Number of item selected: ' . mysqli_affected_rows($con)."<br/>";


} else {

echo 'query failed: ' . mysqli_error($con);

  }

  }

 }

?>

2 个答案:

答案 0 :(得分:1)

我认为你的代码与我正在做的事情非常相似。从导航回页面时我可以看到,每次再次加载页面时,您都会开始新的会话。尝试将其置于会话代码的开头。

if(!isset($_SESSION['cart_array'])){
$_SESSION['cart_array'] = array();
}

答案 1 :(得分:0)

将整个代码包装在另一个条件中,如下所示:

if (isset($_POST['part_id']) && isset($_POST['quantity]) && isset($_POST['price])) {
  foreach (array('part_id', 'quantity', 'price') as $pos) {
    // Your core code here.
  }
}