用springMVC的Multipartfile可以实现视频的上传吗?

用springMVC的Multipartfile可以实现视频的上传吗? 如果可以该怎么做像上传文件一样吗 大神救急

1个回答

用springMVC的Multipartfile可以实现视频的上传,但是我不知道像上传文件有什么区别

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
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
<div class="iteye-blog-content-contain" style="font-size: 14px"></div> [code="java"] public String upload2(MultipartHttpServletRequest request, @RequestParam("name") String name){ List<MultipartFile> files = (List<MultipartFile>) request.getFile("myfiles"); } //修改成如下方法,还是报同样下面的错误: public String upload2(MultipartHttpServletRequest request, @RequestParam("name") String name, // 页面上的控件值 @RequestParam MultipartFile[] myfiles) { List<MultipartFile> files = Arrays.asList(myfiles); } // jsp页面,传一个myfiles,单个文件是可以通过的, [/code] [code="html"] <form method="POST" action="multipartFileUpload.action" enctype="multipart/form-data"> <input type="text" name="name" /><br> <input type="file"name="myfiles" /><br> <input type="file"name="myfiles" /><br> <input type="submit" /><br> </form> [/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]
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 文件上传过大时异常处理出错
我用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中如何获取多个名字未知的上传文件?
一般情况下SpringMVC通过requestparam和MultipartFile获取上传的文件,其中注解requestparam必须要指定文件参数的name。 现在的我的需求是在不知有多少文件上传,也不知道文件参数名的情况下获取到所有上传的文件的信息,等高手来指点一下!
关于springmvc的视频上传
controller里面的代码: @RequestMapping(value = "/fileUpload2.do", method = RequestMethod.GET) public String fileUpload2(HttpServletRequest request) throws IllegalStateException, IOException { System.out.println("1"); // 设置上下方文 CommonsMultipartResolver multipartResolver = new CommonsMultipartResolver( request.getSession().getServletContext()); System.out.println("2"); // 检查form是否有enctype="multipart/form-data" if (multipartResolver.isMultipart(request)) { MultipartHttpServletRequest multiRequest = (MultipartHttpServletRequest) request; System.out.println("3"); Iterator<String> iter = multiRequest.getFileNames(); while (iter.hasNext()) { // 由CommonsMultipartFile继承而来,拥有上面的方法. MultipartFile file = multiRequest.getFile(iter.next()); if (file != null) { String fileName = "demoUpload" + file.getOriginalFilename(); String path = "E:/" + fileName; File localFile = new File(path); file.transferTo(localFile); System.out.println("4"); } } } return "main/homework"; } jsp页面代码: <form id="form" action="fileUpload2.do" method="GET" enctype="multipart/form-data"> <table align="center" border="1" bgcolor="blue" height="300px"> <tr align="center"><td colspan="2" align="center"> <input type="file" name="myfile" style="height:35px; width:100px;"></td> </tr> <tr align="center"><td colspan="2" align="center" > <input type="submit" name="submit" value="上传" style="height:35px; width:100px;" ></td> </tr> </table> </form> 控制台里只能打印出来controller方法里的1和2, if (multipartResolver.isMultipart(request))这条语句往后的代码没有得到执行,这是为什么呢?很急,有没有大神帮帮忙
用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跨服务器上传文件,上传至文件服务器时报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) 本人在网上找了许久,也不见符合的相关答案
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+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的问题
我在前台用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文件上传问题
MultipartFile .png .text上传后 CommonsMultipartFile cf = (CommonsMultipartFile)endorsementfile; DiskFileItem fi = (DiskFileItem) cf.getFileItem(); File file = fi.getStoreLocation(); file.isfile() 判断结果不是文件返回false 我需要完成上传文件不一样时不会重复上传 类似网盘 我采用的MD5加密重命名 但是需要传入File类型
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上传文件报错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) 求各位大佬帮我看看问题到底出在哪了!!!弄了半个小时不知道怎么回事
关于Java批量导入节目,求思路
导入材料:节目excel(excel一行就是一个节目);Zip压缩包(节目图片)。 需求:导入的excel大概有300个节目,图片大概有900张大概2G。 ![图片说明](https://img-ask.csdn.net/upload/201801/26/1516949745_1002.png) 做个假设:一次请求,把上传的excel,zip读入内存;excel把它解析成List,一个元素对应excel的一行。zip解析为一个Map,key图片名字,value图片流。图片流和excel找到映射关系后,做裁图(特定尺寸)保存在服务器静态资源端。然后落值数据库。 思路:前台:new FormData(),multipart/form-data;charset=UTF-8的http的POST请求;后台springmvc的MultipartFile接受两数据。通过解析构造出合理的数据类型,落值一条一条的节目。 矛盾: 1.图片资源过大,考虑用户带宽,请求是通过http协议的。 2.效率问题 3.内存的压力 4.用多线程去提高效率 补充:对于批量这个概率不是太清楚;Zip包里边图片,一个节目对应三张。 前面的假设是针对不超过200M的上传数据,现在数据量增加了,想做一个新思路的解决方法,求大家给点点子,欢迎一起研究这个问题 感谢:各位大哥谢谢你们的建议,我回去整理整理,最终我用了谁的建议,我就把币给谁,币不多一点心意,莫怪莫怪。最终我会把我的实现思路共享给大家。
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上传图片,可能是我选的路径不对还是啥,在客户端读取存入数据库的路径时,图片不显示。
不知道什么回事,图片就是读不出来,但是看网页源代码,有图片路径,单独访问图片路径也可以读到图片,但是在jsp中读不到,可能是过滤器或者拦截器的原因,不知道了,问问各位大神。 下面时spring MVC上传代码: ``` String path = null; //将当前上下文初始化给 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) { path=request.getServletContext().getRealPath("")+"\\image\\"+file.getOriginalFilename(); //上传 file.transferTo(new File(path)); } } } ``` 存入数据库的路径是这样:D:\Tomcat\apache-tomcat-7.0.42\webapps\students\image\QQ图片20180531181825.jpg,在jsp页面中图片路径就是这个,但是就是显示不出来,请问该怎么修改才能在将图片在jsp页面中显示出来,还有, 我这个是不是没有将图片存到服务器上啊? 求教各位了,谢谢
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. 初学者,百思不得其解
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, 求个思路? ``` ```
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私有的数
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
此博客仅为我业余记录文章所用,发布到此,仅供网友阅读参考,如有侵权,请通知我,我会删掉。 补充 有不少读者留言说本文章没有用,因为天气预报直接打开手机就可以收到了,为何要多此一举发送到邮箱呢!!!那我在这里只能说:因为你没用,所以你没用!!! 这里主要介绍的是思路,不是天气预报!不是天气预报!!不是天气预报!!!天气预报只是用于举例。请各位不要再刚了!!! 下面是我会用到的两个场景: 每日下
面试官问我:什么是消息队列?什么场景需要他?用了会出现什么问题?
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸,打败了无数
8年经验面试官详解 Java 面试秘诀
    作者 | 胡书敏 责编 | 刘静 出品 | CSDN(ID:CSDNnews) 本人目前在一家知名外企担任架构师,而且最近八年来,在多家外企和互联网公司担任Java技术面试官,前后累计面试了有两三百位候选人。在本文里,就将结合本人的面试经验,针对Java初学者、Java初级开发和Java开发,给出若干准备简历和准备面试的建议。   Java程序员准备和投递简历的实
究竟你适不适合买Mac?
我清晰的记得,刚买的macbook pro回到家,开机后第一件事情,就是上了淘宝网,花了500元钱,找了一个上门维修电脑的师傅,上门给我装了一个windows系统。。。。。。 表砍我。。。 当时买mac的初衷,只是想要个固态硬盘的笔记本,用来运行一些复杂的扑克软件。而看了当时所有的SSD笔记本后,最终决定,还是买个好(xiong)看(da)的。 已经有好几个朋友问我mba怎么样了,所以今天尽量客观
MyBatis研习录(01)——MyBatis概述与入门
C语言自学完备手册(33篇) Android多分辨率适配框架 JavaWeb核心技术系列教程 HTML5前端开发实战系列教程 MySQL数据库实操教程(35篇图文版) 推翻自己和过往——自定义View系列教程(10篇) 走出思维困境,踏上精进之路——Android开发进阶精华录 讲给Android程序员看的前端系列教程(40集免费视频教程+源码) 版权声明 本文原创作者:谷哥的小弟 作者博客
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外
Python爬虫爬取淘宝,京东商品信息
小编是一个理科生,不善长说一些废话。简单介绍下原理然后直接上代码。 使用的工具(Python+pycharm2019.3+selenium+xpath+chromedriver)其中要使用pycharm也可以私聊我selenium是一个框架可以通过pip下载 pip install selenium -i https://pypi.tuna.tsinghua.edu.cn/simple/ 
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
你知道的越多,你不知道的越多 点赞再看,养成习惯 本文 GitHub https://github.com/JavaFamily 已收录,有一线大厂面试点思维导图,也整理了很多我的文档,欢迎Star和完善,大家面试可以参照考点复习,希望我们一起有点东西。 前前言 为啥今天有个前前言呢? 因为你们的丙丙啊,昨天有牌面了哟,直接被微信官方推荐,知乎推荐,也就仅仅是还行吧(心里乐开花)
Java工作4年来应聘要16K最后没要,细节如下。。。
前奏: 今天2B哥和大家分享一位前几天面试的一位应聘者,工作4年26岁,统招本科。 以下就是他的简历和面试情况。 基本情况: 专业技能: 1、&nbsp;熟悉Sping了解SpringMVC、SpringBoot、Mybatis等框架、了解SpringCloud微服务 2、&nbsp;熟悉常用项目管理工具:SVN、GIT、MAVEN、Jenkins 3、&nbsp;熟悉Nginx、tomca
Python爬虫精简步骤1 获取数据
爬虫的工作分为四步: 1.获取数据。爬虫程序会根据我们提供的网址,向服务器发起请求,然后返回数据。 2.解析数据。爬虫程序会把服务器返回的数据解析成我们能读懂的格式。 3.提取数据。爬虫程序再从中提取出我们需要的数据。 4.储存数据。爬虫程序把这些有用的数据保存起来,便于你日后的使用和分析。 这一篇的内容就是:获取数据。 首先,我们将会利用一个强大的库——requests来获取数据。 在电脑上安装
Python绘图,圣诞树,花,爱心 | Turtle篇
1.画圣诞树 import turtle screen = turtle.Screen() screen.setup(800,600) circle = turtle.Turtle() circle.shape('circle') circle.color('red') circle.speed('fastest') circle.up() square = turtle.Turtle()
作为一个程序员,CPU的这些硬核知识你必须会!
CPU对每个程序员来说,是个既熟悉又陌生的东西? 如果你只知道CPU是中央处理器的话,那可能对你并没有什么用,那么作为程序员的我们,必须要搞懂的就是CPU这家伙是如何运行的,尤其要搞懂它里面的寄存器是怎么一回事,因为这将让你从底层明白程序的运行机制。 随我一起,来好好认识下CPU这货吧 把CPU掰开来看 对于CPU来说,我们首先就要搞明白它是怎么回事,也就是它的内部构造,当然,CPU那么牛的一个东
破14亿,Python分析我国存在哪些人口危机!
2020年1月17日,国家统计局发布了2019年国民经济报告,报告中指出我国人口突破14亿。 猪哥的朋友圈被14亿人口刷屏,但是很多人并没有看到我国复杂的人口问题:老龄化、男女比例失衡、生育率下降、人口红利下降等。 今天我们就来分析一下我们国家的人口数据吧! 更多有趣分析教程,扫描下方二维码关注vx公号「裸睡的猪」 即可查看! 一、背景 1.人口突破14亿 2020年1月17日,国家统计局发布
web前端javascript+jquery知识点总结
Javascript javascript 在前端网页中占有非常重要的地位,可以用于验证表单,制作特效等功能,它是一种描述语言,也是一种基于对象(Object)和事件驱动并具有安全性的脚本语言 ,语法同java类似,是一种解释性语言,边执行边解释。 JavaScript的组成: ECMAScipt 用于描述: 语法,变量和数据类型,运算符,逻辑控制语句,关键字保留字,对象。 浏览器对象模型(Br
Python实战:抓肺炎疫情实时数据,画2019-nCoV疫情地图
文章目录1. 前言2. 数据下载3. 数据处理4. 数据可视化 1. 前言 今天,群里白垩老师问如何用python画武汉肺炎疫情地图。白垩老师是研究海洋生态与地球生物的学者,国家重点实验室成员,于不惑之年学习python,实为我等学习楷模。先前我并没有关注武汉肺炎的具体数据,也没有画过类似的数据分布图。于是就拿了两个小时,专门研究了一下,遂成此文。 2月6日追记:本文发布后,腾讯的数据源多次变更u
听说想当黑客的都玩过这个Monyer游戏(1~14攻略)
第零关 进入传送门开始第0关(游戏链接) 请点击链接进入第1关: 连接在左边→ ←连接在右边 看不到啊。。。。(只能看到一堆大佬做完的留名,也能看到菜鸡的我,在后面~~) 直接fn+f12吧 &lt;span&gt;连接在左边→&lt;/span&gt; &lt;a href="first.php"&gt;&lt;/a&gt; &lt;span&gt;←连接在右边&lt;/span&gt; o
在家远程办公效率低?那你一定要收好这个「在家办公」神器!
相信大家都已经收到国务院延长春节假期的消息,接下来,在家远程办公可能将会持续一段时间。 但是问题来了。远程办公不是人在电脑前就当坐班了,相反,对于沟通效率,文件协作,以及信息安全都有着极高的要求。有着非常多的挑战,比如: 1在异地互相不见面的会议上,如何提高沟通效率? 2文件之间的来往反馈如何做到及时性?如何保证信息安全? 3如何规划安排每天工作,以及如何进行成果验收? ......
作为一个程序员,内存和磁盘的这些事情,你不得不知道啊!!!
截止目前,我已经分享了如下几篇文章: 一个程序在计算机中是如何运行的?超级干货!!! 作为一个程序员,CPU的这些硬核知识你必须会! 作为一个程序员,内存的这些硬核知识你必须懂! 这些知识可以说是我们之前都不太重视的基础知识,可能大家在上大学的时候都学习过了,但是嘞,当时由于老师讲解的没那么有趣,又加上这些知识本身就比较枯燥,所以嘞,大家当初几乎等于没学。 再说啦,学习这些,也看不出来有什么用啊!
渗透测试-灰鸽子远控木马
木马概述 灰鸽子( Huigezi),原本该软件适用于公司和家庭管理,其功能十分强大,不但能监视摄像头、键盘记录、监控桌面、文件操作等。还提供了黑客专用功能,如:伪装系统图标、随意更换启动项名称和表述、随意更换端口、运行后自删除、毫无提示安装等,并采用反弹链接这种缺陷设计,使得使用者拥有最高权限,一经破解即无法控制。最终导致被黑客恶意使用。原作者的灰鸽子被定义为是一款集多种控制方式于一体的木马程序
Python:爬取疫情每日数据
前言 有部分同学留言说为什么412,这是因为我代码里全国的cookies需要你自己打开浏览器更新好后替换,而且这个cookies大概只能持续20秒左右! 另外全国卫健委的数据格式一直在变,也有可能会导致爬取失败! 我现在已根据2月14日最新通报稿的格式修正了! 目前每天各大平台,如腾讯、今日头条都会更新疫情每日数据,他们的数据源都是一样的,主要都是通过各地的卫健委官网通报。 为什么已经有大量平台做
这个世界上人真的分三六九等,你信吗?
偶然间,在知乎上看到一个问题 一时间,勾起了我深深的回忆。 以前在厂里打过两次工,做过家教,干过辅导班,做过中介。零下几度的晚上,贴过广告,满脸、满手地长冻疮。   再回首那段岁月,虽然苦,但让我学会了坚持和忍耐。让我明白了,在这个世界上,无论环境多么的恶劣,只要心存希望,星星之火,亦可燎原。   下文是原回答,希望能对你能有所启发。   如果我说,这个世界上人真的分三六九等,
B 站上有哪些很好的学习资源?
哇说起B站,在小九眼里就是宝藏般的存在,放年假宅在家时一天刷6、7个小时不在话下,更别提今年的跨年晚会,我简直是跪着看完的!! 最早大家聚在在B站是为了追番,再后来我在上面刷欧美新歌和漂亮小姐姐的舞蹈视频,最近两年我和周围的朋友们已经把B站当作学习教室了,而且学习成本还免费,真是个励志的好平台ヽ(.◕ฺˇд ˇ◕ฺ;)ノ 下面我们就来盘点一下B站上优质的学习资源: 综合类 Oeasy: 综合
雷火神山直播超两亿,Web播放器事件监听是怎么实现的?
Web播放器解决了在手机浏览器和PC浏览器上播放音视频数据的问题,让视音频内容可以不依赖用户安装App,就能进行播放以及在社交平台进行传播。在视频业务大数据平台中,播放数据的统计分析非常重要,所以Web播放器在使用过程中,需要对其内部的数据进行收集并上报至服务端,此时,就需要对发生在其内部的一些播放行为进行事件监听。 那么Web播放器事件监听是怎么实现的呢? 01 监听事件明细表 名
3万字总结,Mysql优化之精髓
本文知识点较多,篇幅较长,请耐心学习 MySQL已经成为时下关系型数据库产品的中坚力量,备受互联网大厂的青睐,出门面试想进BAT,想拿高工资,不会点MySQL优化知识,拿offer的成功率会大大下降。 为什么要优化 系统的吞吐量瓶颈往往出现在数据库的访问速度上 随着应用程序的运行,数据库的中的数据会越来越多,处理时间会相应变慢 数据是存放在磁盘上的,读写速度无法和内存相比 如何优化 设计
Python新型冠状病毒疫情数据自动爬取+统计+发送报告+数据屏幕(三)发送篇
今天介绍的项目是使用 Itchat 发送统计报告 项目功能设计: 定时爬取疫情数据存入Mysql 进行数据分析制作疫情报告 使用itchat给亲人朋友发送分析报告(本文) 基于Django做数据屏幕 使用Tableau做数据分析 来看看最终效果 目前已经完成,预计2月12日前更新 使用 itchat 发送数据统计报告 itchat 是一个基于 web微信的一个框架,但微信官方并不允
作为程序员的我,大学四年一直自学,全靠这些实用工具和学习网站!
我本人因为高中沉迷于爱情,导致学业荒废,后来高考,毫无疑问进入了一所普普通通的大学,实在惭愧...... 我又是那么好强,现在学历不行,没办法改变的事情了,所以,进入大学开始,我就下定决心,一定要让自己掌握更多的技能,尤其选择了计算机这个行业,一定要多学习技术。 在进入大学学习不久后,我就认清了一个现实:我这个大学的整体教学质量和学习风气,真的一言难尽,懂的人自然知道怎么回事? 怎么办?我该如何更好的提升
粒子群算法求解物流配送路线问题(python)
粒子群算法求解物流配送路线问题(python) 1.查找论文文献 找一篇物流配送路径优化+粒子群算法求解的论文 参考文献:基于混沌粒子群算法的物流配送路径优化 2.了解粒子群算法的原理 讲解通俗易懂,有数学实例的博文:https://blog.csdn.net/daaikuaichuan/article/details/81382794 3.确定编码方式和解码策略 3.1编码方式 物流配送路线的
教你如何编写第一个简单的爬虫
很多人知道爬虫,也很想利用爬虫去爬取自己想要的数据,那么爬虫到底怎么用呢?今天就教大家编写一个简单的爬虫。 下面以爬取笔者的个人博客网站为例获取第一篇文章的标题名称,教大家学会一个简单的爬虫。 第一步:获取页面 #!/usr/bin/python # coding: utf-8 import requests #引入包requests link = "http://www.santostang.
前端JS初级面试题二 (。•ˇ‸ˇ•。)老铁们!快来瞧瞧自己都会了么
1. 传统事件绑定和符合W3C标准的事件绑定有什么区别? 传统事件绑定 &lt;div onclick=""&gt;123&lt;/div&gt; div1.onclick = function(){}; &lt;button onmouseover=""&gt;&lt;/button&gt; 注意: 如果给同一个元素绑定了两次或多次相同类型的事件,那么后面的绑定会覆盖前面的绑定 (不支持DOM事...
相关热词 c# 数组类型 泛型约束 c#的赛狗日程序 c# 传递数组 可变参数 c# 生成存储过程 c# list 补集 c#获得所有窗体 c# 当前秒数转成年月日 c#中的枚举 c# 计算校验和 连续随机数不重复c#
立即提问