当前位置:首页 > 黑客技术 > 正文内容

PHP弱类型安全问题总结

访客4年前 (2021-04-16)黑客技术1007

 前段时间做了南京邮电大学网络攻防渠道上面的标题,写了一个writeup之后,还有必要总结一下。因为做的标题都是web类型的,一切的标题都是运用PHP来写的,所以许多标题并没有调查到传统的如SQL注入,XSS的类型的缝隙,许多都是PHP自身语法的问题。鉴于现在PHP是世界上最好的言语,PHP自身的问题也能够算作是web安全的一个方面。在PHP中的特性便是弱类型,以及内置函数关于传入参数的松懈处理。本篇文章首要便是记载我在做攻防渠道上面遇到的PHP的函数中存在的问题,以及PHP的弱类型所带来的问题。

PHP弱类型简介

在PHP中,能够进行一下的操作。

1
2
3
$param = 1;
$param = array();
$param = "stringg";

弱类型的言语对变量的数据类型没有约束,你能够在任何地时分将变量赋值给恣意的其他类型的变量,一起变量也能够转化成恣意地其他类型的数据。

类型转化问题

类型转化是无法防止的问题。例如需要将GET或者是POST的参数转化为int类型,或者是两个变量不匹配的时分,PHP会自动地进行变量转化。可是PHP是一个弱类型的言语,导致在进行类型转化的时分会存在许多意想不到的问题。

比较操作符

类型转化

在$a==$b的比较中

1
2
$a=null;$b=flase ; //true
$a='';$b=null; //true

这样的比如还有许多,这种比较都是持平。
运用比较操作符的时分也存在类型转化的问题,如下:

1
2
3
4
0=='0' //true
0 == 'abcdefg' //true
0 === 'abcdefg' //false
1 == '1abcdef' //true

当不同类型的变量进行比较的时分就会存在变量转化的问题,在转化之后就有可能会存在问题。

Hash比较

除了以上的这种方法之外在进行hash比较的时分也会存在问题。如下:

1
2
3
"0e132456789"=="0e7124511451155" //true
"0e123456abc"=="0e1dddada" //false
"0e1abc"=="0" //true

在进行比较运算时,假如遇到了0ed+这种字符串,就会将这种字符串解析为科学计数法。所以上面比如中2个数的值都是0因而就持平了。假如不满足0ed+这种形式就不会持平。这个标题在攻防渠道中的md5 collision就有考到。

十六进制转化

还存在一种十六进制余字符串进行比较运算时的问题。比如如下:

1
2
3
"0x1e240"=="123456" //true
"0x1e240"==123456 //true
"0x1e240"=="1e240" //false

当其间的一个字符串是0x最初的时分,PHP会将此字符串解析成为十进制然后再进行比较,0x1240解析成为十进制便是123456,所以与int类型和string类型的123456比较都是持平。攻防渠道中的起名字真难便是调查的这个特性。

类型转化

常见的转化首要便是int转化为string,string转化为int。
int转string:

1
2
3
$var = 5;
方法1:$item = (string)$var;
方法2:$item = strval($var);

string转int:intval()函数。
关于这个函数,能够先看2个比如。

1
2
3
var_dump(intval('2')) //2
var_dump(intval('3abcd')) //3
var_dump(intval('abcd')) //0

阐明intval()转化的时分,会将从字符串的开端进行转化知道遇到一个非数字的字符。即便呈现无法转化的字符串,intval()不会报错而是回来0。
intval()的这种特性在攻防渠道中的MYSQL这道标题中就有考到。
一起,程序员在编程的时分也不应该运用如下的这段代码:

1
2
3
if(intval($a)>1000) {
mysql_query("select * from news where id=".$a)
}

这个时分$a的值有可能是1002 union…..

内置函数的参数的松懈性

内置函数的松懈性说的是,调用函数时给函数传递函数无法承受的参数类型。解说起来有点拗口,仍是直接经过实践的比如来阐明问题,下面会要点介绍几个这种函数。

[1] [2]  黑客接单网

扫描二维码推送至手机访问。

版权声明:本文由黑客接单发布,如需转载请注明出处。

本文链接:https://therlest.com/106211.html

分享给朋友:

“PHP弱类型安全问题总结” 的相关文章

接单的黑客_可以找黑客黑美团吗

有在网络安全范畴中,猜测网络违法和歹意软件发展趋势好像现已成为了各大网络安全公司的传统了。 为了防止让咱们去阅览上百页的安全陈述,咱们专门整兼并总结了McAfee、Forrester、FiskIQ、卡巴斯基实验室【1、2、3】、WatchGuard、Nuvias、FireEye、CyberArk、F...

黑客了解,中国黑客越南网络apt,黑客网站密码破解工具

6.42 · hxxp[://]offlineearthquake[.]com/file//?id=&n=000 进程三:使命履行及实时数据剖析10.61 2019年6月19日,FireEye Endpoint Security设备上收到了缝隙检测警报。 违规应用程序被辨认为Microso...

有机调和水多少钱一吨 「有机调和水制作过程」

如果说一吨女人是水啊,2,而化学肥料就像人吃的维生素,不能光喝水。 摆放至出水,15种神秘辣椒,用油炸成油炸品,好的纯净水想怎么用就怎么用、稳定供水量。白露节令的露、在本生态系统中有光、过高引起的压力传感的反应原水泵恒定系统供水压力,玉米面4两,制作方法是:将小鱼2调和条。 汽提→大豆原油。手板石膏...

实用的刷卡门禁一体机 - 门禁设置说明书

2011-04-0511:45:53卡号:方向:未知,具体操作说明:门禁控制器,还要看你们所用的门禁是ID的还是IC的。具体的可以根据说明书操作。 手动开门[1 的大门2011-04-0511:45:43[1 大门无效用户刷卡时间,你这个说的真不知道怎么回答你。蜂鸣器连续断续鸣响报警,具体到可以统计...

如何寻找黑客微信号(只有一个微信号,黑客可以查到对方吗)

一、如何寻找黑客微信号(只有一个微信号,黑客可以查到对方吗) 1、有黑客能查到微信聊天记录是骗人的吗绝对是骗子,请勿相信! 微信聊天信息保存在本地 一般聊天信息都是保存在本地的,除非开通会员可以将聊天信息存储。 黑客查找出来的微信聊天截图是真的吗在手机端启动微信,在微信主界面底部导航中点击“微信”...

今天大蒜价格 - 大蒜期货行情

6点20元/市斤左右,2010年12月20日金乡,斑鸠店今日大蒜价格2012年8月21日,50元/市斤左右,回家的时候是4点5公分7?未来一段时间价格是涨还是降,印尼:2点70元/斤左右。小蒜:1点70元/斤左右。单位:元/千克,5点0-6点0公分:2点30-2点。 所以我感觉大蒜要是能存的话,印尼...

评论列表

性许比忠
2年前 (2022-06-19)

$var = 5;方法1:$item = (string)$var;方法2:$item = strval($var);string转int:intval()函数。关于这个函数,能够先看2个比如。123

囤梦做啡
2年前 (2022-06-19)

,0x1240解析成为十进制便是123456,所以与int类型和string类型的123456比较都是持平。攻防渠道中的起名字真难便是调查的这个特性。类型转化常见的转化首要便是int转化为string,string转化为int。int转string:123

泪灼云胡
2年前 (2022-06-19)

bcdefg' //true0 === 'abcdefg' //false1 == '1abcdef' //true当不同类型的变量进行比较的时分就会存在变量转化的问题,在转化之后就有可能会存在问题。Hash比较除了以上的这种方法之外在进行hash比较的时分也会存在问题。如下:123

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。