PHP文件上传利用的常见函数总结大全

 更新时间:2022年03月02日 11:37:47   作者:wingaso  
文件上传是开发中常见的一个功能,下面这篇文章主要给大家介绍了关于PHP文件上传利用的常见函数,文中通过实例代码介绍的非常详细,需要的朋友可以参考下

前言

收集了几个在文件上传利用中常见的函数。

对这些函数的深入理解应该有助于文件上传利用的顺利进行。

1. deldot

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

2. in_array

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

3. intval

intval(mixed $value, int $base = 10): int

intval 函数用于获取变量的整数值。

第一个参数$value为要获取整数值的变量,可以为字符串、数值和数组。
第二个参数$base指定了转换所使用的进制,当且仅当要转换的变量为字符串时有效。

当第二个参数为0时,会检测变量的格式来决定使用的转换进制。

  • 当存在前置的0x或0X时,使用16进制。
  • 当存在前置的0时,使用8进制。
  • 否则使用10进制。

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

4. strrchr

strrchr(string $haystack, mixed $needle): string

strrchr函数在字符串$haystack中查找$needle,并将最后一次查找到的$needle及其后面的字符串返回。如果没有在该字符串中查找到$needle,则返回false。

注:

  • 如果第二个参数不是不是单个字符,则只使用该字符串的第一个字符进行查找匹配。
  • 如果第二个参数是一个数值,则将该数值转换为对应的ASCII码进行匹配。
$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

5. strtolower

strtolower(string $string): string

将字符串$string中的各个英文字符转换为小写并返回。

$S = "HaHaHaHa,Hello!!";
echo strtolower($S);

hahahaha,hello!!

6. strrpos

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:查找最后一个出现的位置,不区分大小写。
    • 即出现“i”则为不区分大小写,出现"rr"则为查找最后一个。
$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中结果可能不一样。

7. str_ireplace

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区分大小写)
<?php
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

8. strstr

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

9. substr

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

10. trim

trim(string $str, string $character_mask = " \t\n\r\0\x0B"): string

去除字符串$str的首尾的空白字符。

当第二个参数保持默认时,去除的字符为:

  • " " 空格
  • “\t” 制表符
  • “\n” 换行符
  • “\r” 回车符
  • “\0” 空字节符
  • “\x0B” 垂直制表符
$s = "\n   1   23456789\t\n123456789\r";
echo trim($s);

1 23456789
123456789

附PHP 文件上传处理

  • $_FILES["file"]["name"] 客户端提交文件的原名称
  • $_FILES["file"]["type"] 浏览器提供的文件的 MIME 类型,如 gif 图片为 image/gif 。不过此类型在 PHP 端并不检查,因此不要想当然认为有这个值
  • $_FILES["file"]["size"] 已上传文件的大小,单位为字节
  • $_FILES["file"]["tmp_name"] 文件被上传后在服务端储存的临时文件名
  • $_FILES["file"]["error"] 和该文件上传相关的错误代码,为0则表示上传成功

参考资料

PHP官方

总结

到此这篇关于PHP文件上传利用的常见函数的文章就介绍到这了,更多相关PHP文件上传常见函数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • php 修改上传文件大小限制实例详解

    php 修改上传文件大小限制实例详解

    php默认情况下,只允许上传一定大小的文件,当上传文件大小超过这个值时,将会出错。本文章将向大家讲解php.ini中如何修改上传文件大小限制。需要修改的设置有三个地方,请看下文
    2016-10-10
  • PHP类的使用 实例代码讲解

    PHP类的使用 实例代码讲解

    用户定义的类,也是学好 PHP 所必备的条件之一。而 PHP 的类,和其它的面向对象语言比较起来,还算蛮单纯的。
    2009-12-12
  • PHP实现图的邻接矩阵表示及几种简单遍历算法分析

    PHP实现图的邻接矩阵表示及几种简单遍历算法分析

    这篇文章主要介绍了PHP实现图的邻接矩阵表示及几种简单遍历算法,结合实例形式分析了php基于邻接矩阵实现图的定义及相关遍历操作技巧,需要的朋友可以参考下
    2017-11-11
  • php错误日志简单配置方法

    php错误日志简单配置方法

    这篇文章主要介绍了php错误日志简单配置方法,较为详细的分析了php错误日志配置所涉及的php.ini与php-fpm.conf文件配置项相关属性操作技巧,需要的朋友可以参考下
    2016-07-07
  • php复制文件后改名的实例代码

    php复制文件后改名的实例代码

    在本篇文章里小编给大家整理的是一篇关于php复制文件后改名的方法及相关内容,有兴趣的朋友们可以学习下。
    2021-09-09
  • php提交过来的数据生成为txt文件

    php提交过来的数据生成为txt文件

    这篇文章主要介绍了php提交过来的数据生成为txt文件的相关资料,具有参考价值,需要的朋友可以参考下
    2016-04-04
  • mysql数据库差异比较的PHP代码

    mysql数据库差异比较的PHP代码

    这天遇见个需求:由于升级系统 这些系统从A库升级到B库,但是不知道数据库添加了哪些字段和增加了哪些表
    2012-02-02
  • php字符串过滤strip_tags()函数用法实例分析

    php字符串过滤strip_tags()函数用法实例分析

    这篇文章主要介绍了php字符串过滤strip_tags()函数用法,结合实例形式分析了php字符串过滤函数strip_tags()功能、参数及相关使用技巧,需要的朋友可以参考下
    2019-06-06
  • 浅谈PHP中其他类型转化为Bool类型

    浅谈PHP中其他类型转化为Bool类型

    本文给大家汇总介绍了下PHP中转化为布尔(bool)类型时的一些情况,非常的简单,有需要的小伙伴可以参考下
    2016-03-03
  • php HandlerSocket的使用

    php HandlerSocket的使用

    目前使用MySQL的网站,多半同时使用Memcache作为键值缓存。虽然这样的架构极其流行,有众多成功的案例,但过于依赖Memcache,无形中让Memcache成为故障的根源
    2011-05-05

最新评论