我觉得这很简单。我有一个像这样的 $_GET :
$cameFromCat = $_GET['cat'];
echo $cameFromCat;
这将按预期读出“卡片”,所以稍后我会这样要求它:
if ($_POST['submission'] == "Continue Shopping") {
Header("location: index.php?cat=" . $cameFromCat);
}
该链接将我发送到index.php?cat=
. 它不会读出“卡片”。但是,如果我对 var 进行硬编码,例如:
$cameFromCat = "Cards";
该链接将我发送到 index.php?cat=Cards
这真的让我发疯了。我究竟做错了什么?
更新:周围的代码:
$cart = $_SESSION['cart'];
$cameFromCat = $_GET['cat'];
$cameFromPage = $_GET['pagenum'];
$action = $_GET['action'];
$cardqty2 = $_POST['var'];
switch ($action) {
case 'add':
if ($cart) {
for ($i = 1; $i <= $cardqty2; $i++) {
$cart .= ','.$_GET['id'];
}
} else {
$cart = $_GET['id'];
for ($i = 2; $i <= $cardqty2; $i++) {
$cart .= ','.$_GET['id'];
}
}
break;
case 'delete':
if ($cart) {
$items = explode(',',$cart);
$newcart = '';
foreach ($items as $item) {
if ($_GET['id'] != $item) {
if ($newcart != '') {
$newcart .= ','.$item;
} else {
$newcart = $item;
}
}
}
$cart = $newcart;
}
break;
case 'update':
if ($_POST['submission'] == "Update") {
if ($cart) {
$newcart = '';
foreach ($_POST as $key=>$value) {
if (stristr($key,'qty')) {
$id = str_replace('qty','',$key);
$items = ($newcart != '') ? explode(',',$newcart) : explode(',',$cart);
$newcart = '';
foreach ($items as $item) {
if ($id != $item) {
if ($newcart != '') {
$newcart .= ','.$item;
} else {
$newcart = $item;
}
}
}
for ($i=1;$i<=$value;$i++) {
if ($newcart != '') {
$newcart .= ','.$id;
} else {
$newcart = $id;
}
}
}
}
}
$cart = $newcart;
break;
}
if ($_POST['submission'] == "Checkout") {
Header("Location: address.php");
}
if ($_POST['submission'] == "Continue Shopping") {
Header("location: index.php?cat=" . $cameFromCat);
}
}