第二十天:WEB攻防-PHP特性&缺陷对比函数&CTF考点&CMS审计实例

文章探讨了编程中的类型判断,如`==`与`===`的区别,以及如何通过MD5值和数组来绕过某些检查。还提到了intval函数在过滤时的作用,以及strpos函数和in_array函数可能存在的安全问题。另外,preg_match和str_replace函数作为字符串处理工具也被提及。
摘要由CSDN通过智能技术生成

函数

== 表示属于弱类型判断 不判断类型
=属于强类型比较,判断类型
在这里插入图片描述
在这里插入图片描述
当然
可以通过MD5的值来进行绕过在这里插入图片描述
而对于===可通过数组来进行绕过
在这里插入图片描述
我写的,不知哪儿出错,但意思我明白//name[]=1&password[]=2 // === 无法判断数组 所以name[] 和password[] 都是null
在这里插入图片描述
在这里插入图片描述

intval函数

intval() 函数通过使用指定的进制 base 转换(默认是十进制),返回变量 var 的 integer 数值。 intval() 不能用于 object,否则会产生 E_NOTICE 错误并返回 1。一般在过滤中将参数强制转化成整数(? id =1 and )
我抄写的别人代码,很遗憾失败
在这里插入图片描述
别人的
在这里插入图片描述

strpos函数

strpos(string,find,start)
查找 “string” 在字符串find中第一次(或使用start指定位置)出现的位置:
可以用%0a(换行符)绕过

in_array函数

in_array第三个参数安全
in_array() 函数搜索数组中是否存在指定的值。 有的话则输出指定文本。(默认是弱类型比较)

preg_match函数和str_replace函数

自己查
查的比写的更清楚

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值