PHP头条
热点:

PHP intval函数安全应用技巧


我们学习PHP语言的人都知道PHP拥有许多功能强大的函数,正确的应用这些函数,可以使我们获得很多好处。今天我们就向大家介绍有关PHP intval函数的正确使用方法,以解决安全漏洞方面的问题。

  • 如何正确实现PHP与Javascript交互
  • 正确解读PHP读取Cookies的方法
  • 深入探讨PHP mysql_fetch_array()函数
  • PHP函数可变参数列表的具体实现方法介绍
  • PHP单元素设计模式的原理及应用解析

一、PHP intval函数描述

intval函数有个特性:"直到遇上数字或正负符号才开始做转换,再遇到非数字或字符串结束时(\0)结束转换",在某些应用程序里由于对intval函数这个特性认识不够,错误的使用导致绕过一些安全判断导致安全漏洞.

二、PHP intval函数分析

当intval函数接受到字符串型参数是调用convert_to_long_base()处理,接下来调用Z_LVAL_P(op) = strtol(strval, NULL, base);通过strtol函数来处理参数。

PHP intval函数原型如下:

long int strtol(const char *nptr,char **endptr,int base);

这个函数会将参数nptr字符串根据参数base来转换成长整型数,参数base范围从2至36,或0.参数base代表采用的进制方式,如base值为10则采用10进制,若base值为16则采用16进制等。

流程为:

strtol()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,再遇到非数字或字符串结束时(\0)结束转换,并将结果返回。

那么当intval用在if等的判断里面,将会导致这个判断实去意义,从而导致安全漏洞.

三、PHP intval函数测试代码

  1. //intval.php  
  2. $var="20070601";  
  3. if (intval($var))  
  4. echo "it's safe";  
  5. echo '$var='.$var;  
  6. echo "  
  7. ";  
  8. $var1="1 union select 1,1,1 from admin";  
  9. if (intval($var1))  
  10. echo "it's safe too";  
  11. echo '$var1='.$var1;  
  12. ?> 

四、PHP intval函数实际应用

WordPress <= 2.0.6 wp-trackback.php Zend_Hash_Del_Key_Or_Index / sql injection exploit

www.phpzy.comtrue/php/12299.htmlTechArticlePHP intval函数安全应用技巧 我们学习PHP语言的人都知道PHP拥有许多功能强大的函数,正确的应用这些函数,可以使我们获得很多好处。今天我们就向大家介绍有关PHP intval函数的正确使用...

相关文章

    暂无相关文章
相关频道:

PHP之友评论

今天推荐