一.开发小插曲
这里是牢骚部分,可以直接跳过到代码部分,最近遇到一个需求是上传excel文件解析数据到数据库存储,一开始是用postman上传文件,后来发现上传不了,网上各种能上传的都试过了,最后从项目架构着手,项目使用的不是原生springmvc,经过封装,并且是前后台分离,前台是angular+node.查看web.xml发现dispatchservlet也是封装的,springmvc文件上传配置也没有,抱着侥幸的心理,各种配置一番,springmvc该有的文件上传配置都有了,我在其他项目中是实现过文件上传功能,所以配置并没什么难度,但是因为框架不同的原因,接口上传还是没有完成,所以框架好不好用真的给开发效率带来很大不同。
既然springmvc的自带功能不能使用,干脆用HttpServletRequest上传文件,这个项目是刚创建不久的微服务,框架没有JSP视图解析器什么也没有,就是一番捣鼓,因为这个功能不需要放在分离出来的前端angular+node的项目当中,所以直接在这个本来是提供接口出去的微服务中开发前端。
二.坑
1.form表单增加enctype="multipart/form-data"属性后,sprinmvc的方法入参@RequestParameter得不到数据,不知道其它框架怎么样,或许是这边springmvc不是原声的原因;
2.form表单增加enctype="multipart/form-data"属性后,HttpServletRequest request请求使用getparameter(name)得不到数值,得到数据的代码在下文当中
三.代码
因为公司代码不能考出来,以下代码为参考代码,主要方法都在这里
JSP页面:
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>文件上传实例</title> </head> <body> <h1>文件上传实例</h1> <form method="post" action="/TomcatTest/UploadServlet" enctype="multipart/form-data"> 选择一个文件: <input type="file" name="uploadFile" /> <br/><br/> <input type="submit" value="上传" /> </form> </body> </html>
JAVA controller参考代码:
// 上传文件存储目录 private static final String UPLOAD_DIRECTORY = "upload"; // 上传配置 private static final int MEMORY_THRESHOLD = 1024 * 1024 * 3; // 3MB private static final int MAX_FILE_SIZE = 1024 * 1024 * 40; // 40MB private static final int MAX_REQUEST_SIZE = 1024 * 1024 * 50; // 50MB /** * 上传数据及保存文件 */ @Requestmapping("upload") public String uploadPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // 检测是否为多媒体上传 if (!ServletFileUpload.isMultipartContent(request)) { // 如果不是则停止 PrintWriter writer = response.getWriter(); writer.println("Error: 表单必须包含 enctype=multipart/form-data"); writer.flush(); return; } // 配置上传参数 DiskFileItemFactory factory = new DiskFileItemFactory(); // 设置内存临界值 - 超过后将产生临时文件并存储于临时目录中 factory.setSizeThreshold(MEMORY_THRESHOLD); // 设置临时存储目录 factory.setRepository(new File(System.getProperty("java.io.tmpdir"))); ServletFileUpload upload = new ServletFileUpload(factory); // 设置最大文件上传值 upload.setFileSizeMax(MAX_FILE_SIZE); // 设置最大请求值 (包含文件和表单数据) upload.setSizeMax(MAX_REQUEST_SIZE); // 中文处理 upload.setHeaderEncoding("UTF-8"); // 构造临时路径来存储上传的文件 // 这个路径相对当前应用的目录 String uploadPath = request.getServletContext().getRealPath("./") + File.separator + UPLOAD_DIRECTORY; // 如果目录不存在则创建 File uploadDir = new File(uploadPath); if (!uploadDir.exists()) { uploadDir.mkdir(); } try { // 解析请求的内容提取文件数据 @SuppressWarnings("unchecked") List<FileItem> formItems = upload.parseRequest(request); if (formItems != null && formItems.size() > 0) { // 迭代表单数据 for (FileItem item : formItems) { if (!item.isFormField()) { // 处理文件 String fileName = new File(item.getName()).getName(); String filePath = uploadPath + File.separator + fileName; File storeFile = new File(filePath); // 在控制台输出文件的上传路径 System.out.println(filePath); // 保存文件到硬盘 item.write(storeFile); request.setAttribute("message", "文件上传成功!"); }else{//这里处理非文件字段 String name = item.getFieldName(); //解决普通输入项的数据的中文乱码问题 String value = item.getString("UTF-8"); //value = new String(value.getBytes("iso8859-1"),"UTF-8"); System.out.println(name + "=" + value); } } } } catch (Exception ex) { request.setAttribute("message", "错误信息: " + ex.getMessage()); } return "page"; }