自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

PHP intval函數(shù)安全應(yīng)用技巧

開發(fā) 后端
PHP intval函數(shù)如何而使用不當(dāng),往往會造成一些錯誤,導(dǎo)致安全漏洞的出現(xiàn)。這一現(xiàn)象尤其對于新手來說是非常頭疼的。

我們學(xué)習(xí)PHP語言的人都知道PHP擁有許多功能強(qiáng)大的函數(shù),正確的應(yīng)用這些函數(shù),可以使我們獲得很多好處。今天我們就向大家介紹有關(guān)PHP intval函數(shù)的正確使用方法,以解決安全漏洞方面的問題。#t#

一、PHP intval函數(shù)描述

intval函數(shù)有個特性:"直到遇上數(shù)字或正負(fù)符號才開始做轉(zhuǎn)換,再遇到非數(shù)字或字符串結(jié)束時(\0)結(jié)束轉(zhuǎn)換",在某些應(yīng)用程序里由于對intval函數(shù)這個特性認(rèn)識不夠,錯誤的使用導(dǎo)致繞過一些安全判斷導(dǎo)致安全漏洞.

二、PHP intval函數(shù)分析

 

  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; 

 

當(dāng)intval函數(shù)接受到字符串型參數(shù)是調(diào)用convert_to_long_base()處理,接下來調(diào)用Z_LVAL_P(op) = strtol(strval, NULL, base);通過strtol函數(shù)來處理參數(shù)。

PHP intval函數(shù)原型如下:

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

這個函數(shù)會將參數(shù)nptr字符串根據(jù)參數(shù)base來轉(zhuǎn)換成長整型數(shù),參數(shù)base范圍從2至36,或0.參數(shù)base代表采用的進(jìn)制方式,如base值為10則采用10進(jìn)制,若base值為16則采用16進(jìn)制等。

流程為:

strtol()會掃描參數(shù)nptr字符串,跳過前面的空格字符,直到遇上數(shù)字或正負(fù)符號才開始做轉(zhuǎn)換,再遇到非數(shù)字或字符串結(jié)束時(\0)結(jié)束轉(zhuǎn)換,并將結(jié)果返回。

那么當(dāng)intval用在if等的判斷里面,將會導(dǎo)致這個判斷實(shí)去意義,從而導(dǎo)致安全漏洞.

三、PHP intval函數(shù)測試代碼

 

 

  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函數(shù)實(shí)際應(yīng)用

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

責(zé)任編輯:曹凱 來源: phpchina.com
相關(guān)推薦

2009-12-11 10:59:48

PHP函數(shù)extrac

2009-12-10 11:02:44

PHP函數(shù)eval()

2009-12-10 17:09:42

PHP編碼轉(zhuǎn)換函數(shù)

2009-12-10 15:41:35

PHP文件操作

2009-12-11 17:57:13

PHP應(yīng)用JSON

2009-12-08 14:00:11

PHP函數(shù)microt

2009-11-17 11:24:00

PHP應(yīng)用技巧

2009-11-18 18:24:26

PHP模板

2009-12-08 17:06:40

PHP應(yīng)用odbc

2009-11-30 09:21:39

PHP函數(shù)rmdir(

2009-12-07 16:59:53

PHP匹配顏色函數(shù)

2009-12-09 09:38:15

PHP序列化數(shù)組

2009-12-01 10:50:45

PHP函數(shù)requir

2009-12-08 13:07:57

PHP函數(shù)mt_sra

2009-11-30 15:10:46

PHP substr函

2009-12-07 10:54:46

PHP uploade

2009-12-07 14:29:08

PHP array_w

2009-12-04 14:23:33

PHP JSON加密函

2009-11-27 09:30:58

PHP函數(shù)mb_str

2009-11-30 16:08:32

PHP addslas
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號