- 目录
- 1. 序章
- 2. 计算机网络与协议
- 3. 信息收集
- 4. 常见漏洞攻防
- 5. 语言与框架
- 6. 内网渗透
- 7. 云安全
- 8. 防御技术
- 9. 认证机制
- 10. 工具与资源
- 11. 手册速查
- 12. 其他
文章来源于网络收集而来,版权归原创者所有,如有侵权请及时联系!
5.1.12. 其它
5.1.12. 其它
5.1.12.1. 低精度
php中并不是用高精度来存储浮点数,而是用使用 IEEE 754 双精度格式,造成在涉及到浮点数比较的时候可能会出现预期之外的错误。 比如 php -r "var_dump(0.2+0.7==0.9);"
这行代码的输出是 bool(false)
而不是 bool(true)
。这在一些情况下可能出现问题。
5.1.12.2. 弱类型
如果使用 ==
来判断相等,则会因为类型推断出现一些预料之外的行为,比如magic hash,指当两个md5值都是 0e[0-9]{30}
的时候,就会认为两个hash值相等。 另外在判断字符串和数字的时候,PHP会自动做类型转换,那么 1=="1a.php"
的结果会是true
另外在判断一些hash时,如果传入的是数组,返回值会为 NULL
, 因此在判断来自网络请求的数据的哈希值时需要先判断数据类型。
同样的, strcmp()
ereg()
strpos()
这些函数在处理数组的时候也会异常,返回NULL。
5.1.12.3. 命令执行
preg_replace 第一个参数是//e的时候,第二个参数会被当作命令执行
5.1.12.4. 截断
PHP字符存在截断行为,可以使用 ereg
/ %00
/ iconv
等实现php字符截断的操作,从而触发漏洞。
5.1.12.5. 变量覆盖
当使用 extract
/ parse_str
等函数时,或者使用php的 $$
特性时,如果没有正确的调用,则可能使得用户可以任意修改变量。
5.1.12.6. php特性
- php自身在解析请求的时候,如果参数名字中包含" "、"."、"["这几个字符,会将他们转换成下划线
- 由于历史原因,
urlencode
和RFC3896存在一定的不同,PHP另外提供了rawurlencode
对RFC3896完成标准的实现
5.1.12.7. /tmp临时文件竞争
phpinfo可访问时,可以看到上传的临时文件的路径,从而实现LFI。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论