网络安全从入门到精通 (第二章-6) 后端基础PHP—表单验证
本文内容:
- 什么是表单?
 - 如何创建一个表单:
 - 接收并验证:
 - PHP和数据库交互
 
1,什么事表单?
表单在网页中主要负责数据采集。
表单由三部分组成:
表单标签:这里面包含了处理表单数据所用动态脚本的URL,以及数据提交到服务器的方法。
表单域:包含了文本框、密码框、隐藏域、多行文本、复选框、下拉选择框和文件上传框等。
表单按钮:包括提交按钮、复位框和一般按钮:用于数据传送到服务器上的动态脚本或者取消输入,还可以用表单按钮来控制其他定义了处理脚本的处理工作。
使用场景:
登录框
搜索框
留言框
上传框
……(各种框)
表单标签:<form action="URL" method="GET/POST">
action:数据提交到哪里。
method:什么方式提交。
表单域:即表单组件,主要有:文本框、密码框、隐藏域、复选框、单选框、文件上传框、多行文本框(文本域)。
补充:正常情况下,有框一定有表单,但是并不是一个框一个表单。
表单其实就是一个HTML标签=>form表单。
反斜杠:[转义字符]
2,如何创建一个表单?
  <meta charset="utf-8">
  <center>
  <h3>后台登录</h3>
  <form action="" method="POST">
  账号:<input type="text" name="a"><br>
  密码:<input type="password" name="b"><br>
  <input type="submit" value="登录"/>
  </form>
  </center>

3,接收并验证表单:
验证表单:
数据长度、数据类型、是否存在敏感内容:stripos()、strstr()
stripos:查找字符串首次出现的位置(不区分大小写)。
stristr:查找字符串首次出现的位置,并返回其余部分字符串。
| 要求 | 检测函数 | 说明 | 
| 字符串不能为空 | strlen() | 判断字符串长度是否为0 | 
| 整数不小于1,不大于100 | <= >= | 使用大于小于判断整数范围 | 
| 数组元素3个 | count() | 判断数据元素个数 | 
| 必须为数字 | is_numeric() | 如果为数字返回true否则返回false | 
| 必须是数组 | is_arrary | 数组返回true,非数组返回false | 
| 不能为空 | is_null() | 为空返回true,否则返回false | 
| isset() | 若存在该变量且不能为null,则返回true,否则返回false | 
补充:SQL注入=>攻击核心就是输入的东西当做代码执行=>只要我们的传参在单引号内永远是字符串。
防注入核心方法:
正则匹配
字符串匹配
4,PHP和数据库交互:
如下:举例,详细看一下第二章-5
<?php
$servername = "localhost";
$username = "username";
$password = "password";
// 创建连接
$conn = new mysqli($servername, $username, $password);
// 检测连接
if ($conn->connect_error) {
die("连接失败: " . $conn->connect_error);
}
echo "连接成功"; 3
?>
与君共勉:
自己喜欢的东西就不要问别人好不好看,
你的生活不会因为别人的话变好,
喜不喜欢,
决定权还是在自己。
网络安全从入门到精通 (第二章-6) 后端基础PHP—表单验证的更多相关文章
- 网络安全从入门到精通(第二章-3)后端基础SQL— MySQL高级查询与子查询
		
本文内容: MySQL的基础查询语句 链接查询 联合查询 子查询 渗透测试常用函数 1,MySQL基础查询语句: select * from 表 order by ASC/DESC; ASC:从小到 ...
 - 网络安全从入门到精通 ( 第二章-5) 后端基础PHP—简介及基本函数-下
		
本文内容: 循环语句 PHP获取表单信息 PHP操作Mysql语句 语法SQL注入 1,循环语句: for循环: 语法:for($x=0,$x<10;$x++){执行语句;} 注意:$x++,先 ...
 - 网络安全从入门到精通 (第二章-4) 后端基础PHP—简介及基本函数-上
		
本文内容 什么是PHP PHP的基础语法 运算符 条件分支语句 1,什么是PHP? PHP(超文本预处理器)是一种通用开源语言,(是动态语言中的一种,动态语言还有ASP,ASPX,JSP). PHP语 ...
 - 网络安全从入门到精通 (第二章-2) 后端基础SQL—MySQL数据库简介及SQL语法
		
本文内容: 什么是数据库 常见数据库 数据库的基本知识 基本SQL语法 1,什么是数据库? 数据库就是将大量数据保存起来,通过计算机加工,可以高效访问的数据聚合. 数据库就是长期存储在计算机内,有组织 ...
 - 网络安全从入门到精通 (第二章-1) Web安全前端基础
		
本文内容: 前端是什么? 前端代码 HTML CSS JS !!!醋成酒的小墨,促成就的小墨,小墨促成就,!!! 1,前端是什么? 网站一般用两部分组成,前端负责展示,后端负责处理请求. 2,前端代码 ...
 - ExtJs 第二章,Ext.form.Basic表单操作
		
1.认识Ext.form.Panel表单面板 Ext.form.field.CheckBox 复选框 checkboxfield Ext.form.CheckBoxGroup 复选框组 ...
 - SaltStack 入门到精通第二篇:Salt-master配置文件详解
		
SaltStack 入门到精通第二篇:Salt-master配置文件详解 转自(coocla):http://blog.coocla.org/301.html 原本想要重新翻译salt-mas ...
 - ArcGIS for Desktop入门教程_第二章_Desktop简介 - ArcGIS知乎-新一代ArcGIS问答社区
		
原文:ArcGIS for Desktop入门教程_第二章_Desktop简介 - ArcGIS知乎-新一代ArcGIS问答社区 1 Desktop简介 1.1 ArcGIS for Desktop ...
 - 第二十二章 Django会话与表单验证
		
第二十二章 Django会话与表单验证 第一课 模板回顾 1.基本操作 def func(req): return render(req,'index.html',{'val':[1,2,3...]} ...
 
随机推荐
- 接口测试-chap3-https请求证书问题
			
接口地址如果是HTTPS,需要安装证书,或者在发送请求时传入参数verify=False,表示忽略 res = requests.get(url, verify=False)
 - Ubuntu全方位美化,定制教程
			
Ubuntu全方位美化,定制教程 上一篇随笔聊了聊Linux图形界面的各种名词及其关系,解释了何为xserver,何为xclient,linux的图形界面是如何工作的,Linux图形软件的多样性.li ...
 - Docker Linux下安装
			
下载脚本并运行安装: sudo wget -qO- https://get.docker.com/ | sh wget:下载文件工具, -q:不显示指令执行过程, -O-:-O-以'-'作为file参 ...
 - 高效JS简化版
			
详:.doc (颜色标注)2章17条 2018.6.24 星期日 1:24 第 1 章 让自己习惯 JavaScript 第 1 条:了解你使用的 JavaScript 版本 ES5 引入了另一种版本 ...
 - ES6学习总结(五)
			
与其说是对象合并,还不如说是JavaScript中对象属性的复制和转移,将多个对象中的属性合并到一个对象中 12345678 var person = { name : 'John', age : 2 ...
 - 《ASP.NET Core 高性能系列》Span<T>和Memory<T>
			
一.Span<T>概述 原文:Provides a type- and memory-safe representation of a contiguous region of arbit ...
 - [置顶]
        利用Python 提醒实验室同学值日(自动发送邮件)
			
前言: 在实验室里一直存在着一个问题,就是老是有人忘记提醒下一个人值日,然后值日就被迫中断了.毕竟良好的 卫生环境需要大家一起来维护的!没办法只能想出一些小对策了. 解决思路: 首先,我 ...
 - css3动画属性有哪些
			
transition : 平衡过渡 transition是一种css里的一种过渡效果,完成过渡需要多少秒 .延迟几秒开始 ,过渡的速度(一般有 "linear 匀速" 和“e ...
 - Javascript学习笔记-基本概念-语句
			
1.if语句 if (condition) statement1 else statement2 也可以像下面这样把整个if 语句写在一行代码中: if (condition1) statement1 ...
 - .NET Core C#目录
			
.NET Core技术开发指南 简介 本系列教程是一份关于微软.NET Core技术栈的全面的教程,其中涉及了C#.Typescript.Angular.Redis等一系列的教程.其中教程中通常会含有 ...