验证后PHP表格为空

时间:2012-06-27 12:23:00

标签: php mysql sql forms validation

我制作了注册表,您必须输入所有个人信息。 现在当你提交并且你得到一些错误时,它会使所有表格都为空,所以你必须重新填写所有内容。我如何防止这种情况,让一切都停留在原地? (密码除外)

这是我的代码:

<html>
<head>
  <title>Westpop</title>
  <link rel="stylesheet" href="opmaak.css">
</head>
<body>
<fblack>
<div id="header"><a href="Index.php"></a></div>

<div id="registreer">
<table cellpadding="5" align="center">
<th colspan="2" align="left">Registeren</th>
<form name="registreren"  method="post" action="registreer.php">
<tr>
    <td><fblackbold>Inloggegevens:<fblackbold></td>
</tr>

<tr>
    <td>Email</td>
    <td><input type="text" size="50" placeholder="email@provider.com" name="email"></td>
</tr>
<tr>
    <td>Wachtwoord</td>
    <td><input type="password" size="50" placeholder="min. 8 tekens, 1 hoofdletter, 1 cijfer" name="wachtwoord"></td>
</tr>
<tr>
    <td><fblackbold>Persoonlijke gegevens:<fblackbold></td>
</tr>
<tr>
    <td>Voornaam</td>
    <td><input type="text" size="50" placeholder="" name="voornaam" ></td>
</tr>
<tr>
    <td>Achternaam</td>
    <td><input type="text" size="50" placeholder="" name="achternaam"></td>
</tr>
<tr>
    <td>Geboorte Datum</td>
    <td><input type="hidden" size="8" name="action" value="submitform" />
    <input type="text" size="50" placeholder="jjjj-mm-dd" name="geboortedatum"></td>

</tr>
<tr>
    <td>Geslacht</td>
    <td>M<input type="radio" size="50" value="m" name="geslacht">
    V<input type="radio" size="50" value="v" name="geslacht"></td>

</tr>
<tr>
    <td>Adres</td>
    <td><input type="text" size="50" placeholder="Straat 00" name="adres"></td>
</tr>
<tr>
    <td>Woonplaats</td>
    <td><input type="text" size="50" placeholder="" name="woonplaats"></td>
</tr>

<tr>
    <td>Telefoonnummer</td>
    <td><input type="text" size="50" placeholder="min. 9 tekens" name="telefoonnummer"></td>
</tr>
<tr>
    <td>Functie</td>
    <td><select name="functie">
<option value="catering">Catering</option>
<option value="muziekpodia">Muziek en podia</option>
<option value="vervoerovernachten">Vervoer en overnachten</option>
<option value="logistiekbeveiliging">Logistiek en beveiliging</option>
<option value="diversen">Diversen</option>
</select></td>
</tr>
<tr align="right">
    <td></td>
    <td><input type="reset" value="Wissen"><input type="submit" name="verzenden" value="Verzenden"></td>
</tr>
</form>
</table>
 <?php
if (isset($_POST['action']) && $_POST['action']=='submitform') {


    $host = "localhost";
    $gebruikersnaam = "root";
    $wachtwoord = "";
    mysql_connect($host, $gebruikersnaam, $wachtwoord);

    $demooistedatabase = "c5g4westpopintranet";
    mysql_select_db($demooistedatabase);

    $achternaam = $_POST["achternaam"];
    $voornaam = $_POST["voornaam"];
    $gbdatum = $_POST["geboortedatum"];
    $email = $_POST["email"];
    $geslacht = $_POST["geslacht"];
    $wachtwoord = $_POST["wachtwoord"];
    $woonplaats = $_POST["woonplaats"];
    $adres = $_POST["adres"];
    $telefoonnummer = $_POST["telefoonnummer"];
    $functie = $_POST["functie"];


    $achternaam = stripslashes($achternaam);
    $voornaam = stripslashes($voornaam);
    $gbdatum = stripslashes($gbdatum);
    $email = stripslashes($email);
    $geslacht = stripslashes($geslacht);
    $wachtwoord = stripslashes($wachtwoord);
    $woonplaats = stripslashes($woonplaats);
    $adres = stripslashes($adres);
    $telefoonnummer = stripslashes($telefoonnummer);
    $functie = stripslashes($functie);


    $query ="INSERT INTO vrijwilliger (voornaam, achternaam, gbdatum, geslacht, wachtwoord, woonplaats, adres, telefoonnummer, functie, activiteitID, groepID, email)
                VALUES('$voornaam','$achternaam','$gbdatum','$geslacht','$wachtwoord','$woonplaats','$adres','$telefoonnummer','$functie',null,null,'$email')";

 $foutloos=true;


if(preg_match("/^.*(?=.{8,})(?=.*[0-9])(?=.*[a-z])(?=.*[A-Z]).*$/", $wachtwoord) === 0)
{
echo '<fblack>Wachtwoord moet minstens 8 tekens lang zijn, een kleine letter, grote letter en cijfer bevatten.<br><fblack>';
$foutloos = false; 
}

if(preg_match("/^[0-9]{10}+$/", $telefoonnummer) === 0)
{
echo '<fblack>Het telefoonnummer moet 10 cijfers bevatten.<br><fblack>';
$foutloos = false; 
}


if(preg_match("/^[0-9]{4}-[0-9]{1,2}-[0-9]{1,2}$/", $gbdatum) === 0)
{
echo '<fblack>Geboorte datum moet op dit formaat ingevoerd worden: JJJJ-MM-DD<br><fblack>';
$foutloos = false; 
}

if(preg_match("/^[a-z0-9]+([_\\.-][a-z0-9]+)*@([a-z0-9]+([\.-][a-z0-9]+)*)+\\.[a-z]{2,}$/i", $email) === 0)
{
echo '<fblack>Email moet hier op lijken: email@provider.com<br><fblack>';
$foutloos = false; 
}


if(preg_match("/^[A-Z][a-zA-Z -]+$/", $voornaam) === 0)
{
echo '<fblack>Voornaam is niet geldig ingevoerd, heeft u een hoofdletter gebruikt?<br><fblack>';
$foutloos = false; 
}


if(preg_match("/^[A-Z][a-zA-Z -]+$/", $achternaam) === 0)
{
echo '<fblack>Achternaam is niet geldig ingevoerd, heeft u een hoofdletter gebruikt?<br><fblack>';
$foutloos = false; 
}


if ($geslacht == '') 
{
echo '<fblack>U heeft uw geslacht niet aangegeven.<br><fblack>';
$foutloos = false; 
}


if(preg_match("/^[a-zA-Z]+\ +[0-9]+$/", $adres) === 0)
{
echo '<fblack>Het adres is verkeerd ingevoerd.<br><fblack>';
$foutloos = false; 
}


if(preg_match("/^[a-zA-Z\s]+$/", $woonplaats) === 0)
{
echo '<fblack>De woonplaats is verkeerd ingevoerd.<br><fblack>';
$foutloos = false; 
}

if ($foutloos == true)
{
mysql_query($query)
or die('<fblack>U staat al in ons systeem<A HREF="javascript:javascript:history.go(-1)"><br><br>Klik hier om terug te gaan</A><fblack>');
echo "<fblack>Uw registratie is succesvol verwerkt!<br>Log <a href='login.php' MEDIA=screen>hier</a> in<fblack>";
}
}
?>
</div>
<?php
include ("html_end.php");
?>

提前致谢!

8 个答案:

答案 0 :(得分:4)

您可以回复发布的值,如:

<input type="text" size="50" placeholder="email@provider.com" name="email" value="<?php echo isset($_POST['email']) ? $_POST['email'] : ''; ?>">

对其他输入也一样。

答案 1 :(得分:2)

您必须将值从表单操作传递回页面。

一旦它们在页面上可用,您就可以将它们设置为值。例如:

在正在进行验证的PHP中,设置

$emailEntered = $_POST['email'];

然后在您的表单中,回显值:

<tr>
    <td>Email</td>
    <td><input type="text" size="50" placeholder="email@provider.com" name="email" value="<?php echo $emailEntered; ?>"></td>
</tr>

答案 2 :(得分:1)

您可以使用javascript验证客户端中的字段,而不是在服务器端错误之后重新加载值

// HTML

// the submit button on page 
<input type="submit" name="verzenden" id= 'verzenden' value="verzenden" onclick='return validate();' />

// javascript

 <script type='text/javascript'>
   function validate()
  {
    // check for all the text fields if they are null
    var fname= document.getElementById('firstname');
    var lname= document.getElementById('lastname');

    if(fname.value == '')
   {
     // if the field is null it does not submit page and focus() function means
     // cursor will be in that textbox
      alert('Please enter first name');
      fname.focus();
      return false;  

   }

  }
 </script>

答案 3 :(得分:0)

您必须将字段的值设置为用户输入的值,例如

<input type="text" size="50" placeholder="Straat 00" name="adres" value="<?php echo $_POST['adres']; ?>">

答案 4 :(得分:0)

而不是回到history.go(-1)(如果您的用户不使用javascript,这将无效),您应该再次生成包含该表单的页面,即将您的HTML代码放在名为form的文件中。 php并在出现问题时包含该文件:

include ('form.php');

if (isset($_POST) {
    deal_with_post_data();

    if (something_wrong()) {
        include('form.php');
    } else {
        include('proceed.php');
    }
}

并且,在您的表单中,执行以下操作:

<input type="text" name="foo" value="<?php echo $_POST['foo']; ?>"/>

这样你就会得到以前的值,如果有的话。

顺便提一下,谨防stripslashes。它可能不足以阻止SQL注入。由于您使用的是MySQL,请改用mysql_real_escape_string

答案 5 :(得分:0)

浏览器无法保存您的数据,因此您需要再次自行提交收到的数据。

 <?php
 $email = isset($_POST['email']) ? $_POST['email'] : '';
 ?>
<td><input type="text" ... name="email" value="<?php echo $email; ?>"></td>

你可以做得更复杂,但我希望你明白这一点。 不要忘记对从$ _POST中收到的价值进行整理!

答案 6 :(得分:0)

您可以使用会话变量:

在页面的开头

<?php
session_start();

//checking if variables are setted
if !(isset($_SESSION("achternaam")){
     $_SESSION["achternaam"]=""
}
//same for all fields

形式

<td><input type="text" size="50" placeholder="" name="achternaam" value="<?php echo $_SESSION["achternaam"];?>"></td>

与所有

相同

然后在$ query之前:

$_SESSION["achternaam"] = $achternaam;

如果成功,你必须重置变量

$_SESSION["achternaam"] = "";

答案 7 :(得分:0)

我不确定这对你有用,但通常我的表单的动作在同一页面上,所以当出现错误时,我会在值属性中回显值。由于这不是您的情况,您可以将操作更改为同一页面,并在该页面中执行以下操作:

<?php
if (sizeof($_POST)) {
    require 'the_action_you_have_now.php';
    // If it succeeds, it would redirect to another page and exit, otherwise, just continue, and set a variable with a message that says there's an error.
}
?>

设置值:

value="<?php print (isset($_POST['email']) ? $_POST['email'] : '');?>

或者,它可能会起作用,具体取决于您的配置:

value="<?=(isset($_POST['email']) ? $_POST['email'] : '')?>

对于s和s,这将有所不同:

<textarea><?php print htmlentities($_POST['comment']); ?></textarea>

<select>
<?php
foreach ($options as $value => $text) {
    $selected = ($_POST['the_select'] == $value)? "selected='selected'" : "";
    print "<option value='$value' $selected>$text</option>";
}
?>
</select>