SpringMvc MultipartFile实现图片文件上传示例
发布时间 - 2026-01-10 23:19:47 点击率:次整理文档,搜刮出一个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;
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# multipartfile
# 上传
# spring
# mvc
# 文件上传
# mvc图片的上传
# SpringMVC中MultipartFile转File的两种方式
# SpringMVC 上传文件 MultipartFile 转为 File的方法
# SpringMVC使用MultipartFile实现文件上传
# SpringMVC使用MultipartFile 实现异步上传方法介绍
# SpringMVC中MultipartFile上传获取图片的宽度和高度详解
# springMVC MultipartFile上传图片时如何修改图片大小
# 图片上传
# 为空
# 上传文件
# 自定义
# 请按
# 没有找到
# 上传图片
# 相对应
# 大家多多
# 文档
# 目录下
# photoUpload
# method
# auth
# form
# action
# shop
# input
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Swift中循环语句中的转移语句 break 和 continue
Laravel如何使用模型观察者?(Observer代码示例)
免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?
如何使用 jQuery 正确渲染 Instagram 风格的标签列表
Laravel如何使用Gate和Policy进行权限控制_Laravel权限判定与策略规则配置
QQ浏览器网页版登录入口 个人中心在线进入
php485函数参数是什么意思_php485各参数详细说明【介绍】
Laravel用户认证怎么做_Laravel Breeze脚手架快速实现登录注册功能
在线教育网站制作平台,山西立德教育官网?
Bootstrap整体框架之CSS12栅格系统
Laravel Fortify是什么,和Jetstream有什么关系
Laravel如何使用Seeder填充数据_Laravel模型工厂Factory批量生成测试数据【方法】
JavaScript如何操作视频_媒体API怎么控制播放
如何登录建站主机?访问步骤全解析
网页制作模板网站推荐,网页设计海报之类的素材哪里好?
php结合redis实现高并发下的抢购、秒杀功能的实例
Laravel如何操作JSON类型的数据库字段?(Eloquent示例)
Java Adapter 适配器模式(类适配器,对象适配器)优缺点对比
香港服务器网站推广:SEO优化与外贸独立站搭建策略
Laravel观察者模式如何使用_Laravel Model Observer配置
香港服务器WordPress建站指南:SEO优化与高效部署策略
Laravel Artisan命令怎么自定义_创建自己的Laravel命令行工具完全指南
Claude怎样写结构化提示词_Claude结构化提示词写法【教程】
零服务器AI建站解决方案:快速部署与云端平台低成本实践
清除minerd进程的简单方法
Laravel如何实现API速率限制?(Rate Limiting教程)
Chrome浏览器标签页分组怎么用_谷歌浏览器整理标签页技巧【效率】
浅述节点的创建及常见功能的实现
如何将凡科建站内容保存为本地文件?
Laravel Admin后台管理框架推荐_Laravel快速开发后台工具
浅谈Javascript中的Label语句
Laravel怎么解决跨域问题_Laravel配置CORS跨域访问
Laravel怎么创建控制器Controller_Laravel路由绑定与控制器逻辑编写【指南】
Laravel事件监听器怎么写_Laravel Event和Listener使用教程
如何挑选最适合建站的高性能VPS主机?
宙斯浏览器怎么屏蔽图片浏览 节省手机流量使用设置方法
Laravel如何使用Eloquent进行子查询
图册素材网站设计制作软件,图册的导出方式有几种?
如何实现建站之星域名转发设置?
Laravel的辅助函数有哪些_Laravel常用Helpers函数提高开发效率
Laravel如何配置Horizon来管理队列?(安装和使用)
简单实现Android文件上传
如何用虚拟主机快速搭建网站?详细步骤解析
西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?
网站制作软件有哪些,制图软件有哪些?
韩国服务器如何优化跨境访问实现高效连接?
Laravel怎么使用Markdown渲染文档_Laravel将Markdown内容转HTML页面展示【实战】
Google浏览器为什么这么卡 Google浏览器提速优化设置步骤【方法】
如何做网站制作流程,*游戏网站怎么搭建?
如何用AWS免费套餐快速搭建高效网站?

