PHP intval函数安全应用技巧

开发 后端
PHP intval函数如何而使用不当,往往会造成一些错误,导致安全漏洞的出现。这一现象尤其对于新手来说是非常头疼的。

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

一、PHP intval函数描述

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

二、PHP intval函数分析

 

  1. PHP_FUNCTION(intval)  
  2. {  
  3. zval **num, **arg_base;  
  4. int base;  
  5. switch (ZEND_NUM_ARGS()) {  
  6. case 1:  
  7. if (zend_get_parameters_ex(1, &num) == FAILURE) {  
  8. WRONG_PARAM_COUNT;  
  9. }  
  10. base = 10;  
  11. break; 

 

当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

责任编辑:曹凯 来源: phpchina.com
相关推荐

2009-12-11 10:59:48

PHP函数extrac

2009-12-10 17:09:42

PHP编码转换函数

2009-12-10 11:02:44

PHP函数eval()

2009-12-10 15:41:35

PHP文件操作

2009-12-11 17:57:13

PHP应用JSON

2009-12-08 14:00:11

PHP函数microt

2009-11-18 18:24:26

PHP模板

2009-12-08 17:06:40

PHP应用odbc

2009-11-17 11:24:00

PHP应用技巧

2009-12-07 16:59:53

PHP匹配颜色函数

2009-11-30 09:21:39

PHP函数rmdir(

2009-12-09 09:38:15

PHP序列化数组

2009-12-01 10:50:45

PHP函数requir

2009-12-07 10:54:46

PHP uploade

2009-11-30 15:10:46

PHP substr函

2009-12-07 14:29:08

PHP array_w

2009-12-08 13:07:57

PHP函数mt_sra

2009-12-04 14:23:33

PHP JSON加密函

2009-11-27 09:30:58

PHP函数mb_str

2009-11-30 16:08:32

PHP addslas
点赞
收藏

51CTO技术栈公众号