springMVC图片上传,单图片上传和多图片上传以及预览

描述:在工作中我们常常会用到图片上传功能, 例如,商城中的商品,用户头像等场景下需要用到。下面小刘讲解单图片上传和多图片上传以及预览图片的功能实现;

前言:本功能实现基于SSM框架,至于SSM框架的搭建,本文不再赘述。4

请看另一篇博客讲解:SSM框架的基本搭建_小刘的博客-CSDN博客_ssm框架

1.上传文件所必须的jar包以及spring的相关配置

<dependency>  
    <groupId>commons-fileupload</groupId>  
    <artifactId>commons-fileupload</artifactId>  
    <version>1.3.1</version>  
</dependency>  
<dependency>  
    <groupId>commons-io</groupId>  
    <artifactId>commons-io</artifactId>  
    <version>2.4</version>  
</dependency> 

spring.xml中添加配置

<!-- 上传文件 -->  
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">  
    <property name="defaultEncoding" value="utf-8"/>  
    <!-- 最大内存大小 -->  
    <property name="maxInMemorySize" value="10240"/>  
    <!-- 最大文件大小,-1为不限制大小 -->  
    <property name="maxUploadSize" value="-1"/>  
</bean>  

 2.单图片页面上传前端代码                    

上图为单图片上传前台代码显示,以及预览,表单控件隐藏触发,既可假改变上传样式。(可更改你喜欢的)下图为效果:

3.前端多图片上传预览代码

<tr>
<td height="40px">
<input type="file" id="productFileId" multiple="multiple" name="productFiles" onchange="javascript:setImagePreviews(this.id);" accept="image/*"  />
</td>
<td rowspan="2" colspan="4" id="productImagesId"></td>
</tr>

特别注意:如果你想上传到后台,你的form表单需要加入:

 method="post" enctype="multipart/form-data" 标签:而且单图片和多图片的html代码略有不同,请细看;

4.后台文件上传的接口方法api


    /**
     * 上传单个文件方法
     * @param request
     * @param file
     * @return
     * @throws IOException
     */
    public static boolean uploadOneFile(HttpServletRequest request, @RequestParam("file") MultipartFile file) throws IOException {
        if (!file.isEmpty()) { //如果文件不为空,写入上传路径
            String path = request.getSession().getServletContext().getRealPath("/images/upload"); //上传文件路径
            //文件原始名字
            String filename = file.getOriginalFilename();
            String suffixLast = filename.substring(filename.lastIndexOf("."));  //获取文件后缀
            String newFileName = Utils.getUUID()+suffixLast;     //文件新名字
            File filepath = new File(path, newFileName);
            判断路径是否存在,如果不存在就创建一个
            if (!filepath.getParentFile().exists()) {
                filepath.getParentFile().mkdirs();
            }
            //将上传文件保存到一个目标文件当中
            file.transferTo(new File(path + File.separator + newFileName));
            String imageUrl="/images/upload/"+newFileName;
            request.getSession().setAttribute("imageUploadUrl",imageUrl);
            return true;
        }
        return false;
    }
    /**
     * 上传多个文件方法
     * @param request
     * @param files
     * @return
     */
    public static boolean uploadManyFiles(
            HttpServletRequest request,
            @RequestParam("files") MultipartFile[] files){
        String path = request.getSession().getServletContext().getRealPath("/images/upload");
        try {
            System.out.println("上传数组图片的长度是"+files.length);
            if (files.length!=0){
                String s="";
                for (int i = 0; i < files.length; i++) {
                    /**
                     * 必须进行判断,否则数组会越界
                     */
                    if (files[i].isEmpty()){
                        return false;
                    }
                    //文件原始名字
                    String filename = files[i].getOriginalFilename();
                    //获取文件后缀
                    String suffixLast = filename.substring(filename.lastIndexOf("."));

                    //文件新名字
                    String newFileName = Utils.getUUID()+suffixLast;
                    File filepath = new File(path, newFileName);
                    if (!filepath.getParentFile().exists()) {
                        filepath.getParentFile().mkdirs();
                    }
                    files[i].transferTo(new File(path + File.separator + newFileName));
                    s+="/images/upload/"+newFileName+"-";
                }
                System.out.println("这是我的图片拼接成的数组字符"+s);
                request.getSession().setAttribute("imageUploadUrl",s);
                return true;
            }
            return false;
        } catch (IOException e) {
            e.printStackTrace();
            return false;
        }
    }

4.1.单个文件上传的接口

    @RequestMapping(value = "/addCompany")
    @ResponseBody
    public String addCompany(
            HttpServletRequest request,
            @RequestParam("file") MultipartFile file) throws IOException {
        boolean b = Utils.uploadOneFile(request, file);
        if (b){
            String url = (String) request.getSession().getAttribute("imageUploadUrl");
            return "单图片上传成功"+url;
        }
        return "单图片上传失败";
    }

4.2.多图片文件上传的接口

@RequestMapping(value = "/addManyCompany")
    @ResponseBody
    public String addManyCompany(
            HttpServletRequest request,
            @RequestParam("files") MultipartFile[] files) throws IOException {
        boolean b = Utils.uploadManyFiles(request, files);
        if (b){
            String urls = (String) request.getSession().getAttribute("imageUploadUrl");
            String[] strings = urls.split("-");
            for (String s:strings){
                System.out.println("上传的数组图片"+s);
            }
            return "多图片上传成功"+urls;
        }
        return "多图片上传失败";
    }

特别接口:比如你想商品类和其他类都上传图片的场景

/**
     * 上传多图片和添加企业信息
     * @param request
     * @param file
     * @param companyFiles
     * @param productFiles
     * @return
     * @throws IOException
     */
    @RequestMapping(value = "/addCompanyOneAndMore")
    @ResponseBody
    public String addCompanyOneAndMore(
            HttpServletRequest request,
            @ModelAttribute CompanyVO companyVO,
            @RequestParam("file") MultipartFile file,
            @RequestParam("companyFiles") MultipartFile[] companyFiles,
            @RequestParam("productFiles") MultipartFile[] productFiles) throws IOException {

。。。。。。。。。。。。。。。。。。
}

方法不再赘述,和单图片多图片类似。如有不解,请加java爱好群大家交流:852665736;大家一起交流,群里都是热心好客的小伙伴,大家一同进步。

无偿免费分享源码以及技术和面试文档,更多优秀精致的源码技术栈分享请关注公众号:gh_817962068649

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
要在SSM框架中使用Ajax实现图片上传到服务器、显示以及选择图片之后在前端显示的功能,可以按照以下步骤进行操作: 1. 在前端页面中添加一个上传图片的input标签,并使用Ajax将图片上传到后台Controller中。 2. 在Controller中使用SpringMVC文件上传功能,将图片保存到服务器指定的路径中。 3. 在Controller中返回图片的访问路径,然后使用Ajax在前端页面中显示图片。 4. 如果需要实现选择图片之后在前端页面中显示,可以使用jQuery的Ajax和HTML5的File API来实现。首先,在前端页面中添加一个显示图片的img标签,然后通过jQuery选择文件,使用Ajax将文件上传到后台Controller中。在Controller中使用SpringMVC文件上传功能,将图片保存到服务器指定的路径中。最后,在Controller中返回图片的访问路径,并使用File API在前端页面中显示图片。 具体实现细节参考以下代码: 前端页面: ```html <input type="file" id="fileUpload" name="fileUpload"/> <img id="preview" src="" style="display:none;"/> <script> $(function() { // 选择图片后显示预览图 $("#fileUpload").change(function() { var file = this.files[0]; var reader = new FileReader(); reader.onload = function(e) { $("#preview").attr("src", e.target.result); $("#preview").show(); } reader.readAsDataURL(file); // 使用Ajax上传图片 var formData = new FormData(); formData.append("file", file); $.ajax({ url: "uploadImage", type: "POST", data: formData, contentType: false, processData: false, success: function(data) { // 显示上传的图片 $("#preview").attr("src", data); } }); }); }); </script> ``` 后台Controller: ```java @Controller public class ImageController { @RequestMapping(value="/uploadImage", method=RequestMethod.POST) @ResponseBody public String uploadImage(@RequestParam("file") MultipartFile file) { String fileName = UUID.randomUUID().toString() + ".jpg"; String filePath = "upload/" + fileName; try { // 保存图片到服务器 file.transferTo(new File(filePath)); // 返回图片的访问路径 return filePath; } catch (Exception e) { e.printStackTrace(); return ""; } } } ``` 注意事项: 1. 在Controller中需要添加`@ResponseBody`注解,将返回值转换成JSON格式。 2. 在前端页面中需要添加jQuery和File API的引用。 3. 在服务器中需要设置文件上传的临时目录和上传文件的大小限制。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值