本帖最后由 jackbill43 于 2013-08-15 15:09:41 编辑
php
新手求教
nbsp;HTML>
教室添加/修改 include_once("base-class.php");
//新建sae数据库类
$mysql = new SaeMysql();
//获取需要修改的教室ID号传入
$class_id=intval($_GET["class_id"]);
//获取操作标识传入
$action=$_POST["action"];
$action= string::un_script_code($action);
$action= string::un_html($action);
//判断是否修改,如果传入了教室ID,进行数据库查询获取全部内容
if($class_id)
{
$class_value=$mysql->getLine("select * from class where class_id=$class_id");
if(!$class_value)
{
echo "<script>alert('无此教室');history.back();</script>";
exit;
}
}
//如果获取到操作标识,进行录入或者修改操作
if($action=="update")
{
//获取表单传入数据
$old_class_id=$_POST["class_id"];
$class_name=$_POST["class_name"];
$class_number=$_POST["class_number"];
$class_fid=$_POST["class_fid"];
$class_status=$_POST["class_status"];
//传入数据过滤
$old_class_id=intval($old_class_id);
$class_name= string::un_script_code($class_name);
$class_number= string::un_script_code($class_number);
$class_fid=intval($class_fid);
$class_status= intval($class_status);
//检测必填项目
if(!$class_name || !$class_number|| !$roster_status)
{
echo "<script>alert('表单未填完整,带星号为必填项!');history.back();</script>";
exit;
}
//默认参数
$nowtime=date("Y/m/d H:i:s",time());
//如果是修改
if($old_class_id)
{
$sql = "update class set
class_name='$class_name',
class_number='$class_number',
class_fid='$class_fid',
class_status='$class_status',
edittime='$nowtime'
where class_id=$old_class_id";
$mysql->runSql( $sql );
}
else
{
//新增
$sql = "insert into class
(class_name,class_number,class_fid,class_status,addtime,edittime,status)
values
('$class_name','$class_number','$class_status','$class_fid','$nowtime','$nowtime',1)";
$mysql->runSql( $sql );
}
if( $mysql->errno() != 0 )
{
echo "<script>alert('".$mysql->errmsg() ."');history.back();</script>";
exit;
}
else
{
echo "<script>alert('操作成功!');location='roster_add.php?class_id=$old_class_id';</script>";
exit;
}
}
//获取所有教学楼
$building_list=$mysql->getData("select building_name,building_id from building where status=1 order by building_fid asc");
?>
带星号为必填项
回复讨论(解决方案)
if(!$class_name || !$class_number|| !$roster_status) { echo "<script>alert('表单未填完整,带星号为必填项!');history.back();</Script>"; exit; }
这里的$roster_status是在哪里被定义和赋值的?你贴出来的代码中没有,页面上的表单中也没有相关的字段,这当然会触发这个验证了
if(!$class_name || !$class_number|| !$roster_status) { echo "<script>alert('表单未填完整,带星号为必填项!');history.back();</Script>"; exit; }
这里的$roster_status是在哪里被定义和赋值的?你贴出来的代码中没有,页面上的表单中也没有相关的字段,这当然会触发这个验证了 这个确实是,但更改以后还是有问题,请问是不是还有什么地方有问题啊
var_dump($_POST);
if(!$class_name || !$class_number|| !$roster_status) { echo "<script>alert('表单未填完整,带星号为必填项!');history.back();</Script>"; exit; }
这里的$roster_status是在哪里被定义和赋值的?你贴出来的代码中没有,页面上的表单中也没有相关的字段,这当然会触发这个验证了 这个确实是,但更改以后还是有问题,请问是不是还有什么地方有问题啊
你是怎么更改的
if(!$class_name || !$class_number|| !$roster_status) { echo "<script>alert('表单未填完整,带星号为必填项!');history.back();</Script>"; exit; }
这里的$roster_status是在哪里被定义和赋值的?你贴出来的代码中没有,页面上的表单中也没有相关的字段,这当然会触发这个验证了 这个确实是,但更改以后还是有问题,请问是不是还有什么地方有问题啊
你是怎么更改的 改成前面定义过的class_status了
var_dump($_POST); 新手求详细
1.$_POST是存放从表单通过post方式提交过来的数据的变量,使用var_dump来打印出这个变量的内部结构,查看下class_status有没有被表单提交,如果有被提交,那么值是什么
2.
<select name="class_status"> <option value="0">请选择教室状态</option> <option <?php if($roster_value["class_status"]==0) echo "selected"?> value="0">空闲</option> <option <?php if($roster_value["classr_status"]==1) echo "selected"?> value="1">有课</option> </select>
这个地方。请选择教室状态和空闲两个option的值都是0,这是不合理的。如果你选择了这两种状态,那么表单提交的class_status就是0,!逻辑非运算符在计算0时得到结果一样是true,因此会触发错误。