form 表单提交数据和文件(fromdata的使用方法)
<!-- 数据和文件一次性提交 -->
<form class="form_meren" id="mainForm" name="mainForm" action="${ctx}/shahescenicinfo/insertShaheScenicinfo.do" method="post" enctype="multipart/form-data"> <input class="form-control " id="aname" name="aname" type="text">
<input type="file" id="otherfiles">
<input type="file" id="otherfiles2">
<button type="button" onclick="sbutripform()" >保存</button>
</form>
//验证结束后执行保存
function sbutripform(){
//form的id就是mainForm
var mainstr=formToJsonObject(mainForm);
//from表单对象 转json
mainstr=JsonToStr(mainstr);
mainstr=mainstr.replace("%", "%25");
var manstr = mainstr.toString();
var formData = new FormData();
formData.append("file1",document.getElementById("otherfiles").files[0]);
formData.append("file2",document.getElementById("otherfiles2").files[0]);
formData.append("jsonStr",manstr);
$.ajax({
url:url,
type:'POST',
dataType:'json',
data:formData,
cache: false,//上传文件无需缓存
processData: false,//用于对data参数进行序列化处理 这里必须false
contentType: false, //必须
success:function(xclyid){
window.top.customAlertTip("", "保存成功", "warning");
},
error:function (error){
window.top.customAlertTip("", "保存失败", "warning");
}
}); }
@RequestMapping(value="/updateallareainfo.do", method={RequestMethod.GET,RequestMethod.POST})
@ResponseBody
public String updateallareainfo(HttpServletRequest request,
@RequestParam(value="file1",required=false)MultipartFile file1,
@RequestParam(value="file2",required=false)MultipartFile file2,
String jsonStr) {
//把数据从json 转换为 实体类
YbsjAreaInfo ybsjAreaInfo = JSON.parseObject(jsonStr,YbsjAreaInfo.class);
try {
log.info("当前访问的action方法:updateallareainfo") ;
// uploads 文件夹位置
String rootPath = request.getSession().getServletContext().getRealPath(PropertyManager.getProperty("voiceupload"));
// uploads 文件夹2位置
String imgPath = request.getSession().getServletContext().getRealPath(PropertyManager.getProperty("filesavepath
// 原始名称
String newFileName1 = "";
String newFileName2 = "";
if (file1!=null) {
String originalFileName1 = file1.getOriginalFilename();//旧的文件名(用户上传的文件名称)
//新的文件名
newFileName1 = UUIDUtil.getuuid() + originalFileName1.substring(originalFileName1.lastIndexOf("."));
File newFile = new File(rootPath + File.separator + newFileName1);
// 判断目标文件所在目录是否存在
if( !newFile.getParentFile().exists()) {
// 如果目标文件所在的目录不存在,则创建父目录
newFile.getParentFile().mkdirs();
}
//存入
file1.transferTo(newFile);
ybsjAreaInfo.setMapUrl("/"+filesavepath+newFileName1);
}
if (file2!=null) {
String originalFileName2 = file2.getOriginalFilename();
newFileName2 = UUIDUtil.getuuid() + originalFileName2.substring(originalFileName2.lastIndexOf("."));
File newFile2 = new File(imgPath + File.separator + newFileName2);
if( !newFile2.getParentFile().exists()) {
// 如果目标文件所在的目录不存在,则创建父目录
newFile2.getParentFile().mkdirs();
}
file2.transferTo(newFile2);
ybsjAreaInfo.setAlogo("/"+filesavepath+newFileName2);
}
} catch (IllegalStateException | IOException e) {
e.printStackTrace();
}
int updateallareainfo = ybsjAreaInfoService.updateallareainfo(ybsjAreaInfo);
String shaheScenicinfoid="{\"id\":\""+updateallareainfo+"\"}";
return shaheScenicinfoid;
}
以上是 单个文件 接收的方法
如果用到一个Input 上传多个文件
后台用
@RequestParam("files") MultipartFile[] files
接收就好了
form 表单提交数据和文件(fromdata的使用方法)的更多相关文章
- Linux curl 模拟form表单提交信息和文件
Linux curl 模拟form表单提交信息和文件 curl是一个命令行方式下传输数据的开源传输工具,支持多种协议:FTP.HTTP.HTTPS.IMAP.POP3.TELNET等,功能超级强大 ...
- thinkPHP5.0使用form表单提交数据和删除文章,不用TP的提示页面,使用弹出提示信息
form表单提交数据和删除文章时,TP的默认信息提示页面的看起来不是很好看,想要实现弹窗提示怎么做呢? 前端:可以使用前端的一个知识--iframe,iframe元素会创建包含另外一个文档的内联框架: ...
- js模拟form表单提交数据, js模拟a标签点击跳转,避开使用window.open引起来的浏览器阻止问题
js模拟form表单提交数据, js模拟a标签点击跳转,避开使用window.open引起来的浏览器阻止问题 js模拟form表单提交数据源码: /** * js模拟form表单提交 * @param ...
- springboot框架中集成thymeleaf引擎,使用form表单提交数据,debug结果后台获取不到数据
springboot框架中集成thymeleaf引擎,使用form表单提交数据,debug结果后台获取不到数据 表单html: <form class="form-horizontal ...
- Java后台使用httpclient入门HttpPost请求(form表单提交,File文件上传和传输Json数据)
一.HttpClient 简介 HttpClient 是 Apache Jakarta Common 下的子项目,用来提供高效的.最新的.功能丰富的支持 HTTP 协议的客户端编程工具包,并且它支持 ...
- js_ajax模拟form表单提交_多文件上传_支持单个删除
需求场景: 用一个input type="file"按钮上传多张图片,可多次上传,可单独删除,最后使用ajax模拟form表单提交功能提交到指定方法中: 问题:由于只有一个file ...
- form表单提交数据的数据格式
form表单提交的数据格式默认是 enctype="application/x-www-form-urlencoded"这样将input框的数据与input框的name属性以键值对 ...
- Form表单提交数据的几种方式
一.submit提交 在form标签中添加Action(提交的地址)和method(post),且有一个submit按钮(<input type='submit'>)就可以进行数据的提交, ...
- 关于AJAX与form表单提交数据的格式
一 form表单传输文件的格式: 只有三种: multipart/form-data 一般用于传输文件,图片文件或者其他的. 那么其中我们默认的是application/x-www-form-urle ...
随机推荐
- Java Fibonacci 斐波那契亚
Java Fibonacci 斐波那契亚 /** * <html> * <body> * <P> Copyright 1994-2018 JasonInternat ...
- WebSocket协议探究(三):MQTT子协议
一 复习和目标 1 复习 Nodejs实现WebSocket服务器 Netty实现WebSocket服务器(附带了源码分析) Js api实现WebSocket客户端 注:Nodejs使用的Socke ...
- What's new in C# 7.0
1.数字分隔符(Digit Separators ) 数字分隔符使代码更具可读性.在声明变量时,可以将_添加到单独的数字中.编译器只删除_.以下代码片段在C#7中看起来更具可读性: In C# 6 l ...
- ZROI17普及23-B星空题解--图的灵活转化
题目链接 版权原因不予提供 分析 这题思路很妙啊,虽然已经算半个套路题(因为我太菜了) 将框视为点,若一个球能放在\(x\)或\(y\)框,则\(x,y\)连一条无向边.有一条非常显然的性质是:在联通 ...
- my SO 链接opencv静态库一些FUCKing的笔记 opencv410 有毒
1. 2. CMake "/work/lib/opencv/ubuntu14/4.1.0" make[2]: *** No rule to make target `/usr/lo ...
- vue学习(4)-组件的创建,父子组件传值,$refs
模块化:代码逻辑 组件化:UI 组件的创建:1.
- string+DFS leetcode-17.电话号码下的字母组合
题面 Given a string containing digits from 2-9 inclusive, return all possible letter combinations that ...
- Axure工作区间
Axure的工作环境可进行可视化拖拉操作,可轻松快速的创建带有注释的线框图.无需编程就可以在线框图中定义简单链接和高级交互.Axure可一体化生成线框图.HTML交互原型.规格说明Word文档.以下是 ...
- 自定义flask转换器
自定义flask转换器 以匹配手机号为例: # 1. 定义自己的转换器 class MobileConverter(BaseConverter): def __init__(self, url_map ...
- flex布局实战
1.实现盒子的水平垂直居中 .parent{ width:200px; height:200px; display:flex; align-items: center; justify-content ...