SpringMvc MultipartFile实现图片文件上传示例

 更新时间:2017年02月28日 11:34:06   作者:LEARN4J  
本篇文章主要介绍了SpringMvc MultipartFile实现图片文件上传示例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。

整理文档,搜刮出一个SpringMvc MultipartFile实现图片文件上传示例,稍微整理精简一下做下分享。

spring-servlet.xml

<!-- SpringMVC上传文件时,需要配置MultipartResolver处理器 -->
  <bean id="multipartResolver"
    class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
    <property name="defaultEncoding" value="UTF-8" />
    <!-- 指定所上传文件的总大小,单位字节。注意maxUploadSize属性的限制不是针对单个文件,而是所有文件的容量之和 -->
    <property name="maxUploadSize" value="10240000" />
  </bean>

upload/index.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>单图片上传</title>
</head>
<body>
<fieldset>
<legend>图片上传</legend>
<h2>只能上传单张10M以下的 PNG、JPG、GIF 格式的图片</h2>
<form action="/shop/auth/photoUpload" method="post" enctype="multipart/form-data">
  选择文件:<input type="file" name="file">
  <input type="submit" value="上传"> 
</form>
</fieldset>
</body>
</html>

或者使用ExtJs

js/user/photoUpload.js

Ext.onReady(function(){
  Ext.create('Ext.form.Panel', {
    title: '图片上传',
    width: 600,
    bodyPadding: 10,
    frame: true,
    renderTo: Ext.getBody(),
    items: [{
      xtype: 'filefield',
      name: 'file',
      fieldLabel: 'Photo',
      labelWidth: 50,
      msgTarget: 'side',
      fileUpload: true ,
      allowBlank: false,
      blankText:"Select an image",
      emptyText: 'You can only upload a single PNG 10M or less, JPG, GIF format images',
      anchor: '100%',
      buttonText: '选择图片'
    }],

    buttons: [{
      text: '上传',
      handler: function() {
        var form = this.up('form').getForm();
        if(form.isValid()){
          form.submit({
            url: '/shop/auth/photoUpload',
            waitMsg: '正在上传图片...',
            success: function(fp, o) {
              Ext.Msg.alert('提示', o.result.msg);
            }
          });
        }
      }
    }]
  });
});

pages/user/photoUpload.html

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>图片上传</title>
</head>
<link href="../../ext-4.2.1.883/resources/css/ext-all.css" rel="external nofollow" rel="stylesheet"
  type="text/css" />
<script type="text/javascript" src="../../ext-4.2.1.883/ext-all.js"></script>
<script src="../../js/user/photoUpload.js" type="text/javascript"></script>
<body>

</body>
</html>

AuthController.java

/**
   * 图片文件上传
   */
  @ResponseBody
  @RequestMapping(value = "/photoUpload",method = RequestMethod.POST)
  public ResultData<Object> photoUpload(MultipartFile file,HttpServletRequest request,HttpServletResponse response,HttpSession session) throws IllegalStateException, IOException{
    ResultData<Object> resultData=new ResultData<>();
    // 判断用户是否登录
    /*User user=(User) session.getAttribute("user");
    if (user==null) {
      resultData.setCode(40029);
      resultData.setMsg("用户未登录");
      return resultData;
    }*/
    if (file!=null) {// 判断上传的文件是否为空
      String path=null;// 文件路径
      String type=null;// 文件类型
      String fileName=file.getOriginalFilename();// 文件原名称
      System.out.println("上传的文件原名称:"+fileName);
      // 判断文件类型
      type=fileName.indexOf(".")!=-1?fileName.substring(fileName.lastIndexOf(".")+1, fileName.length()):null;
      if (type!=null) {// 判断文件类型是否为空
        if ("GIF".equals(type.toUpperCase())||"PNG".equals(type.toUpperCase())||"JPG".equals(type.toUpperCase())) {
          // 项目在容器中实际发布运行的根路径
          String realPath=request.getSession().getServletContext().getRealPath("/");
          // 自定义的文件名称
          String trueFileName=String.valueOf(System.currentTimeMillis())+fileName;
          // 设置存放图片文件的路径
          path=realPath+/*System.getProperty("file.separator")+*/trueFileName;
          System.out.println("存放图片文件的路径:"+path);
          // 转存文件到指定的路径
          file.transferTo(new File(path));
          System.out.println("文件成功上传到指定目录下");
        }else {
          System.out.println("不是我们想要的文件类型,请按要求重新上传");
          return null;
        }
      }else {
        System.out.println("文件类型为空");
        return null;
      }
    }else {
      System.out.println("没有找到相对应的文件");
      return null;
    }
    return resultData;
  }

ResultData.java 代码如下:

public class ResultData<T> {
 private T data;
 private int code =200;
 private String msg;
 private Boolean success = true;
 public Boolean getSuccess() {

 return success;

 }
 public void setSuccess(Boolean success) {

 this.success = success;

 }
 public T getData() {

 return data;

 }
 public void setData(T data) {

 this.data = data;

 }
 public int getCode() {

 

 return code;

 }
 public void setCode(int code) {

 if(200 != code){

  success = false;

 }

 this.code = code;

 }
 public String getMsg() {

 return msg;

 }
 public void setMsg(String msg) {

 this.msg = msg;

 }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • javaweb servlet生成简单验证码

    javaweb servlet生成简单验证码

    这篇文章主要为大家详细介绍了javaweb servlet生成简单验证码,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-03-03
  • 一文搞懂Java中的日期类

    一文搞懂Java中的日期类

    在程序的开发中我们经常会遇到日期类型的操作,Java对日期类型的操作提供了很好的支持。本文将通过示例来聊聊Java中日期类的使用,需要的可以参考一下
    2022-09-09
  • RocketMQ消息积压原因及处理方法

    RocketMQ消息积压原因及处理方法

    RocketMQ是一种可靠的、可扩展的消息中间件,广泛应用于分布式系统中的消息通信,然而,在高并发的场景下,由于消息产生速度超过消费速度,可能会导致消息积压的问题,本文将介绍RocketMQ消息积压的原因和如何处理积压问题
    2023-06-06
  • 详解Java接口的相关知识

    详解Java接口的相关知识

    今天给大家带来的是关于Java基础的相关知识,文章围绕着Java接口展开,文中有非常详细的介绍及代码示例,需要的朋友可以参考下
    2021-06-06
  • Spring Boot RestController接口输出到终端的操作代码

    Spring Boot RestController接口输出到终端的操作代码

    这篇文章主要介绍了Spring Boot RestController接口如何输出到终端,使用 HttpServletResponse 类,可以在使用curl执行 Spring Boot REST接口的同时,在控制台输出一些信息,给运维人员知道当前命令执行的状态,感兴趣的朋友跟随小编一起看看吧
    2023-09-09
  • SpringBoot路径映射实现过程图解

    SpringBoot路径映射实现过程图解

    这篇文章主要介绍了SpringBoot路径映射实现过程图解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-12-12
  • Java方法参数装配顺序详解

    Java方法参数装配顺序详解

    这篇文章主要介绍了Java方法参数装配顺序详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-03-03
  • WebUploader客户端批量上传图片 后台使用springMVC

    WebUploader客户端批量上传图片 后台使用springMVC

    这篇文章主要为大家详细介绍了WebUploader客户端批量上传图片,后台使用springMVC接收实例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-09-09
  • java IO流读取图片供前台显示代码分享

    java IO流读取图片供前台显示代码分享

    这篇文章主要介绍了java IO流读取图片供前台显示代码分享,具有一定借鉴价值,需要的朋友可以参考下。
    2017-12-12
  • Java网络编程之TCP程序设计

    Java网络编程之TCP程序设计

    这篇文章主要为大家详细介绍了Java网络编程之TCP程序设计,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-08-08

最新评论