element 上传fileUpload 同步【文本编码格式】

7 篇文章 0 订阅

fileUpload 普通判断无法阻止条件判断
需使用Promise + (async + await ) 加以阻止

html

<el-upload
  class="hot-upload"
  :action="fileUrl"
  :headers="fileHeaders"
  :on-progress="fileProgress"
  :before-upload="fileUpload"
  :on-success="fileSuccess"
  :multiple="false"
  :show-file-list="false"
  :on-exceed="handleExceed"></el-upload>

js

// 上传前检测【检测文本编码格式】
import {isUtf8} from "@/utils";

fileUpload(file) {
 // resolve(file) 正确放行file
 return new Promise(async (resolve, reject) => {
   const isTxt = file.type === "text/plain";
   const isLt12M = file.size / 1024 / 1024 < 12;
   if (!isTxt) {
     this.$toast({
       message: "请按照提示要求上传对应TXT文件格式",
       type: 2
     });
     return reject(false);
   }
   if (!isLt12M) {
     this.$toast({
       message: "文件超过12MB大小,请按照要求整理上传",
       type: 2
     });
     return reject(false);
   }
   try {
     await isUtf8(file);
   } catch (e) {
     this.$toast({
       message: "编码格式错误,请上传 UTF-8 格式文件",
       type: 2
     });
     return reject(false);
   }
   return resolve(file);
 });
},

封装方法

// 判断文本编码格式
export async function isUtf8 (file) {
  return await new Promise((resolve, reject) => {
    const reader = new FileReader();
    reader.readAsText(file);

    reader.onloadend = (e) => {
      const str = e.target.result;
      // 大致取一半
      const sampleStr = str.slice(4, 4 + str.length / 2);
      if (sampleStr.indexOf("�") === -1) {
        resolve(true);
      } else {
        reject(new Error("编码格式错误,请上传 UTF-8 格式文件"));
      }
    };

    reader.onerror = () => {
      reject(new Error("文件内容读取失败,请检查文件是否损坏"));
    };
  });
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
commons-fileupload是一个用于处理文件上的Java类库。它提供了简单易用的API,可以用于实现文件上功能。要使用commons-fileupload,你需要进行以下步骤: 1. 导入commons-fileupload库:下载commons-fileupload库的jar文件,并将其添加到你的项目中。 2. 创建Servlet或Controller类:创建一个处理文件上的Servlet或Controller类。 3. 创建DiskFileItemFactory对象:使用DiskFileItemFactory类创建一个文件项工厂对象,设置临时文件存储路径和内存缓冲区大小。 4. 创建ServletFileUpload对象:使用ServletFileUpload类创建一个文件上对象,并设置文件上的大小限制和字符编码。 5. 解析请求:使用ServletFileUpload对象的parseRequest()方法解析请求,得到FileItem对象的列表。 6. 处理文件:遍历FileItem对象的列表,对每个文件项进行处理。你可以判断文件项是否是普通字段还是文件,以及获取字段名称、文件名、文件大小等信息。 以下是一个简单的示例代码: ```java import org.apache.commons.fileupload.*; import org.apache.commons.fileupload.disk.*; import org.apache.commons.fileupload.servlet.*; import javax.servlet.http.*; import java.io.*; import java.util.*; public class FileUploadServlet extends HttpServlet { protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { DiskFileItemFactory factory = new DiskFileItemFactory(); ServletFileUpload upload = new ServletFileUpload(factory); try { List<FileItem> items = upload.parseRequest(request); for (FileItem item : items) { if (item.isFormField()) { // 处理普通字段 String fieldName = item.getFieldName(); String fieldValue = item.getString(); // ... } else { // 处理文件 String fieldName = item.getFieldName(); String fileName = item.getName(); long fileSize = item.getSize(); // ... } } // 文件上成功 response.getWriter().println("文件上成功!"); } catch (FileUploadException e) { // 文件上失败 response.getWriter().println("文件上失败!"); } } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值