在另一个PHP文件中访问POST变量

时间:2013-01-15 13:45:06

标签: php mysql sql forms variables

  

可能重复:
  Simplest method of passing one php variable in a url

我正在进行测验申请。在教师端,教师可以输入主题名称(我将用它来形成虚荣URL),并输入3个问题,其中包括可能的选项,包括其中一个答案。每当教师创建测验时,每次都会创建一个包含问题,选项和答案的新表格。

我的db.php文件:

<?php
mysql_connect("localhost","root","");
mysql_select_db("quiz");
?>

我的faculty.php文件:

<form action="fac_handler.php" method="POST">
Quiz Topic:<br><input type="text" name="topic"><br><br>Enter Questions:<br><br>
<?php
$a="a";
$b="b";
$c="c";
$d="d";
for ($i=1; $i<=3;$i++) 
{ 
?>
Question <?php echo $i?>:<br>
<textarea type="text" name="<?php echo "q".$i;?>"></textarea><br>
<br>
<input type="text" name="<?php echo $a.$i; ?>">&nbsp;&nbsp;
<input type="text" name="<?php echo $b.$i; ?>">&nbsp;&nbsp;
<input type="text" name="<?php echo $c.$i; ?>">&nbsp;&nbsp;
<input type="text" name="<?php echo $d.$i; ?>">&nbsp;&nbsp;<br><hr>
<?php
}
?>
<br>
<input type="submit" value="Submit">
</form>

我的fac_handler.php文件:

<?php
require "db.php";

if(isset($_POST['topic']) && !empty($_POST['topic']))
{
$topic=$_POST['topic'];

if(isset($_POST['q1'])&&isset($_POST['a1'])&&isset($_POST['b1'])&&isset($_POST['c1'])&&isset($_POST['d1'])) 
{
if(!empty($_POST['q1']) && !empty($_POST['a1']) && !empty($_POST['b1']) && !empty($_POST['c1']) && !empty($_POST['d1'])) 
{
$q1=$_POST['q1'];
$a1a=$_POST['a1'];
$a1b=$_POST['b1'];
$a1c=$_POST['c1'];
$a1d=$_POST['d1'];  
}
else
{
    echo "Please Set the Questions and the Options!";
    die();
}
} 
if(isset($_POST['q2'])&&isset($_POST['a2'])&&isset($_POST['b2'])&&isset($_POST['c2'])&&isset($_POST['d2']))
{
if(!empty($_POST['q2']) && !empty($_POST['a2']) && !empty($_POST['b2']) && !empty($_POST['c2']) && !empty($_POST['d2']))
{
$q2=$_POST['q2'];
$a2a=$_POST['a2'];
$a2b=$_POST['b2'];
$a2c=$_POST['c2'];
$a2d=$_POST['d2'];  
}
else
{
    echo "Please Set the Questions and the Options!";
    die();
}
}
if(isset($_POST['q3'])&&isset($_POST['a3'])&&isset($_POST['b3'])&&isset($_POST['c3'])&&isset($_POST['d3']))
{
if(!empty($_POST['q3']) && !empty($_POST['a3']) && !empty($_POST['b3']) && !empty($_POST['c3']) && !empty($_POST['d3']))
{
$q3=$_POST['q3'];
$a3a=$_POST['a3'];
$a3b=$_POST['b3'];
$a3c=$_POST['c3'];
$a3d=$_POST['d3'];  
}
else
{
    echo "Please Set the Questions and the Options!";
    die();
}
}  
$ans1=$a1a;
$ans2=$a2a;
$ans3=$a3a;

$qtbname="q_".$topic;
$top=$_SESSION['topic']=serialize($_POST['topic']);
$new="q_".$top;

$create_table="CREATE TABLE $qtbname(id int NOT NULL AUTO_INCREMENT,question VARCHAR(500),answer VARCHAR(30),optiona VARCHAR(30),optionb VARCHAR(30),optionc VARCHAR(30),optiond VARCHAR(30),PRIMARY KEY (id))";
mysql_query($create_table);

$query1="INSERT INTO $qtbname VALUES('','$q1','$ans1','$a1a','$a1b','$a1c','$a1d')";
$query2="INSERT INTO $qtbname VALUES('','$q2','$ans2','$a2a','$a2b','$a2c','$a2d')";
$query3="INSERT INTO $qtbname VALUES('','$q3','$ans3','$a3a','$a3b','$a3c','$a3d')";

$result1=mysql_query($query1);
$result2=mysql_query($query2);
$result3=mysql_query($query3);

header("Location: student.php");
}
else
{
    echo "Please Set the Quiz Topic";
}
?>

现在您可以看到,在每次使用表前缀动态创建表后,它会被重定向到student.php文件,如下所示。

我的student.php文件:

<?php
require "db.php";

$query="SELECT * FROM $new";
$result=mysql_query($query);
$n="1";
$i="a";

while($row=mysql_fetch_assoc($result))
{
echo "Question ".$n." : ".$row['question'];
echo "<br>";
$ansr=$row['answer'];
?>
<form action="std_handler.php" method="POST">
<input type="radio" name="<?php echo $i; ?>" value="<?php echo $row['optiona']; ?>"><?php echo $row['optiona']; ?>
<input type="radio" name="<?php echo $i; ?>" value="<?php echo $row['optionb']; ?>"><?php echo $row['optionb']; ?>
<input type="radio" name="<?php echo $i; ?>" value="<?php echo $row['optionc']; ?>"><?php echo $row['optionc']; ?>
<input type="radio" name="<?php echo $i; ?>" value="<?php echo $row['optiond']; ?>"><?php echo $row['optiond']; ?><br>
<?php
++$i;
++$n;
}
?>
<input type="submit" value="Submit">
</form>

这个student.php文件中的第四行,查询 $ query =“SELECT * FROM $ new”; ,我需要访问我刚才在教师端创建的表以文本和单选按钮格式显示问题和答案。

这是我的std_handler.php文件:

<?php
if(isset($_POST['a']))
{
$ans=$_POST['a'];
echo $ans;
echo "<br>";
}
if(isset($_POST['b']))
{
$ans=$_POST['b'];
echo $ans;
echo "<br>";
}
if(isset($_POST['c']))
{
$ans=$_POST['c'];
echo $ans;
echo "<br>";
}
?>

在教师处理程序文件中,经过验证后,我尝试使用session并获取变量,我尝试将其设置为全局,我尝试将其序列化,我无法成功使用并选择动态表名称student.php页面。

我想要的是,一旦我被重定向到student.php页面,我想选择之前立即创建的表格,我该怎么做?如何访问我创建表的变量并在教师端执行查询?

我不断收到此错误:注意:未定义的变量:第4行的C:\ xampp \ htdocs \ quiz \ student.php中的新内容

请帮我解决这个问题。谢谢。

3 个答案:

答案 0 :(得分:3)

你想要这样的东西:

解决方案不好,但您可以看到如何传递变量

在fac_handler.php中:

更改

header("Location: student.php");

header("Location: student.php?url=". urlencode($new));

在学生页面上:

$query="SELECT * FROM " . mysql_real_escape_string($_GET["url"]);

这是一种方法,但如果我在哪里,我会以其他方式执行此操作。

我将如何做到这一点

创建您发送的ID并将该名称解析为数据库名称。

答案 1 :(得分:1)

如果我不得不猜我会说这个。当它给你这个错误:注意:未定义的变量:第4行的C:\ xampp \ htdocs \ quiz \ student.php中的新,因为它就是这样。如果我们在这里查看代码:

require "db.php";

$query="SELECT * FROM $new";
$result=mysql_query($query);
$n="1";
$i="a";

这是你的student.php ^^^

您没有设置$ new的值。

所以你需要实际定义价值。

$new = $_GET['x'];
$query="SELECT * FROM $new";
$result=mysql_query($query);
$n="1";
$i="a";

其中x是您传递的任何查询值。

或类似的东西。

答案 2 :(得分:0)

好的,我解决了这个问题,这就是我所做的。

我从fac_handler.php页面删除了这两个:

$top=$_SESSION['topic']=serialize($_POST['topic']);
$new="q_".$top;

下面列出了几个,我将标题位置更改为:

header("Location: student.php?url=".$qtbname); 

在student.php页面中,我将查询更改为:

$query="SELECT * FROM " . mysql_real_escape_string($_GET["url"]);

对于上面的最后两个修改,我真诚地感谢劳伦斯。 Thunda也非常感谢我给出了使用GET变量的想法。

deceze和tim.baker(评论中有):非常感谢你的建议,既然我解决了我的问题,我会按照你的建议继续进行规范化。

非常感谢stackoverflow,很长一段时间都在苦苦挣扎。