springmvc 多文件上传 MultipartFile

[code="java"]
public String upload2(MultipartHttpServletRequest request, @RequestParam("name") String name){
List files = (List) request.getFile("myfiles");
}
//修改成如下方法,还是报同样下面的错误:
public String upload2(MultipartHttpServletRequest request, @RequestParam("name") String name, // 页面上的控件值
@RequestParam MultipartFile[] myfiles) {
List files = Arrays.asList(myfiles);
}
// jsp页面,传一个myfiles,单个文件是可以通过的,
[/code]
[code="html"]





[/code]

报错:[code="java"]

org.springframework.web.multipart.MultipartException: Multiple files for field name [myfiles] found - not supported by MultipartResolver
at org.springframework.web.multipart.commons.CommonsFileUploadSupport.parseFileItems(CommonsFileUploadSupport.java:254)
at org.springframework.web.multipart.commons.CommonsMultipartResolver.parseRequest(CommonsMultipartResolver.java:166)
at org.springframework.web.multipart.commons.CommonsMultipartResolver.resolveMultipart(CommonsMultipartResolver.java:149)
at org.springframework.web.servlet.DispatcherServlet.checkMultipart(DispatcherServlet.java:1015)
at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:851)
at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:807)
at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:571)
at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:511)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:643)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:723)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:96)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:76)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:861)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:606)
at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489)
at java.lang.Thread.run(Thread.java:619)

[/code]

4个回答

你的spring和commons-fileupload版本是多少。

我使用spring3.2.2 commons-fileupload:1.2.2没有问题

love_zongming
龙西庄庄主 修改了spring的版本之后, 现在可以了! request.getFiles()这个方法有了 。
6 年多之前 回复
love_zongming
龙西庄庄主 spring.2.5.6 commons-fileupload:1.2.2, 没有request.getFiles()这个方法呢, 只有getFile这个方法, 我修改版本试试先
6 年多之前 回复
love_zongming
龙西庄庄主 List<MultipartFile> files = new LinkedList<MultipartFile>(); files = multipartRequest.getFiles("attach"); 采用了这种方式,没有找到getFiles()这个方法, 只有getFile()方法。报错同上~
6 年多之前 回复





上面的name改成不一样试试,然后代码里边
MultipartFile file1 = (MultipartFile) request.getFile("myfiles");

MultipartFile file2 = (MultipartFile) request.getFile("myfiles2");

这样子试试。

love_zongming
龙西庄庄主 谢谢了, 这样子可以的,我目前需要传递相同的name参数过去,
6 年多之前 回复
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"/>
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
SpringMVC中如何获取多个名字未知的上传文件?
一般情况下SpringMVC通过requestparam和MultipartFile获取上传的文件,其中注解requestparam必须要指定文件参数的name。 现在的我的需求是在不知有多少文件上传,也不知道文件参数名的情况下获取到所有上传的文件的信息,等高手来指点一下!
springmvc 上传MultipartFile
# 直接看代码,如果前台页面不带有上传文件,就进不了controller, ``` @RequestMapping(value="/addApplicationFile") public void addApplicationFile( ApplicationFile applicationFile,HttpServletRequest request,HttpServletResponse response,@RequestParam(value="file", required=false) MultipartFile file){ Map<String, Object> resultMap = new HashMap<String,Object>(); boolean localUploadStatus = false; boolean ftpUploadStatus = false; OptionsItems optionsItems = null; Long userId = null; FtpFileList ftpFileList = null; try { userId = SystemUtil.getUserId(request); //设置请求编码 if( null == userId ){ SystemUtil.userInvalid(request, response); return; } if( null == applicationFile || null == applicationFile.getFileName() || applicationFile.getFileName().equals("") || null == applicationFile.getApplicationVersion() || applicationFile.getApplicationVersion().equals("") || null == applicationFile.getApplicationName() || applicationFile.getApplicationName().equals("") || null == applicationFile.getFileType() || applicationFile.getFileType().equals("") ){ resultMap.put(Constant.SHRG_STATUS, Constant.RESULT_STATUS_ERROR); resultMap.put(Constant.SHRG_MESSAGE, Constant.REQUEST_PARAM_ERROR); SystemUtil.outputJsonObject(resultMap, response); return; } int length = applicationFileService.validateApplicationName(applicationFile); if(length>0){ resultMap.put(Constant.SHRG_FLAG, Constant.RESULT_STATUS_FLAG); resultMap.put(Constant.SHRG_MESSAGE, Constant.APPLICATION_FILE_IS_EXIST); SystemUtil.outputJsonObject(resultMap, response); return; } //先上传再入库 if (null != file && !file.isEmpty()) { //文件上传路径 StringBuffer realPath = new StringBuffer();//tomcat相对路径 realPath.append(Constant.PATH_SEPARATOR_SLASH).append(Constant.PATH_APPLICATION_UPLOAD);//PATH_APPLICATION_UPLOADnew String(Constant.PATH_APPLICATION_UPLOAD.getBytes("GBK"),"iso-8859-1") //在数据得到上传的类型 optionsItems = new OptionsItems(); optionsItems.setModule(Constant.INFO_DIFF); optionsItems.setOptionCode(Constant.APP_UPLOAD_FILE_TYPE); List<OptionsItems> listO = optionsItemsService.initOptionsItem(optionsItems); optionsItems = new OptionsItems(); optionsItems.setModule(Constant.TER); optionsItems.setOptionCode(Constant.SOFTWARE_UPDATE_FILE_TYPE); List<OptionsItems> listT = optionsItemsService.initOptionsItem(optionsItems); //执行上传 if(applicationFile.getUploadType() != null && Constant.UPLOAD_TYPE_A.equals(applicationFile.getUploadType())){ String fileType = listO.get(0).getAttribute1(); fileType = fileType.replaceAll("\\.", ""); ftpFileList = FileUpload.upload(file,realPath.toString(), fileType,request); }else{ String fileType = listT.get(0).getAttribute1(); fileType = fileType.replaceAll("\\.", ""); ftpFileList = FileUpload.upload(file,realPath.toString(),fileType,request); } if(null !=ftpFileList) localUploadStatus = true; ftpUploadStatus = FtpManager.getInstance().uploadFile(ftpFileList.getPath(), ftpFileList.getFtpFilename(), ftpFileList.getFtpPath()); FileUtil.delFile(ftpFileList.getPath(),ftpFileList.getFtpFilename());//删除本地文件 applicationFile.setFileSize(ftpFileList.getFileSize()+""); applicationFile.setFileType(ftpFileList.getFileSuffix()); applicationFile.setFtpFileName(ftpFileList.getFtpFilename()); applicationFile.setFtpFilePath(ftpFileList.getFtpPath()+Constant.PATH_SEPARATOR_SLASH); applicationFile.setCreatedBy(userId); applicationFile.setLastUpdateBy(userId); //文件上传之后,再将文件 入库 applicationFileService.addApplicationFile(applicationFile); resultMap.put(Constant.SHRG_STATUS, Constant.RESULT_STATUS_SUCCESS); resultMap.put(Constant.SHRG_MESSAGE, Constant.ADD_SUCCESS); }else{ resultMap.put(Constant.SHRG_STATUS, Constant.RESULT_STATUS_ERROR); resultMap.put(Constant.SHRG_MESSAGE, Constant.UPLOAD_FILE_IS_NULL); } SystemUtil.outputJsonObject(resultMap, response); }catch(Exception ex){ ex.printStackTrace(); if(ftpUploadStatus){ String deletePath = ftpFileList.getFtpPath()+Constant.PATH_SEPARATOR_SLASH +ftpFileList.getFtpFilename(); try { FtpManager.getInstance().removeFile(deletePath); } catch (Exception e) { int resultCodeA = ShrgLog.exceptionLogMap(this, Constant.ERROR_LEVEL, Constant.INFO_DIFFUSION_PUBLISH, Constant.ADD_UPLOAD_APPLICATION_FILT, e,userId); SystemUtil.exceptionHandle(response, resultCodeA); } }else if(localUploadStatus){ FileUtil.delFile(ftpFileList.getPath(),ftpFileList.getFtpFilename());//删除本地文件 } int resultCode = ShrgLog.exceptionLogMap(this, Constant.ERROR_LEVEL, Constant.INFO_DIFFUSION_PUBLISH, Constant.ADD_UPLOAD_APPLICATION_FILT, ex,userId); SystemUtil.exceptionHandle(response, resultCode); } ```
用springMVC的Multipartfile可以实现视频的上传吗?
用springMVC的Multipartfile可以实现视频的上传吗? 如果可以该怎么做像上传文件一样吗 大神救急
springMVC上传文件报错404
学习springMVC文件上传的时候,选择了文件提交以后报错404 jsp ``` <%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>文件上传</title> </head> <body> <h3>文件上传</h3> <form action="/User/fileUpload" method="post" enctype="multipart/form-data"> <input type="file" name="upload"><br/> <input type="submit" value="上传"> </form> </body> </html> ``` spring-MVC配置如下 ``` <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:p="http://www.springframework.org/schema/p" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation=" http://www.springframework.org/schema/beans https://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/mvc https://www.springframework.org/schema/mvc/spring-mvc.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd"> <!--开启注解扫描--> <context:component-scan base-package="com.ryn"/> <!--配置视图解析器--> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <!--配置解析器--> <property name="suffix" value=".jsp"/> <!--配置目录--> <property name="prefix" value="/WEB-INF/pages/"/> </bean> <!--配置静态资源--> <mvc:resources location="/upload/" mapping="/upload/**" /> <mvc:resources mapping="/js/**" location="js/"/> <!--配置文件解析器--> <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <property name="defaultEncoding" value="utf-8"/> <property name="maxUploadSize" value="10485760"/> </bean> <!--开启springMVC框架注解的支持--> <mvc:annotation-driven/> </beans> ``` web.xml配置 ``` <!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd" > <web-app> <display-name>Archetype Created Web Application</display-name> <!--配置前端控制器--> <servlet> <servlet-name>dispatcherServlet</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:spring-mvc.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>dispatcherServlet</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> </web-app> ``` uploadController ``` /** * 文件上传 * @return */ @RequestMapping("/fileUpload") public String fileUpload(HttpServletRequest request, @RequestParam("upload") MultipartFile upload) throws Exception{ System.out.println("文件上传"); //指定上传位置 String path = request.getSession().getServletContext().getRealPath("/upload/"); //判断文件夹是否存在 File file = new File(path); if (!file.exists()){ //若不存在,则创建文件夹 file.mkdirs(); } String filename = upload.getOriginalFilename(); //使用write方法上传文件 String uuid = UUID.randomUUID().toString().replaceAll("-", "").toUpperCase(); filename = uuid + "_" + filename; upload.transferTo(new File(path,filename)); return "success"; } ``` 报错信息如下 ![图片说明](https://img-ask.csdn.net/upload/201911/14/1573725685_322217.jpg) 求各位大佬帮我看看问题到底出在哪了!!!弄了半个小时不知道怎么回事
springmvc MultipartFile 重复上传同一张图片ear.jpg 如何设置服务器不会增加这张图片
文件上传后 自动 生成 时间戳+随机码 但是 我的后台需要上传的图片有重复的 不想让他重新生成新的图片新的名字 控制器部分代码 ``` MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request; // 图片上传 MultipartFile left_img = multipartRequest.getFile("left_img");// 上传左图原文件 MultipartFile right_img = multipartRequest.getFile("right_img");// 上传右图原文件不仅仅是名字 FileUtil fileUtil = new FileUtil(); String fileRoot = request.getSession().getServletContext().getRealPath("upload/handAcupoint"); System.out.println("fileRoot:" + fileRoot); String type = multipartRequest.getParameter("type"); String id = multipartRequest.getParameter("id1"); String code = multipartRequest.getParameter("num"); String name = multipartRequest.getParameter("name"); String en_name = multipartRequest.getParameter("en_name"); String pinyin = multipartRequest.getParameter("pinyin"); String location = multipartRequest.getParameter("location"); String left_x = multipartRequest.getParameter("left_x"); String left_y = multipartRequest.getParameter("left_y"); String right_x = multipartRequest.getParameter("right_x"); String right_y = multipartRequest.getParameter("right_y"); String zhuzhi = multipartRequest.getParameter("zhuzhi"); String leftFileName = null; String rightFileName = null; String yleftName = null; // 原来左图片名字 String yrightName = null;// 原来右图片名字 String res = null; int code1 = Integer.parseInt(code); int right_x1 = Integer.parseInt("0" + right_x); int right_y1 = Integer.parseInt("0" + right_y); int left_x1 = Integer.parseInt("0" + left_x); int left_y1 = Integer.parseInt("0" + left_y); if (type.equals("0")) {// 添加手诊穴位信息 leftFileName = fileUtil.saveImg(left_img, fileRoot, yleftName); // 左图 rightFileName = fileUtil.saveImg(right_img, fileRoot, yrightName); // 右图 int num = handDiagnosisService.saveHandAcupoint(code1, name, en_name, pinyin, location, leftFileName, rightFileName, left_x1, left_y1, right_x1, right_y1, zhuzhi); if (num != 0) { res = "1001";// 添加成功 } else { res = "1002";// 添加失败 } OutputUtil.outPutString(response, res); } ``` 上传类代码 ``` public class FileUtil { /** * 上传图片 * @param imgFile 图片文件 * @param fileRoot 目标地址 * @param fileName 图片名称 * @return * @throws IOException * @throws IllegalStateException */ public String saveImg(MultipartFile imgFile,String fileRoot,String fileName) throws IllegalStateException, IOException{ if(imgFile == null){ return null; } File src = new File(fileRoot); if (!src.exists()) { src.mkdirs(); } fileName = fileName==null?System.currentTimeMillis()+ new Random().nextInt(100000)+".jpg":fileName; /* String fileName = System.currentTimeMillis()+ new Random().nextInt(100000)+".jpg"; //图片名 */ File newFile = new File(src, fileName); imgFile.transferTo(newFile); return fileName; } } ``` **这是图片 同一张图片重复好多次** ![图片说明](https://img-ask.csdn.net/upload/201610/25/1477388105_516255.jpg)
SpringMVC跨服务器上传文件,上传至文件服务器时报404错误
这是服务器端的代码 ``` @RequestMapping("/fileupload") public String upload(MultipartFile upload) throws IOException { System.out.println("SpringMVC跨服务器方式的文件上传..."); // 定义图片服务器的请求路径 String path = "http://localhost:9090/secondly_war_exploded/uploads/"; // 获取到上传文件的名称 String filename = upload.getOriginalFilename(); // 向图片服务器上传文件 // 创建客户端对象 Client client = Client.create(); // 连接图片服务器 WebResource webResource = client.resource(path+filename); // 上传文件 webResource.put(upload.getBytes()); return "success"; } ``` 这是报错的信息: ![图片说明](https://img-ask.csdn.net/upload/201910/05/1570271504_300400.png) 报错的核心信息是上传到图片服务器的时候404错误。 起初我以为是我的路径写的有问题或者服务器没开,然后我将路径直接粘贴到地址栏上,并没有任何问题: ![图片说明](https://img-ask.csdn.net/upload/201910/05/1570271649_380764.png) 本人在网上找了许久,也不见符合的相关答案
用springMVC框架做文件上传时遇到问题
我是基于red5服务器。来用springMVC框架做文件上传。在上传文件时遇到错误。 @RequestMapping(value = "/upload.do",method = RequestMethod.POST) public String upload(HttpServletRequest request, HttpServletResponse response, String string) { System.out.println("==================run in import"); System.out.println("--------------" + request.getParameter("upload")); // 创建一个通用的多部分解析器. CommonsMultipartResolver commonsMultipartResolver = new CommonsMultipartResolver( request.getSession().getServletContext()); // 设置编码 commonsMultipartResolver.setDefaultEncoding("utf-8"); System.out.println("++++++commonsMultipartResolver.isMultipart(request) : " + commonsMultipartResolver.isMultipart(request)); // 判断是否有文件上传 if (commonsMultipartResolver.isMultipart(request)) { MultipartHttpServletRequest multipartRequest = commonsMultipartResolver .resolveMultipart(request); Iterator<String> iter = multipartRequest.getFileNames(); System.out.println("+++++++++++iter = "+iter.toString()); // iter里面没有值 while (iter.hasNext()) { MultipartFile file = multipartRequest.getFile((String) iter.next()); if (file != null) { File localFile = new File("/WEB-INF/upload" + file.getOriginalFilename()); try { // file.transferTo(localFile); System.out.println("=======1111111111111===="); file.transferTo(localFile); System.out.println("====222222222222222======="); } catch (IllegalStateException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } } // 批量上传 // Map<String, MultipartFile> fileMap = request.getFileMap(); // for(Entry<String, MultipartFile> entry : fileMap.entrySet()){ // MultipartFile file = entry.getValue(); // try { // file.transferTo(new File("/WEB-INF/upload" + // file.getOriginalFilename())); // } catch(IllegalStateException e){ // e.printStackTrace(); // }catch (Exception e) { // // TODO: handle exception // e.printStackTrace(); // } // } return "up"; } } 上传文件后,在我指定的地方没有找到文件。测试发现 if (commonsMultipartResolver.isMultipart(request)) 这个地方获得的是false,我这个action没有接收到上传的文件,但是通过System.out.println("--------------" + request.getParameter("upload"));获取到了我上传文件的文件名。 通过上网查找,我在配置文件中配置了MultipartResolver处理器 <!-- SpringMVC上传文件时,需要配置MultipartResolver处理器 --> <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <!-- 指定所上传文件的总大小不能超过200KB。注意maxUploadSize属性的限制不是针对单个文件,而是所有文件的容量之和 --> <property name="maxUploadSize" value="200000"/> </bean> <!-- SpringMVC在超出上传文件限制时,会抛出org.springframework.web.multipart.MaxUploadSizeExceededException --> <!-- 该异常是SpringMVC在检查上传的文件信息时抛出来的,而且此时还没有进入到Controller方法中 --> <bean id="exceptionResolver" class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver"> <property name="exceptionMappings"> <props> <!-- 遇到MaxUploadSizeExceededException异常时,自动跳转到/WEB-INF/jsp/error_fileupload.jsp页面 --> <prop key="org.springframework.web.multipart.MaxUploadSizeExceededException">error_fileupload</prop> </props> </property> </bean> 如果我在代码最上面写 MultipartHttpServletRequest rrr = (MultipartHttpServletRequest) request; 他就会报转化错误 java.lang.ClassCastException: org.apache.catalina.connector.RequestFacade cannot be cast to org.springframework.web.multipart.MultipartHttpServletRequest 不知道现在是什么问题,求解啊!
springmvc文件上传问题
MultipartFile .png .text上传后 CommonsMultipartFile cf = (CommonsMultipartFile)endorsementfile; DiskFileItem fi = (DiskFileItem) cf.getFileItem(); File file = fi.getStoreLocation(); file.isfile() 判断结果不是文件返回false 我需要完成上传文件不一样时不会重复上传 类似网盘 我采用的MD5加密重命名 但是需要传入File类型
springmvc 文件上传过大时异常处理出错
我用springmvc的multipartfile组件做了一个上传文件的接口,文件大小限定了2M, ![图片说明](https://img-ask.csdn.net/upload/201611/09/1478683504_487509.png) 接着在ExceptionHandler里面捕获异常FileUploadBase.SizeLimitExceededException ![图片说明](https://img-ask.csdn.net/upload/201611/09/1478683572_773042.png) 测试一个3M的文件,结果发现异常是可以正常捕获,但是却没办法取得正常的返回, @ResponseBody注解好像没有生效,跳转到其他页面了 ![图片说明](https://img-ask.csdn.net/upload/201611/09/1478684299_598102.png) 有没有大神知道的?
SpringMVC上传文件参数传递错误?
java类代码(部分): ``` @RequestMapping(value= "/doUpload", method = RequestMethod.POST) public String uploadFileHandler(HttpServletRequest request,Model model, @RequestParam("file") MultipartFile[] files) { //Root Directory String uploadRootPath = request.getServletContext().getRealPath("upload"); System.out.println("uploadRootPath=" + uploadRootPath); File uploadRootDir = new File(uploadRootPath); if(!uploadRootDir.exists())//Creat if it not exists { uploadRootDir.mkdirs(); } List<File> uploadedFiles = new ArrayList<File>(); for (int i=0;i<files.length;i++) { MultipartFile file = files[i]; String name = file.getOriginalFilename(); System.out.println("Client File Name = " + name); if(name != null && name.length() > 0) { try { byte[] bytes = file.getBytes(); File serverFile = new File(uploadRootDir.getAbsolutePath() + File.separator + name); BufferedOutputStream stream = new BufferedOutputStream(new FileOutputStream(serverFile)); stream.write(bytes); stream.close(); uploadedFiles.add(serverFile); System.out.println("Write file: "+ serverFile); } catch(Exception e) { System.out.println("Error Write file : "+ name); } } } model.addAttribute("uploadedFiles", uploadedFiles); return "uploadResult"; } ``` jsp文件: ``` <%@ page language="java" import="java.util.*" pageEncoding="ISO-8859-1"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Upload Multi File</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css"> --> </head> <body> <h2>Upload Multiple File:</h2> <form method="POST" action="doUpload" enctype="multipart/form-data"> File to upload (1): <input type="file" name="file"><br /> File to upload (2): <input type="file" name="file"><br /> File to upload (3): <input type="file" name="file"><br /> File to upload (4): <input type="file" name="file"><br /> File to upload (5): <input type="file" name="file"><br /> <input type="submit" value="Upload"> </form> </body> </html> ``` 错误信息: HTTP Status 400 - Required MultipartFile[] parameter 'file' is not present type: Status report message: Required MultipartFile[] parameter 'file' is not present description: The request sent by the client was syntactically incorrect. 初学者,百思不得其解
Springmvc上传文件限制大小,异常处理返回报错信息后,eclipse控制台还报错
**1、web.xml配置:** ``` <?xml version="1.0" encoding="UTF-8"?> <web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"> <!-- 注册主控制器DispatcherServlet --> <servlet> <servlet-name>DispatcherServlet</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <!-- 指定spring配置文件位置 --> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:applicationContext.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>DispatcherServlet</servlet-name> <url-pattern>*.from</url-pattern> </servlet-mapping> <!-- 指定读取所有文件的编码格式 --> <filter> <filter-name>encodingFilter</filter-name> <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> <init-param> <param-name>encoding</param-name> <param-value>UTF-8</param-value> </init-param> </filter> <filter-mapping> <filter-name>encodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> </web-app> ``` **spring的applicationContext.xml配置:** ``` <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:jdbc="http://www.springframework.org/schema/jdbc" xmlns:jee="http://www.springframework.org/schema/jee" xmlns:tx="http://www.springframework.org/schema/tx" xmlns:jpa="http://www.springframework.org/schema/data/jpa" xmlns:util="http://www.springframework.org/schema/util" xmlns:mvc="http://www.springframework.org/schema/mvc" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.2.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.2.xsd http://www.springframework.org/schema/jdbc http://www.springframework.org/schema/jdbc/spring-jdbc-3.2.xsd http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-3.2.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.2.xsd http://www.springframework.org/schema/data/jpa http://www.springframework.org/schema/data/jpa/spring-jpa-1.3.xsd http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-3.2.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd"> <!-- 定义自动扫描组件 --> <context:component-scan base-package="controller"></context:component-scan> <!-- 定义@RequestMapping映射的注解驱动 --> <mvc:annotation-driven></mvc:annotation-driven> <!-- 定义视图解析器 --> <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix"> <value>/WEB-INF/jsp/</value> </property> <property name="suffix"> <value>.jsp</value> </property> </bean> <!-- 注册spring web mvc中处理上传事件的组件CommonsMultipartResolver, 而具体怎样处理上传文件,则是由导入的包common-upload.jar和common-io.jar去处理--> <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <property name="maxUploadSize" value="10240"></property> <property name="resolveLazily" value="true"></property> </bean> </beans> ``` **java代码Controller处理:** ``` package controller; import java.io.File; import java.util.HashMap; import java.util.Map; import javax.servlet.http.HttpServletRequest; import org.springframework.stereotype.Controller; import org.springframework.ui.ModelMap; import org.springframework.web.bind.annotation.ExceptionHandler; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.multipart.MaxUploadSizeExceededException; import org.springframework.web.multipart.MultipartFile; import org.springframework.web.servlet.ModelAndView; @Controller public class UploadController { // 访问upload.jsp页面 @RequestMapping("/toUpload") public String toUpload() { return "upload"; } @RequestMapping("/upload") public String upload(@RequestParam("file") MultipartFile file, HttpServletRequest request, ModelMap model) throws Exception { // 判断提交来的文件是否为空 if (file.isEmpty()) { // model.addAttribute("error", "上传文件不能为空"); // return "upload"; throw new RuntimeException("file is null"); } // 获取文件所要保存目录在服务器上所对应的实际路径 String path = request.getSession().getServletContext().getRealPath( "upload"); System.out.println(path); // 组成拥有真实路径的一个完整的地址字符串 String fileUrl = path + "\\" + file.getOriginalFilename(); // 封装上传文件名称到model对象中 model.addAttribute("fileName", file.getOriginalFilename()); // 根据这个完整地址字符串,生成提交文件所要保存到的目标文件或目录的对象 File targetFile = new File(fileUrl); // 判断目标文件或目录的对象是否已经存在 if (!targetFile.exists()) { targetFile.mkdirs(); } // 传送文件到目标对象 file.transferTo(targetFile); System.out.println("已上传文件:" + file); return "ok"; } @ExceptionHandler public ModelAndView doException(Exception e,HttpServletRequest request) throws Exception { Map<String,Object> map = new HashMap<String,Object>(); if (e instanceof MaxUploadSizeExceededException) { long maxSize = ((MaxUploadSizeExceededException) e) .getMaxUploadSize(); map.put("error", "上传文件太大,不能超过" + maxSize / 1024 + "k"); }else if(e instanceof RuntimeException){ map.put("error", "未选中文件"); }else{ map.put("error", "上传失败"); } return new ModelAndView("upload",map); } } ``` **上传文件页面upload.jsp:** ``` <%@ page pageEncoding="UTF-8" contentType="text/html;charset=UTF-8"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>上传页面</title> </head> <body> <form action="upload.from" method="post" enctype="multipart/form-data"> <input type="file" name="file"/> <input type="submit" value="上传"/><font color="red">${error}</font> </form> </body> </html> ``` **上传成功页面ok.jsp:** ``` <%@ page pageEncoding="UTF-8" contentType="text/html;charset=UTF-8"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>ok.jsp</title> </head> <body> <h1>上传成功</h1> <a href="upload/${fileName}">${fileName}</a> </body> </html> ``` **eclipse控制台报错信息如下:** ``` 五月 01, 2015 10:27:01 下午 org.springframework.web.multipart.commons.CommonsMultipartResolver cleanupMultipart 警告: Failed to perform multipart cleanup for servlet request org.springframework.web.multipart.MaxUploadSizeExceededException: Maximum upload size of 10240 bytes exceeded; nested exception is org.apache.commons.fileupload.FileUploadBase$SizeLimitExceededException: the request was rejected because its size (19243) exceeds the configured maximum (10240) at org.springframework.web.multipart.commons.CommonsMultipartResolver.parseRequest(CommonsMultipartResolver.java:160) at org.springframework.web.multipart.commons.CommonsMultipartResolver$1.initializeMultipart(CommonsMultipartResolver.java:131) at org.springframework.web.multipart.support.AbstractMultipartHttpServletRequest.getMultipartFiles(AbstractMultipartHttpServletRequest.java:119) at org.springframework.web.multipart.support.AbstractMultipartHttpServletRequest.getMultiFileMap(AbstractMultipartHttpServletRequest.java:99) at org.springframework.web.multipart.commons.CommonsMultipartResolver.cleanupMultipart(CommonsMultipartResolver.java:188) at org.springframework.web.servlet.DispatcherServlet.cleanupMultipart(DispatcherServlet.java:1062) at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:955) at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:856) at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:953) at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:855) at javax.servlet.http.HttpServlet.service(HttpServlet.java:650) at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:829) at javax.servlet.http.HttpServlet.service(HttpServlet.java:731) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:88) at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:220) at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:122) at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:505) at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:170) at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103) at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:950) at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:116) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:423) at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1079) at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:620) at org.apache.tomcat.util.net.AprEndpoint$SocketProcessor.doRun(AprEndpoint.java:2476) at org.apache.tomcat.util.net.AprEndpoint$SocketProcessor.run(AprEndpoint.java:2465) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615) at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) at java.lang.Thread.run(Thread.java:745) Caused by: org.apache.commons.fileupload.FileUploadBase$SizeLimitExceededException: the request was rejected because its size (19243) exceeds the configured maximum (10240) at org.apache.commons.fileupload.FileUploadBase$FileItemIteratorImpl.<init>(FileUploadBase.java:914) at org.apache.commons.fileupload.FileUploadBase.getItemIterator(FileUploadBase.java:331) at org.apache.commons.fileupload.FileUploadBase.parseRequest(FileUploadBase.java:349) at org.apache.commons.fileupload.servlet.ServletFileUpload.parseRequest(ServletFileUpload.java:126) at org.springframework.web.multipart.commons.CommonsMultipartResolver.parseRequest(CommonsMultipartResolver.java:156) ... 37 more ``` 上传文件超过限制大小,异常处理后页面返回了提示信息“上传文件太大,不能超过10k”,但是为啥eclipse的控制台还是有报错呢?
angular restful springmvc 文件上传出现问题
前台代码 var fd = new FormData(); fd.append('file', file); $http({ method: 'POST', url: uploadUrl, data: fd, headers: {'Content-Type': undefined}, transformRequest: angular.identity }) .success(function (response) { console.log('uplaod success' + response); }).error(function (err) { console.log('err: ' + err); }); 后台测试代码: @RestController @RequestMapping("file") @RequestMapping(value = "/fileupload", method = RequestMethod.POST) @ResponseBody public String onUploadFile(HttpServletRequest request, @RequestParam(value = "fd", required = false) MultipartFile file) throws IllegalStateException, IOException, RestAPIException { return "method have been triggered"; } 报错 http 405 method not allowed 405, 求个思路? ``` ```
SpringMVC+ajax上传文件+提交表单数据报错The current request is not a multipart request
AJAX var commercialName=$("#commercialName").val() var commerciaPhone=$("#commerciaPhone").val() var commerciaSite=$("#commerciaSite").val() console.log(commercialName) var file=document.getElementById('file').files var formData=new FormData() formData.append("file",file[0]) $.ajax({"url":"/systemController/merchantController/contact", "encType": 'multipart/form-data', "processData": false, "contentType":false, "data":{"file":formData,"commercialName":commercialName,"commerciaPhone":commerciaPhone, "commerciaSite":commerciaSite}, "type":"post", "dataType":"json", "success":... ``` JAVA ``` @RequestMapping(value = "contact" ,method = RequestMethod.POST) @ResponseBody public Dto contact( MultipartFile file, DbBusinessInformation businessInformation, HttpServletRequest request) ``` ``` 也找了很多方法,还是没办法解决
Intellij IDEA中使用SpringMVC处理图片上传时的路径问题。
使用MultipartFile处理图片上传,使用”request.getServletContext().getRealPath“获取到 图片应该存储的路径,本来是想存到web目录下的,可是结果却存到了out/artifacts目录下, 这个目录下的图片在JSP中又无法用img标签访问到,请问如何将上传的图片存储到web 目录下,而不是artifacts目录。 ![图片说明](https://img-ask.csdn.net/upload/201803/17/1521253236_977299.png)
springmvc使用servlet3.0上传文件错误
文件结构,设定的file在WebContent下 WebAppInitializer配置如下 ``` public class WebAppInitializer extends AbstractAnnotationConfigDispatcherServletInitializer{ @Override protected Class<?>[] getRootConfigClasses() { // TODO Auto-generated method stub return new Class<?>[]{RootConfig.class}; } @Override protected Class<?>[] getServletConfigClasses() { // TODO Auto-generated method stub return new Class<?>[]{WebConfig.class}; } @Override protected String[] getServletMappings() { // TODO Auto-generated method stub return new String[]{"/"}; } // @Override // protected void customizeRegistration(Dynamic registration) { // registration.setMultipartConfig( // new MultipartConfigElement("/file", 2097152, 4194304, 0)); // } @Override protected void customizeRegistration(ServletRegistration.Dynamic registration) { registration.setMultipartConfig(getMultipartConfigElement()); } private MultipartConfigElement getMultipartConfigElement() { MultipartConfigElement multipartConfigElement = new MultipartConfigElement( LOCATION, MAX_FILE_SIZE, MAX_REQUEST_SIZE, FILE_SIZE_THRESHOLD); return multipartConfigElement; } private static final String LOCATION = "/file/"; // Temporary location where files will be stored private static final long MAX_FILE_SIZE = 5242880; // 5MB : Max file size. // Beyond that size spring will throw exception. private static final long MAX_REQUEST_SIZE = 20971520; // 20MB : Total request size containing Multi part. private static final int FILE_SIZE_THRESHOLD = 0; } ``` WebConfig.class配置如下 ``` @Bean(name = "multipartResolver") public StandardServletMultipartResolver resolver() { return new StandardServletMultipartResolver(); } ``` ``` public class User { private MultipartFile multipartFile; get set } ``` controller配置如下 ``` @Controller public class WebControllerr { @Autowired UserService userService; @Autowired HttpServletRequest httpServletRequest; @RequestMapping(value="/photo") public String update(Model model){ model.addAttribute("user", new User()); return "photo"; } @RequestMapping("/filedown") public void fileDownLoad(HttpServletRequest servletRequest, @ModelAttribute User user,Model model){ MultipartFile multipartFile=user.getMultipartFile(); String filename=multipartFile.getOriginalFilename(); try { File file=new File(servletRequest.getServletContext().getRealPath("/file"),filename); multipartFile.transferTo(file); } catch (Exception e) { e.printStackTrace(); } ``` Could not complete request org.springframework.web.multipart.MultipartException: Could not parse multipart servlet request; nested exception is java.io.IOException: The temporary upload location [C:\Tomcat7\work\Catalina\localhost\WebProtect3\file] is not valid at org.springframework.web.multipart.support.StandardMultipartHttpServletRequest.parseRequest(StandardMultipartHttpServletRequest.java:99) at org.springframework.web.multipart.support.StandardMultipartHttpServletRequest.<init>(StandardMultipartHttpServletRequest.java:77) at org.springframework.web.multipart.support.StandardServletMultipartResolver.resolveMultipart(StandardServletMultipartResolver.java:75) at org.springframework.web.servlet.DispatcherServlet.checkMultipart(DispatcherServlet.java:1041) at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:887) at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:851) at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:953) at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:855) at javax.servlet.http.HttpServlet.service(HttpServlet.java:650) at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:829) at javax.servlet.http.HttpServlet.service(HttpServlet.java:731) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.apache.logging.log4j.core.web.Log4jServletFilter.doFilter(Log4jServletFilter.java:66) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:220) at org.apache.catalina.core.StandardContextValve.__invoke(StandardContextValve.java:122) at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java) at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:505) at org.apache.catalina.core.StandardHostValve.__invoke(StandardHostValve.java:170) at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java) at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103) at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:956) at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:116) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:423) at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1079) at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:625) at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:318) at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source) at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) at java.lang.Thread.run(Unknown Source)
问一个关于springmvc的问题
我在前台用form提交数据,上传文件,后端用\@RequestParam(value="file") MultipartFile file这种方式来接受上传的文件 然后在方法里就把接受到的文件存储到了本地文件夹中,这些都完成了,看了另存的目录中,也的确有上传的文件 但很疑惑的是在整个控制层方法执行完毕后,会有三行异常信息出现: o.s.w.s.m.a.AnnotationMethodHandlerExceptionResolver-Resolving exception from handler [web.DemoServlet@799808f9]:org.springframework.web.bind.MissingServletRequestParameterException: Required MultipartFile parameter 'file' is not present o.s.w.s.m.a.ResponseStatusExceptionResolver-Resolving exception from handler [web.DemoServlet@799808f9]:org.springframework.web.bind.MissingServletRequestParameterException: Required MultipartFile parameter 'file' is not present o.s.w.s.m.s.DefaultHandlerExceptionResolver-Resolving exception from handler [web.DemoServlet@799808f9]:org.springframework.web.bind.MissingServletRequestParameterException: Required MultipartFile parameter 'file' is not present 这个问题困扰我两天了,关键是这是控制层方法完毕后才出现的东西啊,为什么啊?难道是视图解析有问题? 我的前台也的确是没有跳转,我是直接返回了一个json数据,已经标注了@ResponseBody了... 有没有遇到过类似情况的,救命啊\手动哭脸
SpringMvc+layui 实现图片上传更新头像 但是总弹出接口异常(很急!!!!)
![图片说明](https://img-ask.csdn.net/upload/201905/25/1558713715_871569.png) **前端请求时候 url 500** ``` <script src="${pageContext.request.contextPath}/resources/layui.all.js"></script> <script> $ = layui.$; var $ = layui.jquery var form = layui.form; var element=layui.element; var layer=layui.layer; var upload = layui.upload; $("#nav").load("/filmos/nav"); upload.render({ elem: '#choose' , auto: false , url: '${pageContext.request.contextPath}/user/updateuserimg' ,accept: 'file' , bindAction: '#upload' , choose: function (obj) {//选择文件的回调,obj为选中的文件 //将每次选择的文件追加到文件队列 var files = obj.pushFile(); //预览选中的文件(本地文件) obj.preview(function (index, file, result) { $('#user-img').attr('src', result); $('#upload').css('display', 'block'); }); } , before: function (obj) {//文件上传前的回调 } , done: function (res) { if (res.code==200) { location.href = "${pageContext.request.contextPath}/ok" }else { //演示失败状态,并实现重传 return layer.msg(res.msg); } } ,error: function(res) { console.log(res); console.log(res.code); console.log(res.msg); var demoText = $('#demoText'); demoText.html('<span style="color: #FF5722;">上传失败</span> <a class="layui-btn layui-btn-xs demo-reload">重试</a>'); demoText.find('.demo-reload').on('click', function () { uploadInst.upload(); }); } }); </script> </body> </html> ``` **js代码** ![图片说明](https://img-ask.csdn.net/upload/201905/25/1558713861_529370.png) **但是实际上功能是实现了的 数据库中也更新了 但是每次都会弹出接口异常** ``` //上面还有个requestmapping是user 通过user/updateuserimg到这个方法 @ResponseBody @RequestMapping(value = "/updateuserimg", method = {RequestMethod.POST,RequestMethod.GET}) private JSONObject updateUserImg(@RequestParam(value = "file", required = false) CommonsMultipartFile multipartFile, HttpSession session) throws IOException{ User user = (User) session.getAttribute("user"); JSONObject jsonObject=new JSONObject(); if (multipartFile != null && multipartFile.getSize() > 0&& user!=null) { userService.updateUserImg(user, multipartFile.getInputStream(), multipartFile.getOriginalFilename()); session.setAttribute("user", userService.login(user)); jsonObject.put("code",200); jsonObject.put("msg","更新成功!"); jsonObject.put("src",user.getUserImg()); return jsonObject; } else { jsonObject.put("code",400); jsonObject.put("msg","更新失败!"); return jsonObject; } } } ``` Contoller的代码 ![图片说明](https://img-ask.csdn.net/upload/201905/25/1558713969_417859.png) ssm配置的 ![图片说明](https://img-ask.csdn.net/upload/201905/25/1558714077_867660.png) ![图片说明](https://img-ask.csdn.net/upload/201905/25/1558714083_361418.png)![图片说明](https://img-ask.csdn.net/upload/201905/25/1558714089_172810.png)
springmvc+easyui实现图片上传
@RequestMapping(value="/upload",method=RequestMethod.POST) @ResponseBody public Json upload(@RequestParam(value="imageFile") MultipartFile file,HttpServletRequest req,HttpServletResponse resp) throws IOException{ String temppath="/image"; Json j = new Json(); //构建文件名称 String oldName = file.getOriginalFilename(); //获取文件的后缀 String suffix = oldName.substring(oldName.indexOf('.')); String name = String.valueOf(System.currentTimeMillis()).concat(suffix); String path = req.getSession().getServletContext().getRealPath(temppath); try { File filepath = new File(path); if(!filepath.exists()){ filepath.mkdir(); //创建目录 } OutputStream os = new FileOutputStream(filepath.getPath() +"/"+name); InputStream is = file.getInputStream(); byte[] buffer = new byte[1024]; int len = 0; while((len = is.read(buffer)) != -1){ os.write(buffer, 0, len); } os.flush(); os.close(); is.close(); j.setSuccess(true); j.setMsg("上传成功"); } catch (Exception e) { j.setMsg("上传失败"); j.setSuccess(false); e.printStackTrace(); } j.setErrorinfo(req.getContextPath()+temppath+"/"+name); j.setObject(path +"\\"+ name); return j; } <tr> <td>法人身份证照片</td> <td><input type="file" name="imageFile" id="imageFile" onchange="previewImage(this)" accept="image/*"></td> <td> <input type="button" onclick="return ajaxFileUpload();" value="上传"/> <input type="hidden" name="legal_url" id="legal_url"/> </td> </tr> <tr> <td>营业执照照片</td> <td><input type="file" name="imageFile" id="imageFile"></td> <td> <input type="button" onclick="return ajaxFileUpload1();" value="上传"/> <input type="hidden" name="busi_url" id="busi_url"/> </td> </tr> <tr> <td>公司前台图片</td> <td><input type="file" name="imageFile" id="imageFile"></td> <td> <input type="button" onclick="return ajaxFileUpload2();" value="上传"/> <input type="hidden" name="comp_url" id="comp_url"/> </td> </tr> //法人身份证照片 function ajaxFileUpload() { $.ajaxFileUpload({ url : '${pageContext.request.contextPath}/commonController/upload', type : 'post', secureuri:false, fileElementId : 'imageFile', dataType : 'JSON', success : function(data, status) { //去掉<pre></pre>标签 var start = data.indexOf(">"); if(start != -1) { var end = data.indexOf("<", start + 1); if(end != -1) { data = data.substring(start + 1, end); } } //转化为JSON对象 data=eval('('+data+')'); if (data.success) { $("#legal_url").val(data.errorinfo); alert("上传成功!"); } }, }); return false; } //营业执照照片 function ajaxFileUpload1() { $.ajaxFileUpload({ url : '${pageContext.request.contextPath}/commonController/upload', type : 'post', secureuri:false, fileElementId : 'imageFile', dataType : 'JSON', success : function(data, status) { //去掉<pre></pre>标签 var start = data.indexOf(">"); if(start != -1) { var end = data.indexOf("<", start + 1); if(end != -1) { data = data.substring(start + 1, end); } } //转化为JSON对象 data=eval('('+data+')'); if (data.success) { $("#busi_url").val(data.errorinfo); alert("上传成功!"); } }, }); return false; } //公司前台照片 function ajaxFileUpload2() { $.ajaxFileUpload({ url : '${pageContext.request.contextPath}/commonController/upload', type : 'post', secureuri:false, fileElementId : 'imageFile', dataType : 'JSON', success : function(data, status) { //去掉<pre></pre>标签 var start = data.indexOf(">"); if(start != -1) { var end = data.indexOf("<", start + 1); if(end != -1) { data = data.substring(start + 1, end); } } //转化为JSON对象 data=eval('('+data+')'); if (data.success) { $("#comp_url").val(data.errorinfo); alert("上传成功!"); } }, }); return false; }
springmvc 图片上传报错,页面报500,有没有大神遇见过,求帮助!!!!!!!!!
前端是: <%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title></title> </head> <body> <form name="Form2" action="http://localhost:8081/jg/merchants/updatespringUpload" method="post" enctype="multipart/form-data"> <h1>使用spring mvc提供的类的方法上传文件</h1> <input type="file" name="file"> <input type="submit" value="upload"/> </form> </body> </html> controller : @RequestMapping(value = "/updatespringUpload") public String springUpload(HttpServletRequest request) throws IllegalStateException, IOException { long startTime=System.currentTimeMillis(); //将当前上下文初始化给 CommonsMutipartResolver (多部分解析器) CommonsMultipartResolver multipartResolver=new CommonsMultipartResolver( request.getSession().getServletContext()); //检查form中是否有enctype="multipart/form-data" if(multipartResolver.isMultipart(request)) { //将request变成多部分request MultipartHttpServletRequest multiRequest=(MultipartHttpServletRequest)request; //获取multiRequest 中所有的文件名 Iterator iter=multiRequest.getFileNames(); while(iter.hasNext()) { //一次遍历所有文件 MultipartFile file=multiRequest.getFile(iter.next().toString()); if(file!=null) { String path="E:/springUpload"+file.getOriginalFilename(); //上传 file.transferTo(new File(path)); } } } long endTime=System.currentTimeMillis(); System.out.println("方法三的运行时间:"+String.valueOf(endTime-startTime)+"ms"); return "/success"; } 报错内容是: HTTP Status 500 - Request processing failed; nested exception is com.alibaba.fastjson.JSONException: toJSON error
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私有的数
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
此博客仅为我业余记录文章所用,发布到此,仅供网友阅读参考,如有侵权,请通知我,我会删掉。 补充 有不少读者留言说本文章没有用,因为天气预报直接打开手机就可以收到了,为何要多此一举发送到邮箱呢!!!那我在这里只能说:因为你没用,所以你没用!!! 这里主要介绍的是思路,不是天气预报!不是天气预报!!不是天气预报!!!天气预报只是用于举例。请各位不要再刚了!!! 下面是我会用到的两个场景: 每日下
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
死磕YOLO系列,YOLOv1 的大脑、躯干和手脚
YOLO 是我非常喜欢的目标检测算法,堪称工业级的目标检测,能够达到实时的要求,它帮我解决了许多实际问题。 这就是 YOLO 的目标检测效果。它定位了图像中物体的位置,当然,也能预测物体的类别。 之前我有写博文介绍过它,但是每次重新读它的论文,我都有新的收获,为此我准备写一个系列的文章来详尽分析它。这是第一篇,从它的起始 YOLOv1 讲起。 YOLOv1 的论文地址:https://www.c
知乎高赞:中国有什么拿得出手的开源软件产品?(整理自本人原创回答)
知乎高赞:中国有什么拿得出手的开源软件产品? 在知乎上,有个问题问“中国有什么拿得出手的开源软件产品(在 GitHub 等社区受欢迎度较好的)?” 事实上,还不少呢~ 本人于2019.7.6进行了较为全面的 回答 - Bravo Yeung,获得该问题下回答中得最高赞(236赞和1枚专业勋章),对这些受欢迎的 Github 开源项目分类整理如下: 分布式计算、云平台相关工具类 1.SkyWalk
记一次腾讯面试:进程之间究竟有哪些通信方式?如何通信? ---- 告别死记硬背
有一次面试的时候,被问到进程之间有哪些通信方式,不过由于之前没深入思考且整理过,说的并不好。想必大家也都知道进程有哪些通信方式,可是我猜很多人都是靠着”背“来记忆的,所以今天的这篇文章,讲给大家详细着讲解他们是如何通信的,让大家尽量能够理解他们之间的区别、优缺点等,这样的话,以后面试官让你举例子,你也能够顺手拈来。 1、管道 我们来看一条 Linux 的语句 netstat -tulnp | gr...
20行Python代码爬取王者荣耀全英雄皮肤
引言 王者荣耀大家都玩过吧,没玩过的也应该听说过,作为时下最火的手机MOBA游戏,咳咳,好像跑题了。我们今天的重点是爬取王者荣耀所有英雄的所有皮肤,而且仅仅使用20行Python代码即可完成。 准备工作 爬取皮肤本身并不难,难点在于分析,我们首先得得到皮肤图片的url地址,话不多说,我们马上来到王者荣耀的官网: 我们点击英雄资料,然后随意地选择一位英雄,接着F12打开调试台,找到英雄原皮肤的图片
网络(8)-HTTP、Socket、TCP、UDP的区别和联系
TCP/IP协议是传输层协议,主要解决数据如何在网络中传输,而HTTP是应用层协议,主要解决如何包装数据。 一、TCP与UDP的不同 1. 是否需要建立连接。 UDP在传送数据之前不需要先建立连接;TCP则提供面向连接的服务; 2. 是否需要给出确认 对方的传输层在收到UDP报文后,不需要给出任何确认,而 TCP需要给出确认报文,要提供可靠的、面向连接的传输服务。 3.虽然UDP不提供可靠交...
简明易理解的@SpringBootApplication注解源码解析(包含面试提问)
欢迎关注文章系列 ,关注我 《提升能力,涨薪可待》 《面试知识,工作可待》 《实战演练,拒绝996》 欢迎关注我博客,原创技术文章第一时间推出 也欢迎关注公 众 号【Ccww笔记】,同时推出 如果此文对你有帮助、喜欢的话,那就点个赞呗,点个关注呗! 《提升能力,涨薪可待篇》- @SpringBootApplication注解源码解析 一、@SpringBootApplication 的作用是什
防劝退!数据结构和算法难理解?可视化动画带你轻松透彻理解!
大家好,我是 Rocky0429,一个连数据结构和算法都不会的蒟蒻… 学过数据结构和算法的都知道这玩意儿不好学,没学过的经常听到这样的说法还没学就觉得难,其实难吗?真难! 难在哪呢?当年我还是个小蒟蒻,初学数据结构和算法的时候,在忍着枯燥看完定义原理,之后想实现的时候,觉得它们的过程真的是七拐八绕,及其难受。 在简单的链表、栈和队列这些我还能靠着在草稿上写写画画理解过程,但是到了数论、图...
西游记团队中如果需要裁掉一个人,会先裁掉谁?
2019年互联网寒冬,大批企业开始裁员,下图是网上流传的一张截图: 裁员不可避免,那如何才能做到不管大环境如何变化,自身不受影响呢? 我们先来看一个有意思的故事,如果西游记取经团队需要裁员一名,会裁掉谁呢,为什么? 西游记团队组成: 1.唐僧 作为团队teamleader,有很坚韧的品性和极高的原则性,不达目的不罢休,遇到任何问题,都没有退缩过,又很得上司支持和赏识(直接得到唐太宗的任命,既给
开挂的人生!那些当选院士,又是ACM/IEEE 双料Fellow的华人学者们
昨日,2019年两院院士正式官宣,一时间抢占了各大媒体头条。 朋友圈也是一片沸腾,奔走相告,赶脚比自己中了大奖还嗨皮! 谁叫咱家导师就是这么厉害呢!!! 而就在最近,新一年度的IEEE/ACM Fellow也将正式公布。 作为学术届的顶级荣誉,不自然地就会将院士与Fellow作比较,到底哪个含金量更高呢? 学术君认为,同样是专业机构对学者的认可,考量标准不一,自然不能一概而论。 但...
聊聊C语言和指针的本质
坐着绿皮车上海到杭州,24块钱,很宽敞,在火车上非正式地聊几句。 很多编程语言都以 “没有指针” 作为自己的优势来宣传,然而,对于C语言,指针却是与生俱来的。 那么,什么是指针,为什么大家都想避开指针。 很简单, 指针就是地址,当一个地址作为一个变量存在时,它就被叫做指针,该变量的类型,自然就是指针类型。 指针的作用就是,给出一个指针,取出该指针指向地址处的值。为了理解本质,我们从计算机模型说起...
Python语言高频重点汇总
Python语言高频重点汇总 GitHub面试宝典仓库——点这里跳转 文章目录Python语言高频重点汇总**GitHub面试宝典仓库——点这里跳转**1. 函数-传参2. 元类3. @staticmethod和@classmethod两个装饰器4. 类属性和实例属性5. Python的自省6. 列表、集合、字典推导式7. Python中单下划线和双下划线8. 格式化字符串中的%和format9.
究竟你适不适合买Mac?
我清晰的记得,刚买的macbook pro回到家,开机后第一件事情,就是上了淘宝网,花了500元钱,找了一个上门维修电脑的师傅,上门给我装了一个windows系统。。。。。。 表砍我。。。 当时买mac的初衷,只是想要个固态硬盘的笔记本,用来运行一些复杂的扑克软件。而看了当时所有的SSD笔记本后,最终决定,还是买个好(xiong)看(da)的。 已经有好几个朋友问我mba怎么样了,所以今天尽量客观
代码详解:如何用Python快速制作美观、炫酷且有深度的图表
全文共12231字,预计学习时长35分钟生活阶梯(幸福指数)与人均GDP(金钱)正相关的正则图本文将探讨三种用Python可视化数据的不同方法。以可视化《2019年世界幸福报告》的数据为例,本文用Gapminder和Wikipedia的信息丰富了《世界幸福报告》数据,以探索新的数据关系和可视化方法。《世界幸福报告》试图回答世界范围内影响幸福的因素。报告根据对“坎特里尔阶梯问题”的回答来确定幸...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外
(经验分享)作为一名普通本科计算机专业学生,我大学四年到底走了多少弯路
今年正式步入了大四,离毕业也只剩半年多的时间,回想一下大学四年,感觉自己走了不少弯路,今天就来分享一下自己大学的学习经历,也希望其他人能不要走我走错的路。 (一)初进校园 刚进入大学的时候自己完全就相信了高中老师的话:“进入大学你们就轻松了”。因此在大一的时候自己学习的激情早就被抛地一干二净,每天不是在寝室里玩游戏就是出门游玩,不过好在自己大学时买的第一台笔记本性能并不是很好,也没让我彻底沉...
如何写一篇技术博客,谈谈我的看法
前言 只有光头才能变强。 文本已收录至我的GitHub精选文章,欢迎Star:https://github.com/ZhongFuCheng3y/3y 我一直推崇学技术可以写技术博客去沉淀自己的知识,因为知识点实在是太多太多了,通过自己的博客可以帮助自己快速回顾自己学过的东西。 我最开始的时候也是只记笔记,认为自己能看得懂就好。但如果想验证自己是不是懂了,可以写成技术博客。在写技术博客的...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
面试还搞不懂redis,快看看这40道面试题(含答案和思维导图)
Redis 面试题 1、什么是 Redis?. 2、Redis 的数据类型? 3、使用 Redis 有哪些好处? 4、Redis 相比 Memcached 有哪些优势? 5、Memcache 与 Redis 的区别都有哪些? 6、Redis 是单进程单线程的? 7、一个字符串类型的值能存储最大容量是多少? 8、Redis 的持久化机制是什么?各自的优缺点? 9、Redis 常见性...
大学四年自学走来,这些珍藏的「实用工具/学习网站」我全贡献出来了
知乎高赞:文中列举了互联网一线大厂程序员都在用的工具集合,涉及面非常广,小白和老手都可以进来看看,或许有新收获。
互联网公司的裁员,能玩出多少种花样?
裁员,也是一门学问,可谓博大精深!以下,是互联网公司的裁员的多种方法:-正文开始-135岁+不予续签的理由:千禧一代网感更强。95后不予通过试用期的理由:已婚已育员工更有责任心。2通知接下来要过苦日子,让一部分不肯同甘共苦的员工自己走人,以“兄弟”和“非兄弟”来区别员工。3强制996。员工如果平衡不了工作和家庭,可在离婚或离职里二选一。4不布置任何工作,但下班前必须提交千字工作日报。5不给活干+...
【设计模式】单例模式的八种写法分析
网上泛滥流传单例模式的写法种类,有说7种的,也有说6种的,当然也不排除说5种的,他们说的有错吗?其实没有对与错,刨根问底,写法终究是写法,其本质精髓大体一致!因此完全没必要去追究写法的多少,有这个时间还不如跟着宜春去网吧偷耳机、去田里抓青蛙得了,一天天的....
《面试宝典》:检验是否为合格的初中级程序员的面试知识点,你都知道了吗?查漏补缺
欢迎关注文章系列,一起学习 《提升能力,涨薪可待篇》 《面试知识,工作可待篇》 《实战演练,拒绝996篇》 也欢迎关注公 众 号【Ccww笔记】,原创技术文章第一时间推出 如果此文对你有帮助、喜欢的话,那就点个赞呗,点个关注呗! 《面试知识,工作可待篇》-Java笔试面试基础知识大全 前言 是不是感觉找工作面试是那么难呢? 在找工作面试应在学习的基础进行总结面试知识点,工作也指日可待,欢...
关于研发效能提升的思考
研发效能提升是最近比较热门的一个话题,本人根据这几年的工作心得,做了一些思考总结,由于个人深度有限,暂且抛转引入。 三要素 任何生产力的提升都离不开这三个因素:人、流程和工具,少了其中任何一个因素都无法实现。 人,即思想,也就是古人说的“道”,道不同不相为谋,是制高点,也是高层建筑的基石。 流程,即方法,也是古人说的“法”。研发效能的提升,也就是要提高投入产出比,既要增加产出,也要减...
微博推荐算法简述
在介绍微博推荐算法之前,我们先聊一聊推荐系统和推荐算法。有这样一些问题:推荐系统适用哪些场景?用来解决什么问题、具有怎样的价值?效果如何衡量? 推荐系统诞生很早,但真正被大家所重视,缘起于以”facebook”为代表的社会化网络的兴起和以“淘宝“为代表的电商的繁荣,”选择“的时代已经来临,信息和物品的极大丰富,让用户如浩瀚宇宙中的小点,无所适从。推荐系统迎来爆发的机会,变得离用户更近: 快...
相关热词 c#开发的dll注册 c#的反射 c# grid绑定数据源 c#多线程怎么循环 c# 鼠标左键 c# char占位符 c# 日期比较 c#16进制转换为int c#用递归求顺序表中最大 c#小型erp源代码
立即提问