uniapp APP 上传PDF文件

uniapp APP端

文件上传使用plus.io.chooseFile

图片上传使用uni.chooseImage

如果两种需求都存在的情况下使用plus.nativeUI.actionSheet 做一个判断 调用uni.uploadFile实现上传,只不过APP端需要使用plus.io.chooseFile来选取文件调起移动端文件列表

javascript 复制代码
 plus.nativeUI.actionSheet(
    {
      title: "选择上传类型",
      cancel: "取消",
      buttons: [{ title: "选择图片" }, { title: "选择文件" }],
    },
    (e) => {
      switch (e.index) {
        case 1:
          handleChooseImage();
          break;
        case 2:
          handleChooseFile();
          break;
      }
    }
  );

图片上传

javascript 复制代码
const handleChooseImage = async () => {
  const remainCount = getRemainCount();

  try {
    const selectResult = await uni.chooseImage({
      count: remainCount,
      sizeType: ["original", "compressed"],
      sourceType: ["album", "camera"],
    });

    for (const tempFile of selectResult.tempFiles) {
      await uploadSingleFile(tempFile);//上传方法
    }
  } catch (error) {
    const errMsg = error?.errMsg || "";
    if (errMsg && !errMsg.includes("cancel")) {
      uni.showToast({
        title: "选择图片失败:" + errMsg,
        icon: "none",
      });
    }
  }
};

文件上传

javascript 复制代码
const handleChooseFile = async () => {
  try {
    const result = await new Promise((resolve, reject) => {
      plus.io.chooseFile(
        {
          title: "选择文件",
          filter: {
            mimeTypes: ["application/pdf", "image/*"],
            extensions: ["pdf", "jpg", "jpeg", "png", "gif", "bmp", "webp"],
          },
          multiple: true,
          maximum: getRemainCount(),
        },
        (result) => {
          if (!result || !result.files || result.files.length === 0) {
            reject("未选择任何文件");
            return;
          }
          resolve(result);
        },
        (err) => {
          reject("选择文件失败:" + err.message);
        }
      );
    });

    const files = result.files;

    for (const filePath of files) {
      await uploadSingleFile({ path: filePath });
    }
  } catch (error) {
    if (error !== "未选择任何文件" && !error.includes("cancel")) {
      uni.showToast({
        title: typeof error === "string" ? error : "选择文件失败",
        icon: "none",
      });
    }
  }
};

公共方法

javascript 复制代码
const uploadSingleFile = async (tempFile) => {
  let loadingShown = false;
  try {
    const isImage = isImageFile(tempFile);
    const uploadUrl = isImage
      ? getUrl("/api/upload/picture")
      : getUrl("/api/upload/file");
    const fileName = isImage ? "picture" : "file";

    loadingShown = true;
    uni.showLoading({
      title: `正在上传: ${tempFile.path.split("/").pop()}`,
      mask: true,
    });

    const uploadResult = await new Promise((resolve, reject) => {
      uni.uploadFile({
        url: uploadUrl,
        filePath: tempFile.path,
        name: fileName,
        formData: { zip: "1" },
        success: (uploadRes) => {
          try {
            const data = JSON.parse(uploadRes.data);
            if (data.code === 200) {
              resolve(data);
            } else {
              reject(data.message || "上传失败");
            }
          } catch (e) {
            reject("解析上传结果失败");
          }
        },
        fail: (err) => {
          reject("上传失败:" + (err.errMsg || "网络错误"));
        },
      });
    });

    const serverFilePath =
      uploadResult.data?.path || uploadResult.data?.url || uploadResult.path;
    if (serverFilePath) {
      const fileObj = {
        name: tempFile.name || tempFile.path.split("/").pop(),
        path: serverFilePath,
        url: serverFilePath,
        size: tempFile.size || 0,
      };

      if (userInfo[currentUploadField.value].length < 20) {
        userInfo[currentUploadField.value].push(fileObj);
        uni.showToast({
          title: "上传成功",
          icon: "success",
        });
      }
    } else {
      throw new Error("服务器未返回文件路径");
    }
  } catch (error) {
    console.error("上传文件失败:", error);
    throw error;
  } finally {
    if (loadingShown) {
      uni.hideLoading();
    }
  }
};
相关推荐
中国胖子风清扬1 天前
GPUI 在 macOS 上编译问题排查指南
spring boot·后端·macos·小程序·rust·uni-app·web app
码云数智-园园2 天前
uni-app 实现物流进度跟踪功能:从 UI 到数据驱动的完整方案
ui·uni-app
予你@。4 天前
UniApp + Vue3 实现 Tab 点击滚动定位(微信小程序)
微信小程序·小程序·uni-app
游戏开发爱好者84 天前
完整教程:App上架苹果App Store全流程指南
android·ios·小程序·https·uni-app·iphone·webview
予你@。4 天前
uni-app progress 组件使用详解
uni-app
iOS阿玮4 天前
春节提审高峰来袭!App Store 审核时长显著延长。
uni-app·app·apple
2501_916007474 天前
ios上架 App 流程,证书生成、从描述文件创建、打包、安装验证到上传
android·ios·小程序·https·uni-app·iphone·webview
2501_915106325 天前
iPhone 文件管理,如何进行应用沙盒文件查看
android·ios·小程序·https·uni-app·iphone·webview
2501_915921435 天前
Fastlane 结合 AppUploader 来实现 CI 集成自动化上架
android·运维·ci/cd·小程序·uni-app·自动化·iphone
云游云记5 天前
vue2 vue3 uniapp (微信小程序) v-model双向绑定
微信小程序·uni-app·vue