将用户输入数据保存在多页 php 表单中

Posted

技术标签:

【中文标题】将用户输入数据保存在多页 php 表单中【英文标题】:save user input data in multiple page php form 【发布时间】:2014-10-03 10:21:58 【问题描述】:

我在 php 中有一个多页表单。我还创建了一个登录页面,其中用户名和密码存储在会话中(我使用了this tutorial)。现在,我对这些事情有点困惑:

    我想让用户从上次保存的会话中填写表格(例如,在计算机或浏览器崩溃、互联网连接失败等情况下,他不会重写他之前插入的所有数据) .

    另外,我不确定如何将每个用户插入的数据存储在 mysql 表中。如果我只是将所有用户的答案插入到一个包含以下字段的表中(比如说“答案”)是否可以:Unique_Id、UserId、问题 1、问题 2、...)?或者,最好将每个表中的数据插入到具有相同设计的单独表中,例如表 1:(userId, q1, q2,.., q5),表 2:(userId, q6,q7, ..q10) 等等。

这是其中一个表单页面的代码(Page2,其他页面类似)

<?php
session_start();

 // Checking first page values for empty,If it finds any blank field then redirected to first page.
 if (isset($_POST['submit1']))
 if (empty($_POST['q1'])
 || empty($_POST['q2'])
 || empty($_POST['q5'])
 || empty($_POST['q6']))

 // Setting error message
  $_SESSION['error'] = "Mandatory field(s) are missing, Please fill it again";
  header("location: page1.php"); // Redirecting to first page 
   else 

   foreach ($_POST as $key => $value) 
       if (is_array($_POST[$key]))
            $_SESSION['post'][$key] = implode(',', $_POST[$key]);
         
       else
            $_SESSION['post'][$key] = $value;
        
   
  
   else 
  if (empty($_SESSION['error_page2'])) 
  header("location: page1.php");// Redirecting to first page.
  
 
?> 

<html>
<head>
<link type="text/css" rel="stylesheet" href="style.css" media=screen>

<style>
.error 
 color: #FF0000;

 
</style>

</head>

<body>
 <div id="show">   

<span id="error">
<!---Initializing Session for errors-->
<?php
if (!empty($_SESSION['error_page2'])) 
 echo $_SESSION['error_page2'];
 unset($_SESSION['error_page2']);
 
 ?>
 </span>

 <form id="form2" action="page3.php" method="post">

<div class="meter"><span style="width: 40%">Step 2</span></div>
<fieldset id = "Form_Questions"> 
<fieldset id = "q8"> <legend class="Q8"></legend>
<label class="question"> What are your favourite genres of movies?<span>*</span></label>
<div class="fieldset content"> 

<style type="text/css">
.checkbox-grid li 
display: block;
float: left;
width: 25%;
margin-bottom:5px; 
     
</style>

<title>Survey Form</title>
 <meta http-equiv="content-Type" content="text/html: charset=UTF-8" /
 <ul class="checkbox-grid">
<li><input type="checkbox" name="q8[]" value="Action"><label for="checkgenre[]">Action</label><span></span></li>
<li><input type="checkbox" name="q8[]" value="Adventure"><label for="checkgenre[]">Adventure</label></li>
<li><input type="checkbox" name="q8[]" value="Comedy"><label for="checkgenre[]">Comedy</label></li>
<li><input type="checkbox" name="q8[]" value="Animation"><label for="checkgenre[]">Animation</label></li>
<li><input type="checkbox" name="q8[]" value="Drama"><label for="checkgenre[]">Drama</label></li> 

 </ul>
</div>
</fieldset>
 //REST OF QUESTIONS
  .....
   ....
<input class="mainForm" type="submit" name="continue" value="Save and Continue" />  

</form>

【问题讨论】:

【参考方案1】:

如果您想从以前的访问中提取问题的答案,那么只需对数据库执行 SELECT 查询以确定他们输入的内容,或者如果他们之前没有输入答案则留空。

无法通过将所有内容存储在会话中来准确理解您的意思,但如果您想在最后一次性保存所有答案,则最好将答案存储在 cookie 中。

要使您的网页动态化,您可以将所有问题和答案存储在数据库中。你可以使用这样的布局......

Table name: 'Questions'
  ID               int (autonumber)
  Question         text

Table name: 'Answers'
  ID               int (autonumber)
  QuestionID       int
  Answer           varchar(250)

Table name: 'UsersAnswers'
  ID               int (autonumber)
  UserID           int
  AnswerID         int

(这是假设你所有的问题都是选择题)

这样做可以让您添加任意数量的问题,而无需在表格中添加额外的列。

编辑...

如果您想要动态答案,那么您可以将答案存储在表格中,例如...

Table name: 'UsersAnswers'
  ID               int (autonumber)
  UserID           int
  QuestionID       int
  Answer           string

此表将允许您存储用户回答的问题的答案。

【讨论】:

感谢您的回答,但正如您所说,这假设问题都是多项选择......但我有一些问题是文本(自动完成)或国家/地区的保管箱......你有什么关于如何将这些答案存储在答案表中的想法???

以上是关于将用户输入数据保存在多页 php 表单中的主要内容,如果未能解决你的问题,请参考以下文章

PHP/HTML:输入后保存表单数据

Laravel 5.6,使多页注册并将输入数据保存到会话

Jquery -> php -> mysql 和动态表单字段

将PHP表单输入保存到网页

使用websocket节点js和php中的输入表单保存消息

Canonical:如何将 HTML 表单数据保存到 MySQL 数据库中