gpt4 book ai didi

php文件上传 你真的掌握了吗

转载 作者:qq735679552 更新时间:2022-09-27 22:32:09 24 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章php文件上传 你真的掌握了吗由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

这里首先声明一下这一章的内容比较多,比较难,你要抱着和自己死磕的态度。细微之处不放过,多敲多练是王道。 学习就像爬山,得一步一步来,首先给自己定一个小目标,然后再坚持不懈地往高出攀爬,最终到达最顶峰。 请仔细斟酌上面两句忠告 。

1、我的准备情况说明.

编辑器:sublime text3(用什么编辑器看自己爱好) 服务器构建:使用phpstudy2014构建服务器,服务器文件存储在我自身电脑d盘的www文件中。(安装phpstudy会自动生成www文件,安装在哪个盘自己做主)。运行phpstudy,通过在浏览器地址栏输入localhost可以访问服务器中文件。 上传文件的过程:浏览器在客户端上传文件,点击提交,文件被传送给服务器中的某个php文件进行处理,该php对该上传文件保存到服务器.

2、创建表单 。

请看我的html代码 。

php文件上传 你真的掌握了吗

enctype 。

在form元素的语法中,enctype表明提交数据的格式 用 enctype 属性指定将数据回发到服务器时浏览器使用的编码类型。enctype有三种: 1、application/x-www-form-urlencoded: 窗体数据被编码为名称/值对。这是标准的编码格式。 2、multipart/form-data: 窗体数据被编码为一条消息,页上的每个控件对应消息中的一个部分。 3、 text/plain: 窗体数据以纯文本形式进行编码,其中不含任何控件或格式字符。  补充(随便看看就好):orm的enctype属性为编码方式,常用有两种:application/x-www-form-urlencoded和multipart/form-data,默认为application/x-www-form-urlencoded。 当action为get时候,浏览器用x-www-form-urlencoded的编码方式把form数据转换成一个字串(name1=value1&name2=value2…),然后把这个字串append到url后面,用?分割,加载这个新的url。 当action为post时候,浏览器把form数据封装到http body中,然后发送到server。 如果没有type=file的控件,用默认的application/x-www-form-urlencoded就可以了。 但是如果有type=file的话,就要用到multipart/form-data了。浏览器会把整个表单以控件为单位分割,并为每个部分加上content-disposition(form-data或者file),content-type(默认为text/plain),name(控件name)等信息,并加上分割符(boundary).

有点难理解。 总归就记住两句话:如果input标签中有type=file,则enctype=multipart/form-data。如果没有type=file一般情况下使用application/x-www-form-urlencoded。 文件上传时都要将数据进行一定转化才能上传到服务器,application/x-www-form-urlencoded和multipart/form-data两者之间的区别就在与转化编码方式不同.

3、创建php文件用于处理上传的文件.

php文件上传 你真的掌握了吗

上传文件后效果如下:

php文件上传 你真的掌握了吗

每一个上传文件都有name、type、size、tmp_name等信息。文件上传后,这些文件相关信息存在files这个数组变量。_files[“myfile”][“name”]相当于一个多维数组的访问,files先获取表单名称为myfile的input上传的文件数据,然后再访问name、type、size、error等数据。_files["myfile"]["error"]用来处理文件没有正常上传的情况,例如超过限定上传的文件大小。如果files[“myfile”][“error”]=0,表示文件正常上传。_files[“myfile”][“error”]>0表示文件没有正常上传。 files[“myfile”][“error”]=1上传文件超过服务器限定的值,比如超过服务器空间大小。_files[“myfile”][“error”]=2 超过浏览器限定上传的值 $_files[“myfile”][“error”]=3文件只有部分被上传 。

files[“myfile”][“error”]=4没有文件本上传。_files[“myfile”][“error”]还可以为5、6、7、8,这里不做深究,只需知道其大于0时就意味这文件上传出错即可.

上传限制 。

通常情况下,服务器通常会限制服务器上传文件的大小或者类型。我们在上面php代码的基础上添加对上传文件代码的限制。 先熟悉几个函数用法: explode()函数用于分割字符串,例:explode(“.”,”aaa.html”)就是在点的位置将这个字符串分成”aaa”和”html”两个字符串,这两个字符串按顺序存储在同一个数组中。 end()获取数组中最后一个元素的值。 in_array()在数组中查找某个元素,看是否存在,存在返回为true,不存在返回为false.

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
<?php
//第一步:明确服务器规定上传至服务器的文件类型。这里我们只允许上传以下类型的图片。
$allowedexts = array ( "gif" , "jpeg" , "jpg" , "png" ); // 允许上传的图片后缀
//第二部:获取上传的文件名称,通过explorde()函数将其分割成字符串形式的数组。
$temp = explode ( "." , $_files [ "myfile" ][ "name" ]);
echo $_files [ "file" ][ "size" ];
 
$extension = end ( $temp );   // end函数用于获取数组中最后一个元素的值。
//第三步:列出上传文件需要满足的条件
if ((( $_files [ "myfile" ][ "type" ] == "image/gif" )
|| ( $_files [ "myfile" ][ "type" ] == "image/jpeg" )
|| ( $_files [myfile "][" type "] == " image/jpg")
|| ( $_files [ "myfile" ][ "type" ] == "image/pjpeg" )
|| ( $_files [ "myfile" ][ "type" ] == "image/x-png" )
|| ( $_files [ "myfile" ][ "type" ] == "image/png" ))
&& ( $_files [ "myfile" ][ "size" ] < 204800)  // 小于 200 kb
&& in_array( $extension , $allowedexts ))
   //in_array表示在$allowedexts数组中查找$extension这个字符串
{
   if ( $_files [ "myfile" ][ "error" ] > 0)
   {
     echo "错误:: " . $_files [ "myfile" ][ "error" ] . "<br>" ;
     //举个例子服务器空间不足,文件只能上传部分就会出现错误。
   }
   else
   {
     echo "上传文件名: " . $_files [ "myfile" ][ "name" ] . "<br>" ;
     echo "文件类型: " . $_files [ "myfile" ][ "type" ] . "<br>" ;
     echo "文件大小: " . ( $_files [ "myfile" ][ "size" ] / 1024) . " kb<br>" ;
     echo "文件临时存储的位置: " . $_files [ "myfile" ][ "tmp_name" ] . "<br>" ;
   }
}
else
{
   echo "非法的文件格式" ;
}
?>

4、保存上传的文件 。

文件上传后,它是保存在一个临时的位置。脚本结束时它就会消失。如果要把他永久的保存在服务器中,我们要把它保存在另一个位置。 . file_exists(“upload/” . files[“file”][“name”])检查文件或目录是否存在。.moveuploadedfile(_files["file"]["tmp_name"], "upload/" . $_files[“myfile”][“name”]);将上传文件从临时位置转移到服务器空间.

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
<?php
//第一步:明确服务器规定上传至服务器的文件类型。这里我们只允许上传以下类型的图片。
$allowedexts = array ( "gif" , "jpeg" , "jpg" , "png" ); // 允许上传的图片后缀
//第二部:获取上传的文件名称,通过explorde()函数将其分割成字符串形式的数组。
$temp = explode ( "." , $_files [ "myfile" ][ "name" ]);
echo $_files [ "myfilefile" ][ "size" ];
$extension = end ( $temp );   // end函数用于获取数组中最后一个元素的值。
//第三步:列出上传文件需要满足的
if ((( $_files [ "myfile" ][ "type" ] == "image/gif" )
|| ( $_files [ "myfile" ][ "type" ] == "image/jpeg" )
|| ( $_files [ "myfile" ][ "type" ] == "image/jpg" )
|| ( $_files [ "myfile" ][ "type" ] == "image/pjpeg" )
|| ( $_files [ "myfile" ][ "type" ] == "image/x-png" )
|| ( $_files [ "myfile" ][ "type" ] == "image/png" ))
&& ( $_files [ "myfile" ][ "size" ] < 204800)  // 小于 200 kb
&& in_array( $extension , $allowedexts )) //in_array表示在$allowedexts数组中查找$extension这个字符串
{
   if ( $_files [ "myfilefile" ][ "error" ] > 0)
   {
     echo "错误:: " . $_files [ "myfile" ][ "error" ] . "<br>" ;
   }
   else
   {
     echo "上传文件名: " . $_files [ "myfile" ][ "name" ] . "<br>" ;
     echo "文件类型: " . $_files [ "myfile" ][ "type" ] . "<br>" ;
     echo "文件大小: " . ( $_files [ "myfile" ][ "size" ] / 1024) . " kb<br>" ;
     echo "文件临时存储的位置: " . $_files [ "myfile" ][ "tmp_name" ] . "<br>" ;
 
     // 判断当期目录(即www文件夹中)下的 upload 目录(自己创建,名字自取)是否存在该文件
     // 如果没有 upload 目录,你需要创建它,upload 目录权限为 777
     if ( file_exists ( "upload/" . $_files [ "myfile" ][ "name" ]))
     {
       echo $_files [ "myfile" ][ "name" ] . " 文件已经存在。 " ;
     }
     else
     {
       // 如果 upload 目录不存在该文件则将文件上传到 upload 目录下
       move_uploaded_file( $_files [ "myfile" ][ "tmp_name" ], "upload/" . $_files [ "file" ][ "name" ]); //
       echo "文件存储在: " . "upload/" . $_files [ "myfile" ][ "name" ];
     }
   }
}
else
{
   echo "非法的文件格式" ;
}
?>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我.

最后此篇关于php文件上传 你真的掌握了吗的文章就讲到这里了,如果你想了解更多关于php文件上传 你真的掌握了吗的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com