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();
    }
  }
};
相关推荐
anyup9 小时前
uView Pro 的主题系统有多强大?3 分钟设计 uni-app 企业级 UI 主题
前端·vue.js·uni-app
怀君15 小时前
Uniapp——View布局生成图片转PDF
pdf·uni-app
2501_9159214315 小时前
uni-app一键生成iOS安装包并上传TestFlight全流程
android·ios·小程序·https·uni-app·iphone·webview
久爱@勿忘15 小时前
uniapp H5 图片压缩并且转blob
前端·javascript·uni-app
Dashingl15 小时前
uni-app 页面传值 报错:TypeError: $t.setAttribute is not a function
前端·javascript·uni-app
橘子编程2 天前
UniApp跨端开发终极指南
开发语言·vue.js·uni-app
叱咤少帅(少帅)4 天前
Uniapp开发pc端,小程序和APK
小程序·uni-app
2501_915918414 天前
iOS性能测试工具 Instruments、Keymob的使用方法 不局限 FPS
android·ios·小程序·https·uni-app·iphone·webview
2501_915918415 天前
iOS 混淆流程 提升 IPA 分析难度 实现 IPA 深度加固
android·ios·小程序·https·uni-app·iphone·webview
前端 贾公子5 天前
解决uni-app 输入框,键盘弹起时页面整体上移问题
前端·vue.js·uni-app