位置: 编程技术 - 正文

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

发布时间:2024-01-05

推荐整理分享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十六进制颜色)

  • 收购农副产品怎么做账
  • 兼职劳务报酬需要发票吗
  • 暂估材料收到发票后是更正还是红冲
  • 进项税转出主要内容包括
  • 合同每三个月付一次款
  • 建筑业确认主营业务收入
  • 对账状态未对账
  • 进货费用会计科目
  • 保证金逾期退还
  • 税收成本如何影响税收管理制度
  • 税费种认定功能在哪里
  • 专用发票与普通发票代码区别
  • 公司与股东的往来款涉税
  • 公对公转账备注信息填错了怎么办
  • 生产企业办理出口退税时要提供发票吗
  • 个人股权转让个税计算
  • 虚开增值税专用发票案例
  • 代缴社保工资怎么做账
  • 未抵扣完的进项税额可以跨年抵扣吗
  • 支付装修押金的会计科目
  • 情绪情感的特点
  • 行业收购溢价
  • 发放工资的时候,如何在excel里快速查询未发放成功的
  • 手工明细分类账本怎么记
  • 苹果手机密码忘记了怎么重置密码
  • 公司为什么要签劳务协议
  • mce是什么文件格式
  • PHP:__halt_compiler()的用法_misc函数
  • PHP:getimagesizefromstring()的用法_GD库图像处理函数
  • cuda completed with errors
  • 小米随身wf
  • vue中使用数组
  • 股东借款产生的利息可以税前扣除吗
  • 其他收益属于利润表吗
  • 生产企业计提车折旧年限
  • PHP array_key_exists检查键名或索引是否存在于数组中的实现方法
  • 企业会计核算应当以权责发生制为基础
  • 国内旅客运输服务普票可以抵扣吗
  • json_server
  • vue-mapvgl
  • php获取文件名称
  • 母公司为子公司提供担保需要决议吗
  • 查补收入是否享受免税政策
  • 环保税的纳税义务人是施工方还是建设方安徽
  • 年收入1500万是富人吗
  • 普通发票的开具是?
  • 无形资产分期付款会计分录?
  • 车辆保险发票一般在哪开
  • 个税起征点调整至10000
  • 增值税普通发票和电子普通发票的区别
  • 发票金额大于实际报销怎么做账
  • 贷款服务的利息怎么算
  • 上年度计提多了的奖金怎么办
  • 啥叫合同
  • 增值税普通发票查询
  • 如何提取工会经费的钱
  • mac下安装anaconda
  • win7怎么创建新用户
  • windows8.1右下角水印
  • Ubuntu下VirtualBox的vdi文件克隆方法
  • linux 图形
  • xp系统下载文件没有出现下载对话框让你选择保存的位置
  • win10web服务器在哪打开
  • win8.1网络设置
  • win7 64位旗舰版设置插上耳机就能播放声音拔下耳机就自动禁音方法
  • linuxwho
  • 宽带连接错误628win10
  • 方块滚动代码怎么写
  • 手机注册发送验证码收不到
  • javascript组件
  • shell的变量分为哪三种
  • shell脚本编写 方法
  • js如何使用
  • python的gym
  • python爬虫京东
  • python 分析
  • python mor
  • 企业科研经费管理制度
  • 缴纳了车辆购置税能退吗
  • 土地评估报告书
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号