当用户单击模式表中的记录时,我会尝试设置一个PHP $_SESSION变量。
模态表是通过执行while循环遍历SQL Server表中的记录来设置的。它看起来如下所示:
Value | Link
---------------------------
0 | <a href= changeVar.php?ficheNum=0></a>
1 | <a href= changeVar?ficheNum=1></a>
2 | <a href= changeVar?ficheNum=2></a>
...
当单击表中的一个链接时,它会运行以下代码:
<?php
$ficheNum=$_REQUEST['ficheNum'];
$_SESSION['ficheCount'] = $ficheNum;
header("Location: test.php");
?>
test.php页面只是一个包含输入的页面,其中填充了数据库表中的值。它还具有上面所示的模式表。test.php上的PHP如下。
$fiche_array = array();
$sel_query = "SELECT fiche
FROM test.dbo.[TLM.Fiche_Globale]
ORDER BY fiche ASC;";
$sel_result = sqlsrv_query($con, $sel_query) or die( print_r( sqlsrv_errors(), true));
while($sel_row = sqlsrv_fetch_array($sel_result)) {
array_push($fiche_array, $sel_row['fiche']);
}
if(isset($_POST['new']) && $_POST['new']==1)
{
$_SESSION['ficheCount'] ++;
}else if(isset($_POST['new2']) && $_POST['new2']==1)
{
$_SESSION['ficheCount'] = $_SESSION['ficheCount'] - 1;
}else if(isset($_SESSION['ficheCount']) && $_SESSION['ficheCount'] > 0)
{
$_SESSION['ficheCount'] = $_SESSION['ficheCount'];
}else{
session_start();
$_SESSION['ficheCount'] = 0;
}
if/else语句中的前两个语句用于操作next和previous record按钮。它们工作得很好。最后一条语句是在语句1-3都未被触发时运行的代码。如果用户从changeVar.php页面被重定向回页面,则会触发第三条语句。然而,这永远不会触发。或者,它触发并不做任何事情--我不确定。
我尝试过手动测试changeVar页面:
<?php
$ficheNum=$_REQUEST['ficheNum'];
$_SESSION['ficheCount'] = $ficheNum;
echo $_SESSION['ficheCount'];
?>
它将变量设置为正确的数字,但是,当我返回到test.php页面时,它总是默认返回到之前设置的ficheCount,就好像我从未在changeVar.php页面中设置过变量一样。
如果有人能看到我在这里做错了什么,我将不胜感激。
干杯,
发布于 2019-03-06 13:42:11
为了使用PHP会话,您总是需要在每个使用会话的PHP文件的开头运行命令session_start();
。http://php.net/manual/en/function.session-start.php
https://stackoverflow.com/questions/55024414
复制