PHP弱类型安全问题笔记
2018-06-22 04:56:56来源:未知 阅读 ()
一、类型转换问题
intval();
var_dump(intval('1asdfasd')); //1
var_dump(intval('awqw12')); //0
var_dump(intval(array())); //0
var_dump(intval(array('foo','val'))); //1
var_dump(intval(0x1A)); //26 十六进制转换
var_dump(intval('asdfqwer')); //0
intval 如果转换值为字符串时,不会返回错误,而是返回 0,如果转换值为数组时,有两种情况,转换值为空数组时,则会返回0,否则就会返回 1
注意:php用32位内存来保存一个整数,32位可以表示4294967296个数字,有符号的话就是-2147483647到2147483648;
二、内置函数松散性问题
switch();
$i='3adcd';
switch($i){
case 1:
echo 'i is 1';
break;
case 2:
echo 'i is 2';
break;
case 3:
echo 'i is 3';
break;
default:
echo 'i is default';
break;
}
以上结果,会进入switch case 3 里面,为什么会这样,如果switch是数字类型的case的判断时,switch会将其中的参数转换为int类,所以上述执行的时候,首先会把$i进行了类型转换,转换结果为3 ,所以。。。
in_array();
$arr = [0,1,2,3,'test'];
var_dump(in_array('abd',$arr)); // true
var_dump(in_array('1bc',$arr)); // true
为什么上面执行结果会是这样的,后面通过查询手册,官方给出的说法是, in_array 默认是走松散比较方式,只比值是否相等,而不比较值的类型是否一样,所以才有上面这种结果,不过可以设置in_array 函数第三个参数,设置为True就是严谨的比较方式。
以上都是我们平常开发需要注意的地方。
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:laravel框架少见方法详解
下一篇:PHP类的自动载入机制
- PHP写UltraEdit插件脚本实现方法 2020-03-29
- php 带逗号千位符数字的处理方法 2020-03-28
- PHP三元运算符的结合性介绍 2020-03-28
- PHP静态延迟绑定和普通静态效率的对比 2020-03-28
- 基于php流程控制语句和循环控制语句 2020-03-28
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash