[head first php&mysql]读书笔记-客户的反馈(第四章)

本文探讨了如何使用PHP的isset和empty函数进行表单验证,防止提交空白表单,以及如何通过主键确保数据库表中数据的唯一性。介绍了在用户提交错误时的表单回显方法,并讨论了主键在数据删除操作中的应用。

有时候会发送空白表单到客户那,因为啥都没填直接submit掉。哎,多不好。

介绍2个函数,isset和empty。isset对赋值后的变量返回true,不论赋的什么值,空string也是true;empty当里面的参数是空值是返回true;

空值有null,'',0,false.

这样就不会就能再用户提交空的东西的时候做出响应了。照理来说应该在客户端用js先去处理,再PHP处理,php作为最后一道墙检验。

假如提交过来东西有问题,就用类似这样的if循环去判断掉

 

 

判断掉之后,万一出错呢,还要回显一张表单给客户重填把。

就直接用html代码了

<?php

  if(out_false){

?>

<form action="<?php echo $_SERVER[PHP_SELF]?>" method="post">
<input type="text" name="user" value="<?php echo $user ?>">
<input type="pasword" name="password" value=<?php echo $password?>>
<input type="submit" value="submit"/>
</form>

<?php
}
?>

<?php?>外面的都是html代码了,但是form表单部分还是在if逻辑里面的,还有这个东西$_SERVER[PHP_SELF],可以引用前台提交过来的表单的url。假如表单数据填写有误,直接返回一个表单,这个返回的表单记录这之前填的东西。<?php echo $password?> 直接用php代码把传过来的东西再输到表单上,不过这次的表单地址url是.php结尾的了,要注意下。
另外,可以用isset($_POST['submit'])判断表单是否提交,点了submit,就有一个值传到这个超级全局变量中了,isset就是true了。


另外,数据库中我们必须让表的每一行数据具有唯一性。这就用到了主键这个东西。这就要改数据表了,总不能直接drop table 掉把。。。
alter table 表名 add id int not null auto_increment first,add primary key(id)
大意就是添加id,Int类型,不能为空,每次自己增加1,放在第一列,添加为主键,(每个表只有一个主键滴);这样每一行数据就唯一了。

唯一的主键干嘛用呢?明天再看再写。嘿嘿,要劳逸结合。
接上篇。
主键用来标志每一行,给每个表单字段加上一个复选框,再name设为todelete[],value设为主键,传到后台$_POST['todelete']就是一个数组,数组的项就是value值,也就是主键。
这样就可以用来删主键对应的行了。





 

转载于:https://www.cnblogs.com/wz0107/p/4970178.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值