位置: 编程技术 - 正文

PHP实践教程之过滤、验证、转义与密码详解(php实验报告)

编辑:rootadmin

推荐整理分享PHP实践教程之过滤、验证、转义与密码详解(php实验报告),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:php实训,php实用教程,php教程 实例,php教程 实例,php教程 实例,php实训,php实训,php实践项目,内容如对您有帮助,希望把文章链接给更多的朋友!

本文主要给大家介绍的是关于PHP实践之过滤、验证、转义与密码等相关的内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍:

一、过滤、验证和转义

1).不要相信任何来自不受自己直接控制的数据源中的数据。包括但不限于:

$_GET $_POST $_REQUEST $_COOKIE $argv file_get_contents() 远程数据库 远程API 来自客户端的数据

2).解决办法:过滤输入。删除不安全的字符,在数据到达应用的存储层之前,必须过滤数据。需要过滤的数据包括不限于:HTML、SQL查询和用户资料信息。

HTML:使用htmlentities()函数过滤HTML成对应的实体。这个函数会转义制定字符的HTML字符,以便在存储层安全的渲染。正确的使用方式是使用htmlentities($input, ENT_QUOTES, 'UTF-8')过滤输入。或者使用HTML Purifier。缺点是慢 SQL查询: 有时必须根据数据构建SQL查询。这时要要使用PDO预处理语句过滤外部数据。 用户资料信息:使用filter_var()和filter_input()过滤用户资料信息

3).验证数据:也可以使用filter_var() ,验证成功返回要验证的值,失败返回false。但是这个函数无法验证所有数据,所以可以使用一些验证功能组件。例如aura/filter或者symfony/validator

4)转义输出:任然可以使用htmlentities这个函数,一些模板引擎也自带了转义功能。

密码

PHP实践教程之过滤、验证、转义与密码详解(php实验报告)

1).绝对不能知道用户的密码。

2).绝对不要约束用户的密码,要限制的话只限制最小长度。

3).绝对不能使用电子邮件发送用户的密码。你可以发送一个修改密码的链接,上面带一个token验证是用户本人就行了。

4).使用bcrypt计算用户密码的哈希值。加密和哈希不是一回事,加密是双向算法,加密的数据可以被解密。但是哈希是单项算法,哈希之后的数据无法被还原,想同的数据哈希之后得到的数据始终是相同的。使用数据库存储通过bcrypt哈希密码之后的值。

5).使用密码哈希API简化计算密码哈希和验证密码的操作。下面的注册用户的一般操作

下面是接受这个请求的PHP文件

6).根据机器的具体计算能力修改password_hash()的第三个值。计算哈希值一般需要0.1s-0.5s。

7).密码的哈希值存储在varchar()类型的数据库列中。

8).登录用户的一般流程

9).PHP5.5.0版本之前的密码哈希API无法使用,推荐使用ircmaxell/password-compat组件。

总结

标签: php实验报告

本文链接地址:https://www.jiuchutong.com/biancheng/287533.html 转载请保留说明!

上一篇:PHP 实现页面静态化的几种方法(php静态页面实现搜索功能)

下一篇:PHP十六进制颜色随机生成器功能示例(web十六进制颜色)

  • 增值税为什么不重复征税
  • 出口退税调整后退税率包括什么档次
  • 公司缴纳养老保险不在个人账户里吗
  • 银行应发贷款和实际收到的贷款为什么不一致
  • 环评费用怎么入账
  • 无形资产价值评估收费
  • 航空公司能开电动车吗
  • 管理费用借贷方都有,如何结转
  • 月底计提分录
  • 教育费附加可以扣除吗
  • 什么是税收筹划风险?税收筹划风险的种类有哪些?
  • 应收票据的会计分录例题
  • 应收款抹零计入什么会计科目
  • 交防伪税控服务费怎么交
  • 顺流交易为什么不管是否出售
  • 由财政拨钱还银行借款怎么做分录?
  • 质保期内质量问题
  • 汇算清缴抵税和退税
  • 给客户赔偿如何入账
  • 企业收到税务局退税分录
  • 进项税额有哪些明细科目
  • 法律关系的内容是指
  • 消费税的纳税环节可能有
  • 北京市取暖标准
  • 开办费要如何扣款
  • 资产减值损失如何结转本年利润
  • 利润表季度报表
  • 保洁属于劳务报酬吗
  • 员工吃饭发票的怎么报销
  • 银行汇票银行不予受理的是
  • 以前年度应收账款错误如何调整
  • Linux下 php5 MySQL5 Apache2 phpMyAdmin ZendOptimizer安装与配置[图文]
  • 误解苹果
  • realpopup.exe - realpopup是什么进程
  • linux的系统配置文件
  • 没结婚生了小孩分手了怎么办?
  • uni app面试题
  • 境外汇款预处理是什么意思
  • 启动电容坏了的表现
  • YOLOv5网络结构组成
  • php环境怎么搭
  • 员工不小心重复报销了
  • 帝国cms仿站工具
  • 小规模纳税人企业所得税2023
  • 个税查询和实发工资不符合
  • 其他收益在利润表填在哪里
  • mysql修改表结构会锁表吗
  • 百旺连接服务器失败,是否使用离线文件进行更新
  • 出口货物不缴纳增值税
  • 如何根据销售额的降序计算销售排名
  • 发票开错对方已抵扣该怎么处理?
  • 差旅费的处理
  • sql server 2016 sp2
  • 公用经费属于哪一类经费
  • 土地出让合同的法律效力
  • 对公账户取钱该怎么取钱
  • 什么叫系统服务
  • 营业外收入算未开票收入吗
  • 应当设置会计机构的单位有
  • 一般纳税人会计分录
  • ssms连接mysql
  • win7鼠标右键一闪就没了
  • win10搜索类型
  • linux常用基本命令pwd
  • centos开机自动运行
  • windowsxp示例图片
  • 如何优化winxp
  • linux ii
  • opengl深度值与z值
  • opengl learn
  • js跨域请求的三种方法
  • android基础入门
  • 学习JavaScript事件流和事件处理程序
  • js 比较
  • 湖北税务查询电话
  • 天津国税局电子税务局
  • 保险免保费是什么意思
  • pageoffice控件安装不上
  • 演员个人所得税2023
  • 西北地区的沙尘暴
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设