Php 提交前验证表单(比检查空字段更复杂)
我有一个包含时间输入的表单(特别是开始和结束时间)。当按下submit按钮时,它会进入一个php页面,这些输入被添加到数据库中。在允许提交表单之前,我想检查一些事情。例如,我希望确保开始时间早于(小于)结束时间。以下是表格:Php 提交前验证表单(比检查空字段更复杂),php,javascript,forms,validation,Php,Javascript,Forms,Validation,我有一个包含时间输入的表单(特别是开始和结束时间)。当按下submit按钮时,它会进入一个php页面,这些输入被添加到数据库中。在允许提交表单之前,我想检查一些事情。例如,我希望确保开始时间早于(小于)结束时间。以下是表格: Opens: <select name="starthour1"> <option value="00">12</option>
Opens:
<select name="starthour1">
<option value="00">12</option>
<option value="01">1</option>
<option value="02">2</option>
<option value="03">3</option>
<option value="04">4</option>
<option value="05">5</option>
<option value="06">6</option>
<option value="07">7</option>
<option value="08">8</option>
<option value="09">9</option>
<option value="10">10</option>
<option value="11">11</option>
</select> :
<select name="startminute1">
<option value="00">00</option>
<option value="15">15</option>
<option value="30">30</option>
<option value="45">45</option>
<option value="59">59</option>
</select>
<select name="startwhen1">
<option value="am">am</option>
<option value="pm">pm</option>
</select>
Closes:
<select name="endhour1">
<option value="00">12</option>
<option value="01">1</option>
<option value="02">2</option>
<option value="03">3</option>
<option value="04">4</option>
<option value="05">5</option>
<option value="06">6</option>
<option value="07">7</option>
<option value="08">8</option>
<option value="09">9</option>
<option value="10">10</option>
<option value="11">11</option>
</select> :
<select name="endminute1">
<option value="00">00</option>
<option value="15">15</option>
<option value="30">30</option>
<option value="45">45</option>
<option value="59">59</option>
</select>
<select name="endwhen1">
<option value="am">am</option>
<option value="pm">pm</option>
</select>
打开:
12
1.
2.
3.
4.
5.
6.
7.
8.
9
10
11
:
00
15
30
45
59
是
下午
关闭:
12
1.
2.
3.
4.
5.
6.
7.
8.
9
10
11
:
00
15
30
45
59
是
下午
我找到了如何检查单个表单元素的javascript代码,但我不知道如何在不提交的情况下组合多个表单元素。在我的php页面中,我有以下代码:
$starthour1=$_POST['starthour1'];
$startminute1=$_POST['startminute1'];
$startwhen1=$_POST['startwhen1'];
$endhour1=$_POST['endhour1'];
$endminute1=$_POST['endminute1'];
$endwhen1=$_POST['endwhen1'];
$start_time1=$end_time1="";
if($startwhen1=="pm"){
$starthour1=$starthour1+12;
}
if($endwhen1=="pm"){
$endhour1=$endhour1+12;
}
$start_time1=$starthour1.":".$startminute1.":00";
$end_time1=$endhour1.":".$endminute1.":00";
if($end_time1=="00:00:00"){
$end_time1="23:59:00";
}
echo "<br>start time is ".$start_time1;
echo "<br>end time is ".$end_time1;
$startnum=str_replace(":", "", $start_time1);
$endnum=str_replace(":", "", $end_time1);
if($endnum<$startnum){
echo "<br>start time can't be later than end time!";
}
else{
//add to database
}
$starthour1=$\u POST['starthour1'];
$startminute1=$_POST['startminute1'];
$startwhen1=$_POST['startwhen1'];
$endhour1=$_POST['endhour1'];
$endminute1=$_POST['endminute1'];
$endwhen1=$_POST['endwhen1'];
$start_time1=$end_time1=“”;
如果($startwhen1==“pm”){
$starthour1=$starthour1+12;
}
如果($endwhen1==“pm”){
$endhour1=$endhour1+12;
}
$start_time1=$starthour1.:“$startminute1.:00”;
$end_time1=$endhour1.:“$endminute1.:00”;
如果($end_time1==“00:00:00”){
$end_time1=“23:59:00”;
}
echo“
开始时间为”。$start\u time1;
echo“
结束时间为”。$end\u time1;
$startnum=str_replace(“:”,“,$start_time1);
$endnum=str_replace(“:”,“”,$end_time1);
if($endnum始终在PHP级别检查用户输入,无论您是否也在客户端使用javascript检查用户输入
在javaScript中,我建议您使用一个Js库,比如jQuery,它有一个用于表单验证的
在PHP级别,我建议您使用函数。效率也很高。考虑将表单数据转换为对象。这将使比较比单独处理每个部分容易得多。它还将确保放入数据库的日期时间字符串可以安全插入,因为您将从met获取字符串hod。让表单的onSubmit()或操作调用JavaScript函数,如下所示:
<form id="form" onSubmit="return doSubmit();" action="#">
要通知用户实际表单字段旁边的输入无效,可以在每个字段旁边隐藏div或span,如果验证失败,可以使用Javascript取消隐藏它们
if(!fieldNotValid){
$('#field-error').show(); //Or use effects like .highlight()
}
谢谢你的帮助!我最终使用了:
<form action="add.php" onsubmit="return validate_form()" method="POST" name="addform">
与:
函数验证\u表单(){
var f=document.addform;
变量开始、结束、开始时间、结束时间;
var valid=true;
..........
starthour=f.starthour 1.0;
endhour=f.endhour1.value;
如果(f.startwhen1.value==“pm”){
var starthour=starthour*1;
starthournum=starthournum+12;
starthour=starthournum.toString();
}
如果(f.endwhen1.value==“pm”){
var endhournum=endhour*1;
starthournum=starthournum+12;
starthour=starthournum.toString();
}
开始=开始时间+f.startminute1.value;
end=endhour+f.endminute1.value;
如果(结束=“0000”){
end=“2359”;
}
if(endso)我应该将小时、分钟和am/pm连接成一个字符串,就像我目前正在做的那样,然后执行以下操作:$date=new DateTime($start\u time);echo$date->format('H:i:s'));但这无法防止恶意用户向服务器发送无效数据。客户端验证是一项可用性功能。对于保护输入来说,它是无用的。
<form action="add.php" onsubmit="return validate_form()" method="POST" name="addform">
function validate_form(){
var f = document.addform;
var start, end, starthour, endhour;
var valid=true;
..........
starthour=f.starthour1.value;
endhour=f.endhour1.value;
if(f.startwhen1.value=="pm"){
var starthournum = starthour * 1;
starthournum = starthournum+12;
starthour = starthournum.toString();
}
if(f.endwhen1.value=="pm"){
var endhournum = endhour * 1;
starthournum = starthournum+12;
starthour = starthournum.toString();
}
start = starthour+f.startminute1.value;
end = endhour+f.endminute1.value;
if(end=="0000"){
end="2359";
}
if(end<start){
alert("Start time can't be later than end time!");
valid=false;
}
return valid;
}