SSM框架实现多张图片和其他数据一起上传
一、SSM+Form 多张图片和其他数据一起上传,
1、导包:
commons-fileupload-1.3.3.jar
commons-io-2.4.jar
2、springmvc.xml 文件配置
<!--文件上传,id必须设置为multipartResolver-->
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<!--设置上传大小 单位:B-->
<property name="maxUploadSize" value="10240000"></property>
</bean>
3、后端设置
@RequestMapping(value = "/upload.do")
public String updateItem(MultipartFile[] pictureFile,User user,HttpServletRequest request) throws IOException {
//图片上传 //设置图片名称,名称不能重复,可以使用uuid
String picName = UUID.randomUUID().toString().replace("-","");
System.out.println("传入图片的数量:"+pictureFile.length);
System.out.println("传入其他的参数或者实体:"+user);
//获取文件名
String oriName = pictureFile[0].getOriginalFilename();
System.out.println("获取文件名 "+oriName);
//获取图片后缀
String extName = oriName.substring(oriName.lastIndexOf("."));
System.out.println("获取图片后缀"+extName);
String path = request.getSession().getServletContext().getRealPath("image");
System.out.println("图片路径"+path);
File dir = new File(path,picName+extName);
if(!dir.exists()){
dir.mkdirs();
}
//开始上传
pictureFile[0].transferTo(dir);
return "forward:/index.html";
}
4、前端页面配置
<form enctype="multipart/form-data" method="post" action="upload.action">
文件:<input type="file" name="pictureFile" multiple/>
姓名:<input type="text" name="username"/>
密码:<input type="text" name="password">
<input type="submit" value="上传"/>
</form>
二、SSM+AJAX 多张图片和其他数据一起上传,总共四个步骤:
1、导包:
同上。
2、springmvc.xml 文件配置
同上。
3、controller 后台设置
@RequestMapping(value = "/upload.do")
public String updateItem(@RequestParam("pictureFile") MultipartFile[] pictureFile,User user,HttpServletRequest request) throws IOException {
//图片上传 //设置图片名称,名称不能重复,可以使用uuid
String picName = UUID.randomUUID().toString().replace("-","");
System.out.println("传入图片的数量:"+pictureFile.length);
System.out.println("传入其他的参数或者实体:"+user);
//获取文件名
String oriName = pictureFile[0].getOriginalFilename();
System.out.println("获取文件名 "+oriName);
//获取图片后缀
String extName = oriName.substring(oriName.lastIndexOf("."));
System.out.println("获取图片后缀"+extName);
String path = request.getSession().getServletContext().getRealPath("image");
System.out.println("图片路径"+path);
File dir = new File(path,picName+extName);
if(!dir.exists()){
dir.mkdirs();
}
//开始上传
pictureFile[0].transferTo(dir);
return "forward:/index.html";
}
4、前端页面配置:
文件:<input type="file" name="pictureFile" multiple/>
姓名:<input type="text" name="username"/>
密码:<input type="text" name="password">
<input type="submit" value="上传" onclick="shangchuan()"/>
js部分
<script type="text/javascript">
function shangchuan() {
var username = document.getElementsByName("username")[0].value;
var password = document.getElementsByName("password")[0].value;
var filesl = document.getElementsByName("pictureFile")[0].files;
var files = document.getElementsByName("pictureFile")[0];
var formData = new FormData();
for(var i=0;i < filesl.length;i++){
formData.append("pictureFile",files.files[i]);
}
formData.append("username", username);
formData.append("password", password);
console.log(formData)
$.ajax({
url:"upload.action",
type:"post",
data:formData,
dataType:"json",
mimeType: "multipart/form-data",
cache:false,
processData:false,
contentType:false,
async:false,
success:function(data){
console.log(data)
}
})
至此两种方式配置结束,form表单形式更容易实现,也比较常用,推荐使用这种,希望能帮助到你!
SSM框架实现多张图片和其他数据一起上传的更多相关文章
- Jquery DataTable AJAX跨域请求的解决方法及SSM框架下服务器端返回JSON格式数据的解决方法
如题,用HBuilder开发APP,涉及到用AJAX跨域请求后台数据,刚接触,费了不少时间.幸得高手指点,得以解决. APP需要用TABLE来显示数据,因此采用了JQ 的DataTable. 在实现 ...
- 基于springboot的SSM框架实现返回easyui-tree所需要数据
1.easyui-tree easui-tree目所需要的数据结构类型如下: [ { "children": [ { "children": [], " ...
- 使用.NET框架、Web service实现Android的文件上传(二)
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAYUAAAKpCAIAAADcx6fPAAAgAElEQVR4nOydd1hT5+LHg1attbfr1t ...
- 基于python的Elasticsearch索引的建立和数据的上传
这是我的第一篇博客,还请大家多多指点 Thanks ♪(・ω・)ノ 今天我想讲一讲关于Elasticsearch的索引建立,当然提前是你已经安装部署好Elasticsearch. ok ...
- JAVA 后台SSM框架接收安卓端的json数据
最近项目上与安卓端做JSON数据交互,使用的SSM框架,刚开始的时候感觉很简单,想着不就是把安卓端的JSON数据封装为Bean类对象吗? 于是就这样写了 可是这样一直报400,百度原因是因为请求url ...
- 搭建ssm框架,可实现登录和数据展示以及增删改查
需求: 后台使用ssm(spring-springMVC-mybatis)进行整合 前台使用bootstrap框架 前后台交互使用Ajax进行发送 表结构: 登录页面后显示所有用户信息,可对每条进行增 ...
- SpringMVC框架笔记02_参数绑定返回值文件上传异常处理器JSON数据交互_拦截器
目录 第1章 高级参数的绑定 1.1 参数的分类 1.2 数组类型的参数的绑定 1.3 集合类型的参数的绑定 第2章 @RequestMapping的用法 2.1 URL路径映射 2.2 请求方法限定 ...
- [iOS AFNetworking框架实现HTTP请求、多文件图片上传下载]
简单的JSON的HTTP传输就不说了,看一个简单的DEMO吧. 主要明白parameters是所填参数,类型是字典型.我把这部分代码封装起来了,以便多次调用.也许写在一起更清楚点. #pragma m ...
- Android 利用an框架快速实现网络请求(含下载上传文件)
作者:Bgwan链接:https://zhuanlan.zhihu.com/p/22573081来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. an框架的网络框架是完全 ...
随机推荐
- Docker中搭建FastDFS文件系统(多图)
关于FastDFS FastDFS 是以 C 语言开发的一项开源轻量级分布式文件系统,他对文件进行管理,主要功能有:文件存储,文件同步,文件访问(文件上传/下载)等,特别适合以文件为载体的在线服务,如 ...
- pom文件中<dependencies>和<dependencyManagement>的区别
在父pom中,如果使用了<dependencies>标签,那么在该标签体中的所有jar包,即使子工程中没有写这些依赖,依旧会引用. 如果使用了<dependencyManagemen ...
- 《MySQL慢查询优化》之SQL语句及索引优化
1.慢查询优化方式 服务器硬件升级优化 Mysql服务器软件优化 数据库表结构优化 SQL语句及索引优化 本文重点关注于SQL语句及索引优化,关于其他优化方式以及索引原理等,请关注本人<MySQ ...
- 喜欢 Dapper 的朋友看过来,送一份厚礼
写在开头 众所周知 Dapper 是 .NET 下最轻最快的 ORM,它是喜欢写 SQL 码农的福音,相对于 SqlHelper 它更加方便,据统计 10个 .NETer 有 9个 用过 Dapper ...
- 本地web项目部署到服务器里连接不上数据库的解决办法
今天突然想到把自己之前的项目挂到服务器上,但是用到了数据库,于是给服务器装上了MySQL,想着能赶紧把项目挂上去看看效果,然后并不是一帆风顺,在奋斗了四小时后终于解决了问题的所在. (1)首先我找到了 ...
- 关于我 About Me
重庆某大学计算机专业大三学渣 CTF酱油选手 web安全菜鸡 SRC低危小子 精通多门语言 hello world 输出 和 windows linux单词拼写 扣扣:MjU4NTYxNDQ2NA== ...
- 将ACCESS 的数据库中的表的文件 导出了EXCEL格式
将ACCESS 的数据库中的表的文件 导出了EXCEL格式 '''' '将ACCESS数据库中的某个表的信息 导出为EXCEL 文件格式 'srcfName ACCESS 数据库文件路径 'desfN ...
- 深度剖析目标检测算法YOLOV4
深度剖析目标检测算法YOLOV4 目录 简述 yolo 的发展历程 介绍 yolov3 算法原理 介绍 yolov4 算法原理(相比于 yolov3,有哪些改进点) YOLOV4 源代码日志解读 yo ...
- 写了两年的一本.NET书现在终于在北京最大的新华书店上架了,然而我却很难找到工作了。
两年前,有几个出版社的编辑在QQ上跟我联系写书的事情,好奇为什么出版社会找到我这样一个很普通的.NET技术人员,其中一个编辑说他们分析了很多博客园博主的文章阅读量和写作质量,觉得我的博客还是不错的.尽 ...
- qq获取验证码接口
测试 获取验证码 import smtplib from email.mime.text import MIMEText from email.utils import formataddr #定义参 ...