SpringMvc MultipartFile 图片文件上传

 

spring-servlet.xml

复制代码

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

复制代码

 upload/index.jsp

复制代码

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

复制代码

 

或者使用ExtJs

js/user/photoUpload.js

复制代码

 1 Ext.onReady(function(){
 2     Ext.create('Ext.form.Panel', {
 3         title: '图片上传',
 4         width: 600,
 5         bodyPadding: 10,
 6         frame: true,
 7         renderTo: Ext.getBody(),
 8         items: [{
 9             xtype: 'filefield',
10             name: 'file',
11             fieldLabel: 'Photo',
12             labelWidth: 50,
13             msgTarget: 'side',
14             fileUpload: true ,
15             allowBlank: false,
16             blankText:"Select an image",
17             emptyText: 'You can only upload a single PNG 10M or less, JPG, GIF format images',
18             anchor: '100%',
19             buttonText: '选择图片'
20         }],
21 
22         buttons: [{
23             text: '上传',
24             handler: function() {
25                 var form = this.up('form').getForm();
26                 if(form.isValid()){
27                     form.submit({
28                         url: '/shop/auth/photoUpload',
29                         waitMsg: '正在上传图片...',
30                         success: function(fp, o) {
31                             Ext.Msg.alert('提示', o.result.msg);
32                         }
33                     });
34                 }
35             }
36         }]
37     });
38 });

复制代码

pages/user/photoUpload.html

复制代码

 1 <!DOCTYPE html>
 2 <html>
 3 <head>
 4 <meta charset="UTF-8">
 5 <title>图片上传</title>
 6 </head>
 7 <link href="../../ext-4.2.1.883/resources/css/ext-all.css" rel="stylesheet"
 8     type="text/css" />
 9 <script type="text/javascript" src="../../ext-4.2.1.883/ext-all.js"></script>
10 <script src="../../js/user/photoUpload.js" type="text/javascript"></script>
11 <body>
12 
13 </body>
14 </html>  

复制代码

AuthController.java

复制代码

 1   /**
 2      * 图片文件上传
 3      */
 4     @ResponseBody
 5     @RequestMapping(value = "/photoUpload",method = RequestMethod.POST)
 6     public ResultData<Object> photoUpload(MultipartFile file,HttpServletRequest request,HttpServletResponse response,HttpSession session) throws IllegalStateException, IOException{
 7         ResultData<Object> resultData=new ResultData<>();
 8         // 判断用户是否登录
 9         /*User user=(User) session.getAttribute("user");
10         if (user==null) {
11             resultData.setCode(40029);
12             resultData.setMsg("用户未登录");
13             return resultData;
14         }*/
15         if (file!=null) {// 判断上传的文件是否为空
16             String path=null;// 文件路径
17             String type=null;// 文件类型
18             String fileName=file.getOriginalFilename();// 文件原名称
19             System.out.println("上传的文件原名称:"+fileName);
20             // 判断文件类型
21             type=fileName.indexOf(".")!=-1?fileName.substring(fileName.lastIndexOf(".")+1, fileName.length()):null;
22             if (type!=null) {// 判断文件类型是否为空
23                 if ("GIF".equals(type.toUpperCase())||"PNG".equals(type.toUpperCase())||"JPG".equals(type.toUpperCase())) {
24                     // 项目在容器中实际发布运行的根路径
25                     String realPath=request.getSession().getServletContext().getRealPath("/");
26                     // 自定义的文件名称
27                     String trueFileName=String.valueOf(System.currentTimeMillis())+fileName;
28                     // 设置存放图片文件的路径
29                     path=realPath+/*System.getProperty("file.separator")+*/trueFileName;
30                     System.out.println("存放图片文件的路径:"+path);
31                     // 转存文件到指定的路径
32                     file.transferTo(new File(path));
33                     System.out.println("文件成功上传到指定目录下");
34                 }else {
35                     System.out.println("不是我们想要的文件类型,请按要求重新上传");
36                     return null;
37                 }
38             }else {
39                 System.out.println("文件类型为空");
40                 return null;
41             }
42         }else {
43             System.out.println("没有找到相对应的文件");
44             return null;
45         }
46         return resultData;
47     }

复制代码

 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;

}

}

分类: JAVAEE

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值