收集了几个在文件上传利用中常见的函数。
对这些函数的深入理解应该有助于文件上传利用的顺利进行。
deldot
函数为upload-lab中一个常见的函数,它实际为一个自定义函数,定义于common.php中,函数定义如下:
function deldot($s){
for($i = strlen($s)-1;$i>0;$i--){
$c = substr($s,$i,1);
if($i == strlen($s)-1 and $c != '.'){
return $s;
}
if($c != '.'){
return substr($s,0,$i+1);
}
}
}
即从字符串的尾部开始,从后向前删除点.
,直到该字符串的末尾字符不是.
为止。
因此对于如下输入,
echo deldot("hello world")."\n";
echo deldot("hello world.")."\n";
echo deldot("hello world....")."\n";
echo deldot("hello.world.")."\n";
输出为
hello world
hello world
hello world
hello.world
in_array(mixed $needle, array $haystack, bool $strict = false): bool
其中第一个参数$needle
为待搜索的值,$haystack
为被搜索的数组,第三个参数决定是否进行类型比较。
第三个类型默认为false
,即不考虑类型是否相同。
对于如下输入:
if(in_array("AAA",$arr,false)) echo 1;
if(in_array("aaa",$arr,false)) echo 2;
if(in_array("AAA",$arr,true)) echo 3;
if(in_array("aaa",$arr,true)) echo 4;
输出
13
intval(mixed $value, int $base = 10): int
intval
函数用于获取变量的整数值。
第一个参数$value
为要获取整数值的变量,可以为字符串、数值和数组。
第二个参数$base
指定了转换所使用的进制,当且仅当要转换的变量为字符串时有效。
当第二个参数为0时,会检测变量的格式来决定使用的转换进制。
0x
或0X
时,使用16进制。0
时,使用8进制。intval
函数返回的数值为一个int
类型的数值。当转换不成功时,返回0。
特别要注意,使用该函数返回的值有上限。当转换的数值大于php的整数范围时,返回的结果为整型数值的取值上限。
echo intval("111");
echo "\n";
echo intval("111a");
echo "\n";
echo intval("0x333");
echo "\n";
echo intval("888",8);
echo "\n";
echo intval("122",3);
echo "\n";
echo intval("11111111111111111111111111111111111");
echo "\n";
echo intval("2222222222222222222222222222222");
输出为
111
111
0
0
17
9223372036854775807
9223372036854775807
strrchr(string $haystack, mixed $needle): string
strrchr
函数在字符串$haystack
中查找$needle
,并将最后一次查找到的$needle
及其后面的字符串返回。如果没有在该字符串中查找到$needle
,则返回false
。
注:
$S = "hhhahahaha2333";
echo strrchr($S,'h')."\n";
echo strrchr($S,'hwweraer')."\n";
echo strrchr($S,104)."\n";
if(strrchr($S,'k') == false) echo "false";
ha2333
ha2333
ha2333
false
strtolower(string $string): string
将字符串$string
中的各个英文字符转换为小写并返回。
$S = "HaHaHaHa,Hello!!";
echo strtolower($S);
hahahaha,hello!!
strrpos(string $haystack, string $needle, int $offset = 0): int
返回字符$needle
最后一次出现的位置。
在php4中,$needle
只能为单个字符。如果$needle
中存在多个字符,仅使用第一个字符做匹配。
和strrchr
相似,如果$needle
是一个数值,则使用该数值对应的ASCII码字符进行匹配。
从php5开始,$needle
可以为多个字符。
从php5开始,strrpos
新增一个参数$offset
,可以指定从$haystack
的哪儿位置开始进行匹配。
返回匹配的下标位置,没有匹配到时返回false
。
注意:
false
的时候必须使用全等于符号===
。stripos
:查找首个出现的位置,不区分大小写。strpos
:查找首个出现的位置,区分大小写。strripos
:查找最后一个出现的位置,不区分大小写。$s = "Phpphphpphpp";
echo strrpos($s,"php");
echo strrpos($s,"h");
echo strrpos($s,"P");
if(strrpos($s,"PHP") === false) echo "No exist";
输出:
890No exist
注:测试使用的PHP版本为5.3.3。
在PHP4中结果可能不一样。
str_ireplace(
mixed $search,
mixed $replace,
mixed $subject,
int &$count = ?
): mixed
str_ireplace
函数用于对数组中的元素或字符串中的子串进行替换。
第一个参数$search
为需要替换的内容(子串或数组),第二个参数$replace
为替换成的内容(字符串或数组),第三个参数$subject
为被替换的字符串。
$search
和$replace
都为字符串,那么将会把$subject
中匹配的子串$search
替换为$replace
。$search
和$replace
都为数组时,将会进行映射替换。如果$replace
的值的个数少于 search 的个数,多余的替换将使用空字符串来进行。$search
为数组而$replace
为字符串,则对于$subject
中出现的每一个search
的元素,都会使用$replace
做替换。$count
可以用于限定替换次数。
注:
str_replace
区分大小写)
echo str_ireplace("php","","hello.php")."\n";
echo str_ireplace("pHP","","hello.Php")."\n";
echo str_ireplace("php","","hello.phPHpp")."\n";
echo str_ireplace("php","p","hello.phphp")."\n";
echo str_ireplace("php",""."phpphpphpphpphp.php",3)."\n";
echo str_ireplace(array("php","html"),"","hello.php.html")."\n";
echo str_ireplace(array("php","html"),array("1","2"),"hello.php.html")."\n";
echo str_ireplace(array("php","html","css"),array("1","2"),"hello.php.css.html")."\n";
echo str_ireplace(array("php","html","css"),"1","hello.php.css.html")."\n";
foreach (str_ireplace(array("php","html","css"),array("1","2","3"),array("hello.html","hello.css","hello.html")) as $it){
echo "$it ";
}
?>
hello.
hello.
hello.Hpp
hello.php
3
hello…
hello.1.2
hello.1…2
hello.1.1.1
hello.2 hello.3 hello.2
strstr(string $haystack, mixed $needle, bool $before_needle = false): string
查找字符串$needle
在$haystack
中首次出现的位置,并将$needle
及其之后的字符串返回。
PHP5起新增第三个参数$before_needle
,如果$before_needle
取值为true
,则返回$needle
前面的部分。
$s = "123phpphp.php";
echo strstr($s,"php")."\n";
echo strstr($s,"php",true)."\n";
phpphp.php
123
substr(string $string, int $offset, ?int $length = null): string
返回字符串$string
中的子串。
$offset
指定子串首个字符在$string
中的下标位置,$length
指定截取的子串长度。
$length
的取值:
$length
为默认取值时,函数会将$offset
至$length
的字符串截取并返回。$length
取正数时,会从$offset
开始将最多$length
个字符截取返回出来。$length
取0时,返回一个空字符串。$length
取负数时,会将$offset
至字符串$string
倒数第$length
前的字符返回出来。$s = "123456789";
echo substr($s,1,3)."\n";
echo substr($s,1,-1)."\n";
echo substr($s,1)."\n";
echo substr($s,1,0)."\n";
234
2345678
23456789
trim(string $str, string $character_mask = " \t\n\r\0\x0B"): string
去除字符串$str
的首尾的空白字符。
当第二个参数保持默认时,去除的字符为:
$s = "\n 1 23456789\t\n123456789\r";
echo trim($s);
1 23456789
123456789
PHP官方
注意:本文只做技术分享,请勿用于非法用途,否则后果作者概不负责。
原创不易,感谢支持。