SpringMVC上传文件,批量上传文件

一:导入相关Jar包

commons-fileupload.jar

commons-io.jar

 

二:配置web.xml。上载解析器

<!-- 文件上传配置 -->
<bean id="multipartResolver"  class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
    <!-- 设置编码格式 -->  
    <property name="defaultEncoding" value="utf-8"></property> 
    <!-- 设置文件大小 -->  
    <property name="maxUploadSize" value="10485760000"></property>
    <!-- 设置缓冲区大小 -->  
    <property name="maxInMemorySize" value="40960"></property>  
</bean> 

 

三:web页面

<form action="upload.do" enctype="multipart/form-data" method="post">
  	文件:<input type="file" name="file"/><input type="submit" value="上传"/>
</form>

 

四:controller类 @RequestParam("file") 这个注解必须有

/**
* spring mvc封装了上传文件  将其封装为一个file对象
* */
@RequestMapping("/upload.do")
public String upload(@RequestParam("file") CommonsMultipartFile file,HttpServletRequest req){
    //获取上传位置
    String path=req.getRealPath("/upload");
    //获取文件名
    String filename=file.getOriginalFilename();
    try {
        InputStream is = file.getInputStream();
        OutputStream os = new FileOutputStream(new File(path,filename));
        int len=0;
        byte[] buffer = new byte[400];
        while((len=is.read(buffer))!=-1){
            os.write(buffer, 0, len);
        }
        os.close();
        is.close();
    } catch (FileNotFoundException e) {
        e.printStackTrace();
    } catch (IOException e) {
        e.printStackTrace();
    }
    return "redirect:index.jsp";
}

 

五:批量上传web页面

<form action="batch.do" enctype="multipart/form-data" method="post">
  	文件1:<input type="file" name="file"/><br>
  	文件2:<input type="file" name="file"/><br>
  	<input type="submit" value="上传"/>
</form>

 

六:批量上传controller类

@RequestMapping("/batch.do")
public String batch(@RequestParam("file") CommonsMultipartFile file[],HttpServletRequest req){
    //获取上传位置
    String path=req.getRealPath("/upload");
    for(int i=0;i<file.length;i++){
        //获取文件名
        String filename=file[i].getOriginalFilename();
        try {
            InputStream is = file[i].getInputStream();
           OutputStream os = new FileOutputStream(new File(path,filename));
           int len=0;
           byte[] buffer = new byte[400];
           while((len=is.read(buffer))!=-1){
               os.write(buffer, 0, len);
           }
           os.close();
           is.close();
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
    return "redirect:index.jsp";
}

 

java 基于springMVC多图片上传,MySQL源码 @Controller @RequestMapping("/upload") public class UploadFileController { @Autowired private UploadFileService uploadFileService; @RequestMapping("/upfile") public String upload(HttpServletRequest request, @RequestParam("designation") String designation, @RequestParam("remark") String remark, //@RequestParam("file") String file, Model model)throws Exception { String str = designation; String[] st=str.split(","); //以逗号为分隔符进行截取 String re = remark; String[] stre = re.split(","); UploadFile uploadFile = new UploadFile(); //转成文件上传请求 MultipartHttpServletRequest murequest = (MultipartHttpServletRequest)request; //在文件上传请求中获取文件,根据file的name List files = murequest.getFiles("image"); if( files !=null && files.size()>0) { for(int i=0; i<files.size(); i++) { String uuid = UUID.randomUUID().toString().replace("-", "").toUpperCase()+"_"; String filename = files.get(i).getOriginalFilename(); //System.out.println("filename="+filename); int hCode =filename.hashCode(); String hex = Integer.toHexString(hCode); String mkdir = hex.charAt(0)+"\\"+hex.charAt(1)+"\\"; String path = request.getServletContext().getRealPath("/images/")+mkdir; //System.out.println("path="+path); File filepath = new File(path,filename); if(!filepath.getParentFile().exists()) { filepath.getParentFile().mkdirs(); } //将上传文件保存到目标文件中 files.get(i).transferTo(new File(path+File.separator+filename)); //获取数据库存储路径 String root = request.getContextPath(); String mkdirsql = hex.charAt(0)+"/"+hex.charAt(1)+"/"; String sqlpath = root+"/images/"+mkdirsql+filename; String imgpath = sqlpath; //图片保存到数据库的路径 uploadFile.setDesignation(st[i]); uploadFile.setRemark(stre[i]); uploadFile.setFile(filename); uploadFile.setImgpath(sqlpath); uploadFileService.addUploadFile(uploadFile); } return "success"; } return "404"; }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

EngineerForSoul

你的鼓励是我孜孜不倦的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值