php - 调用第三个 session 变量后丢失前 2 个 session 变量 (php 5)

标签 php mysql session

这是我的案例(在 php 上相对较新):我有一个页面“zoek_form.php”,您可以在其中在表单中输入 2 个搜索值(naam 和 categorie)。提交后,将加载页面“zoek.php”并执行搜索(mysql 5.6)。为了执行搜索,从 2 个 session 变量中获取 2 个值。到目前为止一切顺利,搜索工作正常并且行被检索。 但现在我希望用户能够基于下拉列表在 zoek.php 中创建一个序列(通过 ORDER BY)。所选值将存储在第三个 session 变量中。但现在的问题是:当选择序列并提交表单时,前 2 个 session 值丢失。我很困惑为什么。 session 变量的本质只是存储值并能够反复使用它们? (直到它们被覆盖或杀死)。 当然我使用session_start();在 php 脚本的开头(否则它根本不会工作;-)。有什么想法吗?

这是 zoek_form.php:

<html>
<head>
<title>Zoeken</title>
</head>
<body>

<?php session_start(); ?>
<form name="form1" method="POST" action="zoek.php">
<table border="0">
<tr><td>Naam product:</td>
<td><input type="text" size="50" name="form_naam"></td></tr>
<tr><td>Categorie:</td>
<td><input type="text" size="50" name="form_cat"></td></tr>
<tr><td></td>
<td align = "right"><input type="submit" name="B1" value="Zoeken">
</td></tr>
</table>
</form>

</body>
</html>

这是 zoek.php:

<html>
<head>
<title>Zoeken</title>
</head>
<body>

<form name="form1" method="POST" action="">
<table border="0">
<tr><td>Sorteer op:</td>
<td><select name="form_sort">
  <option value="Naam">Naam</option>
  <option value="Categorie">Categorie</option>  
</select></td>
<td><input type="submit" name="B1" value="Sorteer"></td></tr>
</table>
</form>

<?php

session_start();
require_once 'test_connect.php';
$_SESSION['form_naam'] = $_POST['form_naam'];
$_SESSION['form_cat'] = $_POST['form_cat'];
$_SESSION['form_sort'] = $_POST['form_sort'];
// The 3 lines below were used to check whether session vars were set
// echo  $_SESSION['form_naam'];
// echo  $_SESSION['form_cat'];
// echo  $_SESSION['form_sort'];

function sorteren() {
global $sorteer;
$sorteer = $_SESSION['form_sort'];
  if ($sorteer == "Naam") {
  $sorteer = "ORDER BY naam";
  }
  else {
  $sorteer = "ORDER BY categorie";
  }
 }

// Put values from zoek_form.php in vars.
$naam = $_SESSION['form_naam'];
$cat = $_SESSION['form_cat'];

// Check if user has set a sequence. If yes: call function sorteren(),
// if no: leave var $sorteer empty.
if (isset($_SESSION['form_sort'])) {
sorteren();
}
else {
$sorteer = "";
}

// Get rows from table product
$sql = "SELECT * FROM product WHERE naam LIKE '$naam%' OR categorie
LIKE '$cat%' $sorteer";
$result = $conn -> query($sql);

if ($result->num_rows > 0) {
// here code to retrieve rows etc.    
}

// Give result free
$result -> free();

// Close connection
$conn -> close();

?>

</body>
</html>

最佳答案

您在 zoek.php 中的表单不包含 form_naamform_cat,因此当您运行时

$_SESSION['form_naam'] = $_POST['form_naam'];
$_SESSION['form_cat'] = $_POST['form_cat'];

它将这些值设置为 null。如果您想保留这些值,您可以尝试在带有隐藏输入字段的表单中再次将它们传回

<input type="hidden" name="form_naam" value="<?= $_SESSION['form_naam'] ?>">
<input type="hidden" name="form_cat" value="<?= $_SESSION['form_cat'] ?>">

防止覆盖 session 值的另一种方法是仅在设置了 $_POST 值时才更改它们

if(isset($_POST['form_naam']) && isset($_POST['form_cat'])) {
  $_SESSION['form_naam'] = $_POST['form_naam'];
  $_SESSION['form_cat'] = $_POST['form_cat'];
}

关于php - 调用第三个 session 变量后丢失前 2 个 session 变量 (php 5),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28197694/

相关文章:

php - Laravel 邮件中的 "Reply-to"字段不起作用

php - 使用 MySQL 数据库中的数据在 HTML 中创建表不起作用

javascript - 如何从 "Session"中的.html页面检查 `.NET`

ruby - Sinatra 中的 session 问题

php - 将数据上传到数据库时出现问题

python-3.x - python TLS套接字中的TLS session 恢复

PHP date() 不带前导零的小时、分钟和秒

php - PHP 中的广告管理系统?

php - Google Maps Store Finder 查询未正确返回

java - Spring Boot 中的 JDBC 授权