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();
    }
  }
};
相关推荐
一颗小青松11 小时前
uniapp输入框fixed定位,导致页面顶起解决方案
前端·uni-app
2501_9151063218 小时前
深入解析无源码iOS加固原理与方案,保护应用安全
android·安全·ios·小程序·uni-app·cocoa·iphone
万能小林子19 小时前
2026 AI开发新范式:Vibe Coding生成网页 + 3分钟打包成App,非技术人也能独立发布自己的App!
人工智能·uni-app·ai编程·web app·vibecoding
一颗小青松21 小时前
uniapp 集成友盟并且上传页面路径
前端·vue.js·uni-app
00后程序员张2 天前
HTTPS单向认证、双向认证、抓包原理与反抓包策略详解
网络协议·http·ios·小程序·https·uni-app·iphone
h_65432102 天前
uniapp-APP端获取拍照时的方向角,同一位置横竖屏拍方向角一致
uni-app
梦梦代码精2 天前
LikeShop按摩到家系统:2026年本地生活创业新风口,上门服务O2O源码私有化部署实战
大数据·docker·小程序·uni-app·生活·高并发·开源软件
这是个栗子2 天前
【uni-app微信小程序问题解决】Uni-app 微信小程序组件不渲染
微信小程序·小程序·uni-app
梦梦代码精2 天前
LikeShop开源多端商城系统:半年使用记录
git·uni-app·github