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


    有时候会发送空白表单到客户那,因为啥都没填直接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值,也就是主键。
    这样就可以用来删主键对应的行了。





  • 相关阅读:
    Kali 2020.3安装docker和vulhub
    Web渗透——身份管理测试
    Web渗透——配置管理测试
    网站信息收集
    linux修改MAC的方法
    '文件上传总结'
    美杜莎和九头蛇的对比
    渗透测试常见开放端口及利用
    Google hacking 语法
    web渗透测试基本步骤
  • 原文地址:https://www.cnblogs.com/wz0107/p/4970178.html
Copyright © 2020-2023  润新知