PHP前端开发

uniapp多图上传php接受不到怎么解决

百变鹏仔 2个月前 (11-20) #uniapp
文章标签 多图

一、背景介绍

随着互联网技术的不断发展,越来越多的Web应用需要支持图片上传功能。而uniapp是一款目前非常流行的移动端开发框架,具有跨平台、高效、易用等特点。然而,当我们使用uniapp开发多图上传功能时,就会遇到一些问题:服务器无法正确接收请求,无法获取到传递的图片信息。本文将探讨这个问题的可能原因和解决方案。

二、问题描述

我们使用uniapp提供的上传组件插件 uni-upload 开发多图上传功能,使用 PHP 后端代码来接收上传请求和保存图片信息。上传页面代码如下:

<template>  <view class="container">    <view class="uploadBtn" @tap="chooseImage">      <image src="../../static/plus.png"></image>    </view>    <view class="image-list">      <view class="image-item" v-for="(item, index) in fileList" :key="index">        <image :src="item.path"></image>        <view class="delete" @tap="deleteImage(index)">删除</view>      </view>    </view>    <view class="submitBtn" @tap="submit">      提交    </view>  </view></template><script>  import uniUpload from "@/components/uni-upload/uni-upload.vue";  export default {    components: { uniUpload },    data() {      return {        fileList: [],      };    },    methods: {      chooseImage() {        uni.chooseImage({          count: 9,          success: (res) => {            this.fileList = [...this.fileList, ...res.tempFilePaths.map((path) => ({ path }))];          },        });      },      deleteImage(index) {        this.fileList.splice(index, 1);      },      submit() {        const formData = new FormData();        this.fileList.forEach((item, index) => {          formData.append(`file${index}`, item.path);        });        uni.request({          method: "POST",          url: "http://localhost/upload.php",          header: {            "Content-Type": "multipart/form-data",          },          data: formData,          success: (res) => {            console.log("upload success", res.data);          },          fail: (error) => {            console.log("upload fail", error);          },        });      },    },  };</script>

上传组件采用了 uni-upload 插件,通过 chooseImage 方法调用相册选择图片,将 tempFilePaths 中的图片路径填入 fileList 中,同时在submit 方法中将 fileList 中的图片路径上传到后端服务器。

立即学习“PHP免费学习笔记(深入)”;

在服务器端,我们使用PHP作为后端语言,代码如下:

<?php  $upload_dir = "uploads/";  if (!file_exists($upload_dir)) {    mkdir($upload_dir);  }  foreach ($_FILES as $key => $file) {    $tmp_name = $file["tmp_name"];    $name = $file["name"];    if (move_uploaded_file($tmp_name, $upload_dir . $name)) {      echo "upload success ";    } else {      echo "upload fail ";    }  }?>

在本地测试中发现,在提交图片后,后端服务器无法正确读取上传请求,不能正确地保存图片。下面将会会提出一些解决方案。

三、问题原因

根据错误提示,可能是文件上传方式不正确导致的。而 FormData 和 multipart/form-data 是现在用来表单实现文件上传的一种重要方式,但是如果不设置合适的请求头信息,服务器无法正确获取上传文件,这可能是造成这个问题的原因。

四、解决方案

  1. 更改请求头信息

在上传请求中增加头部内容 type 与 boundary ,其中 type 是发送请求时的 Content-Type, boundary 部分是分割数据的随机字符串。

uni.request({
 method: "POST",
 url: "http://localhost/upload.php",
 header: {

"Content-Type": "multipart/form-data; boundary=" + Math.random().toString().substr(2),

},
 data: formData,
 success: (res) => {

console.log("upload success", res.data);

},
 fail: (error) => {

console.log("upload fail", error);

},
});

  1. 更改上传文件的 key 名称

在客户端,我们通过表单数据 append 的方式将文件列表拼装成 formData 。此时,每个文件的 key 默认是它在 formData 中的位置,即从 0 开始的递增数字。而服务器接收到的 key 可能是上传组件里面指定的 name 值,因此,在上传文件时可以为每个文件指定一个 key 名称,如下:

this.fileList.forEach((item, index) => {
 formData.append("file" + index, item.path);
});

由于这里的 file 不同于上传组件的 name 属性值,因此在后端处理时也应对应修改。

foreach($_FILES as $file) {
 $tmp_name = $file["tmp_name"];
 $name = $file["name"];
 if (move_uploaded_file($tmp_name, $upload_dir . $name)) {

echo "upload success ";

} else {

echo "upload fail ";

}
}

  1. 高版本 PHP 需要增加参数修改 php.ini

对于高版本 PHP,需要在 php.ini 文件中增加以下参数:

post_max_size=20M  
upload_max_filesize=20M  
max_execution_time=600  
max_input_time=600

设置完毕后,需要重启 Apache 才能生效。

四、总结

本篇文章探讨了 uniapp 多图上传时传递图片信息无法被 PHP 接收的问题,通过修改请求头信息、更改上传文件的 key 名称和配置 php.ini 文件等方式,成功解决了问题。最后,建议 Web 开发者在使用 uniapp 进行移动端应用开发中,要注意对上传功能进行有效的测试,减少不必要的错误和损失。