#详细点: ==与=== md5 intval strpos in_array preg_match str_replace PHP比对规则 == 和 === =:赋值 ==:对比,但是不会对比数据类型 ===:对比,同时对比数据类型 1
#详细点:
==与===
md5
intval
strpos
in_array
preg_match
str_replace
PHP比对规则
== 和 ===
=:赋值
==:对比,但是不会对比数据类型
===:对比,同时对比数据类型
1.== 只要赋值变量是1开头,都可以正常访问
2.===
可以看到这两个MD5值都是0开头,而==符号存在的缺陷就是不对比数据类型,相当于对比第一个数
Http://127.0.0.1/ctf.php?name=QNKCDZO&passWord=240610708
当遇到===的PHP验证代码时
2.intval
intval() 函数用于获取变量的整数值。
intval() 函数通过使用指定的进制 base 转换(默认是十进制),返回变量 var 的 integer 数值。 intval() 不能用于 object,否则会产生 E_NOTICE 错误并返回 1。
语法
int intval ( mixed $var [, int $base = 10 ] )
参数说明:
如果 base 是 0,通过检测 var 的格式来决定使用的进制:
header("Content-Type:text/html;charset=utf-8");
$flag='dafei ai chi xigua!';
$a='1';
$i=$_GET['n'];
if(intval($i==$a)){
echo $flag;
}
2.绕过方式 666 0x29a(16进制)
$a='666';
$i=$_GET['n'];
if(intval($i==$a,0)){
echo $flag;
}
PHP strpos() 函数
查找 "php" 在字符串中第一次出现的位置:
strpos() 函数查找字符串在另一字符串中第一次出现的位置。
注释:strpos() 函数对大小写敏感。
注释:该函数是二进制安全的。
strpos(string,find,start)
string | 必需。规定要搜索的字符串。 |
find | 必需。规定要查找的字符串。 |
start | 可选。规定在何处开始搜索。 |
0a:换行
in_array() 函数搜索数组中是否存在指定的值。
bool in_array ( mixed $needle , array $haystack [, bool $strict = FALSE ] )
needle | 必需。规定要在数组搜索的值。 |
haystack | 必需。规定要搜索的数组。 |
strict | 可选。如果该参数设置为 TRUE,则 in_array() 函数检查搜索的数据与数组的值的类型是否相同。 |
设置true属性时
preg_match 函数用于执行一个正则表达式匹配。
int preg_match ( string $pattern , string $subject [, array &$matches [, int $flags = 0 [, int $offset = 0 ]]] )
搜索 subject 与 pattern 给定的正则表达式的一个匹配。
参数说明:
//模式分隔符后的"i"标记这是一个大小写不敏感的搜索
preg_match('/^php$/im')
^:前边随意
$:结尾随意
/i:不区分大小写
/m:换行匹配
绕过函数方法:利用数组,pre_match处理不了数组数据
把字符串 "Hello world!" 中的字符 "world" 替换成 "Peter":
echostr_replace("world","Peter","Helloworld!");
?>
正常情况
过滤掉select时
过滤方法,只能过滤一次select
CTFshow实战演练
//模式分隔符后的"i"标记这是一个大小写不敏感的搜索
name=QNKCDZO&password=240610708
成功的拿到了flag
来源地址:https://blog.csdn.net/m0_63917373/article/details/126830004
--结束END--
本文标题: PHP特性&缺陷对比函数&CTF考点
本文链接: https://lsjlt.com/news/417638.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0