我正在尝试在数组上设置会话,但如果我离开页面并返回到它,我将得到错误,看起来我的会话没有保留数据。
警告:在第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);
}
}
}
?>
答案 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.
}
}