💎一站式轻松地调用各大LLM模型接口,支持GPT4、智谱、星火、月之暗面及文生图 广告
上传文件的信息和数据,都保存在$\_FILFS全局数组中,不在$\_POST中,$\_POST是普通表单信息 ![Image](https://box.kancloud.cn/f013478ec0e9a2d71ee83c3abd347298_448x166.png) - name:原文件名称; - type:上传文件的后缀名; - tmp\_name:上传文件的二进制数据,在服务器端的保存位置。 - error:上传文件的错误编号。 - size:上传文件大小 #### 上传文件错误代码 第5个错误为上传文件大小为0 1为文件超过了php对上传文件大小的设置 upload\_max\_filesize 2为文件过大,超过表单中元素 MAX\_FILE\_SIZE 3文件没有上传完 4没有上传文件 6临时上传目录没找到 可以在ini中改;upload\_tmp\_dir= 7临时文件写入失败 磁盘空间不足,权限不允许 #### 判断文件是否通过HTTP POST上传的 语法:bool is\_upload\_file(string $filename) 参数:$filename是上传的临时文件 $filename就用的是$\_FILES\[‘uploadFile’\]\[‘tmp\_name’\] #### 将上传文件移动到新位置 语法:bool move\_upload\_file(string $filename,string $destination); 参数: $filename临时文件 $destination目标文件,一般将目标文件复制到网站空间 #### 生成唯一ID文件名 语法:string uniqid(\[string $prefix=””\[,bool $more\_entropy = false\] \]) 参数:如果省略2个参数则生成13位的随机数. $prefix给随机数添加前缀 $more\_entropy后面添加一个子随机数 #### 验证上传文件是否有错误 if($\_FILES\[‘uploadFile’\]\[‘error’\] != 0){exit(‘上传文件发生错误’);} #### 上传文件大小判断 (1) 修改php.ini中的upload\_max\_filesize配置项(单个文件大小)系统默认上传文件大小为2M (2) 在表单中使用隐藏域来存储文件的最大允许上传的值 提示:要写在<input type=”file”>之前才有效 如果超过php.ini中的max\_file\_size指定的最大值,则$\_FILES\[‘upload’\]\[‘error’\]=2 (3) 在服务器端也要进行大小判断 #### 使用php.fileinfo对MIME类型进行检查 在php.ini中开启extension=php\_fileinfo.dll #### finfo\_file() 返回指定文件的信息(字符集,MIME类型) 语法:string finfo\_file(resource $finfo,string $file\_name=NULL); 参数:$finfo资源 $file\_name指定取出信息的文件名 #### finfo\_open() 创建一个检查MIME类型的资源 语法:resource finfo\_open(\[int $options=FILEINFO\_NONE\]); 参数:如果是默认参数,则返回含有字符集的MIME类型,如果使用FILEINFO\_MIME参数,只返回MIME类型。