inputmultiple选择多张图片时,需要删除其中的一张图片怎么做,大家都知道 input 中的文件是不能删除和更改的,只能清空,这里我的做法是 定义一个对象储存器把需要的文件存在储存器中 formData,后台不从Input中读取,从对象存储器中获取文件,一组图片使用一个储存器中formData,存储器中的 key 我们用文件名Input的ID 拼接,而后取出图片的key 也用Input的ID;删除图片也是同一个key; 上传所有的图片时,用ajax 需要异步操作与后台交互,后台根据 key 获取所有图片,图片最终保存在阿里oss对象储存服务器上,数据库写入图片上传后返回的URL地址;

ajaxasync: false同步后,(确认框)无法关闭用户会误认为程序卡死状态】,确认框需要等待所有的ajax代码依次执行结束才会关闭,所以这里需要把ajax改为异步,自己通过其它技术实现同步,用户点确认按钮后确认框会马上关闭

【 

ajax同步技术:

1、  var someAjaxDfd = $.Deferred();

2、var its_promise = $.when(someAjaxDfd);

3、 someAjaxDfd.resolve();   放对应的ajax 执行结束的代码中

4、its_promise.done(function () {
【对应的ajax执行结束后会执行这里面的代码】
});

ajax 同步图:

someAjaxDfd.resolve();   放对应的ajax 执行结束的代码中;

效果:

添加图片:

删除其中一张图片:

 

重复图片提示:

单图片预览:

确认框:

(ajax 如不做异步,这个框点击确认后会一直存在直到ajax都执行完毕,用户点击后会误认为程序卡死)

上传图片组件样式:

D:\Project\lvmsm\src\main\webapp\assets\upjs\css\index.css

<link href="/assets/upjs/css/index.css" type="text/css" rel="stylesheet"/>

/*上传图片插件的样式*/
.img-box{margin-top: 40px;
}
.img-box .up-p{margin-bottom: 20px;font-size: 16px;color: #555;
}
.z_photo{padding: 18px;border:2px dashed #E7E6E6;/*padding: 18px;*/
}
.z_photo .z_file{position: relative;
}
.z_file  .file{width: 100%;height: 100%;opacity: 0;position: absolute;top: 0px;left: 0px;z-index: 100;
}
.z_photo .up-section{position: relative;margin-right: 20px;margin-bottom: 20px;
}
.up-section .close-upimg{position: absolute;top: 6px;right: 8px;display: none;z-index: 10;
}
.up-section .up-span{/*display: block;*/width: 100%;height: 100%;visibility: hidden;position: absolute;top: 0px;left: 0px;z-index: 9;background: rgba(0,0,0,.5);
}
.up-section:hover{border: 2px solid #f15134;
}
.up-section:hover .close-upimg{display: block;
}
.up-section:hover .up-span{/*选择中图片变黑*//*visibility: visible;*/
}
.z_photo .up-img{display: block;width: 100%;height: 100%;
}
.loading{border: 1px solid #D1D1D1;background:url(../img/loading.gif) no-repeat center;
}
.up-opcity{opacity: 0;
}
.img-name-p{display: none;
}
.upimg-div .up-section {width: 190px;height: 180px;
}
.img-box .upimg-div .z_file {width: 190px;height: 180px;
}
.z_file .add-img {display: block;width: 190px;height: 180px;
}
/*遮罩层样式*/
.mask{z-index: 1000;display: none;position: fixed;top: 0px;left: 0px;width: 100%;height: 100%;background: rgba(0,0,0,.4);
}
.mask .mask-content{width: 500px;position: absolute;top: 50%;left: 50%;margin-left: -250px;margin-top: -80px;background: white;height: 160px;text-align: center;
}
.mask .mask-content .del-p{color: #555;height: 94px;line-height: 94px;font-size: 18px;border-bottom: 1px solid #D1D1D1;
}
.mask-content .check-p{height: 66px;line-height: 66px;position: absolute;bottom: 0px;left: 0px;width: 100%;
}
.mask-content .check-p span{width: 49%;display:inline-block;text-align: center;color:#d4361d ;font-size: 18px;
}
.check-p .del-com{border-right: 1px solid #D1D1D1;
}
<link href="/assets/upjs/css/common.css" type="text/css" rel="stylesheet"/>
* {box-sizing: border-box;-moz-box-sizing: border-box;/* Firefox */-webkit-box-sizing: border-box;/* Safari */
}
.up-section .type-upimg{display: none;
}
::-ms-clear,::-ms-reveal{display:none;}
textarea{outline: none;line-height: 14px;padding-left: 4px;padding-top: 4px;border: 1px solid #ccc;color: #444;font-size: 14px;outline: none;text-align: left;
}
.overflow{overflow: hidden;text-overflow: ellipsis;white-space: nowrap;
}
button{outline: none;border: 0px;font-family: "微软雅黑", "PingFang SC", "arial, helvetica, sans-serif";
}
input{font-family: "微软雅黑", "PingFang SC", "arial, helvetica, sans-serif";outline: none;
}
a {outline: none;
}
a,button{cursor:pointer;} /*body {background: #f4f4f4;font-size: 14px;font-family: "微软雅黑", "PingFang SC", "arial, helvetica, sans-serif";
}*/
.clear {clear: both;
}
.full{width: 1210px;min-width: 1210px;margin: 0 auto;
}
.full-big{width: 1340px;min-width: 1340px;margin: 0 auto;
}
.img-full{display: block;width: 100%;
}
::-webkit-input-placeholder {color: #777;font-size: 14px;
}
:-moz-placeholder {/* Firefox 18- */color: #777;font-size: 14px;
}
::-moz-placeholder {/* Firefox 19+ */color: #777;font-size: 14px;
}
:-ms-input-placeholder {color:#777;font-size: 14px;
}
/* ====clear float====== */
/*nav a:visited{color: rgb(65,65,65);}
aside a:visited{color: rgb(65,65,65);}*/
.fl {float: left;
}
.fr {float: right;
}
.clear:after {content: '';display: block;clear: both;
}
/* reset */
.pic img{display: none;}
i,
p,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
br,
em,
dl,
dd,
li,
ul,
ol,
td,
th,
pre,
form,
body,
input,
strong,
textarea,
select,figcaption,figure{margin: 0;padding: 0;
}
em {font-style: normal
}
li {list-style: none
}
a {text-decoration: none;
}
img {border: none;}
table {border-collapse: collapse;
}
textarea {resize: none;overflow: auto;
}
a,button{cursor:pointer;} 

图片增删 与后台交互js:

assets/js/gm/add-GasCylinderCheckInfoAjaxfileupload.js

/*===========================================主页证书查看===================================================*/
$(document).ready(function() {});
//多图片查看
function showImg(urls) {var  url = "";if(null != urls && 0 < urls.length) {$("#showImg").val(urls);var url = urls.split(',');}if(null != url && url != ""){popWin.showWin("1300","590","查看证书",url);}else{DJMask.msg("未获取到数据请检查!");}}//单图片查看
function showImgD(url) {if(null != url && url != ""){popWinD.showWin("600","590","查看证书",url);}else{DJMask.msg("未获取到数据请检查!");}}
/*function ass() {popWin.showWin("800","600","通用的iframe弹层插件","http://www.jq22.com");
}*/
/*-------------------------------------------------上传图片,图片显示js,控制5张图片------------------------------------------------------------------------*/
//取数据
/*产品合格证*/
/*对应图片上传input的ID*/
var fu1="productqualifyurlFile1";
/*图片储存器*/
var formData = new FormData();
var formData1 = new FormData();/*(质量证明书)*/
/*对应图片上传input的ID*/
var fuA="qualitycertificateurlFile2";
/*图片储存器*/
var formDataA = new FormData();
var formDataA1 = new FormData();/*(使用说明书)*/
/*对应图片上传input的ID*/
var fuB="instructionmanualurlFile2";
/*图片储存器*/
var formDataB = new FormData();
var formDataB1 = new FormData();/*(检验报告)*/
/*对应图片上传input的ID*/
var fuC="inspectereporturlFile2"
/*图片储存器*/
var formDataC = new FormData();
var formDataC1 = new FormData();/*(日常检验记录)*/
/*对应图片上传input的ID*/
var fuD="dailyinspectrecordurlFile2";
/*图片储存器*/
var formDataD = new FormData();
var formDataD1 = new FormData();$(function () {var delParent;var idFile;var defaults = {fileType: ["jpg", "png", "bmp", "jpeg", "JPG","PNG"],   // 上传文件的类型fileSize: 1024 * 1024 * 10                  // 上传文件的大小 10M};/*点击图片的文本框*/$("table").delegate(".file", "change", function () {/*获取对应图片上传input的ID*/idFile = $(this).attr("id")+"";/*获取对应图片集*/var file = document.getElementById(idFile);var imgContainer = $(this).parents(".z_photo"); //存放图片的父亲元素var fileList = file.files; //获取的图片文件console.log(fileList + "======filelist=====");var input = $(this).parent();//文本框的父亲元素var imgArr = [];//遍历得到的图片文件var numUp = imgContainer.find(".up-section").length;var totalNum = numUp + fileList.length;  //总的数量if (fileList.length > 5 || totalNum > 5) {//一次选择上传超过5个 或者是已经上传和这次上传的到的总数也不可以超过5个DJMask.msg("上传图片数目不可以超过5个,请重新选择!");}else if (numUp < 5) {fileList = validateUp(fileList);for (var i = 0; i < fileList.length; i++) {var imgUrl = window.URL.createObjectURL(fileList[i]);imgArr.push(imgUrl);var $section = $("<section class='up-section fl loading'>");imgContainer.prepend($section);var $span = $("<span class='up-span'>");$span.appendTo($section);/*   删除图片*/var $img0 = $("<img class='close-upimg'>").on("click", function (event) {event.preventDefault();event.stopPropagation();$(".works-mask").show();delParent = $(this).parent();var numUp = delParent.siblings().length;if (numUp < 6) {delParent.parent().find(".z_file").show();}/* 获取删除图片的图片名*/  var fileName =$(this).parent().children(".img-name-p").text();/* 获取删除图片的input的ID*/  var idFile1 = $(this).parent(). nextAll(".z_file").children(".file").attr("id")+"";/* 判断删除图片的input的ID是哪一组图片,对应操作对应的图片储存器!*/          if(idFile1 == fu1){formData.delete((fileName+idFile1));formData.delete(idFile1);formData1.delete(idFile1);var i = formData.entries();while(item = i.next()){if(item.done) break;//因为对象里存储多个类型的图片,需要区分图片单独增删if(item.value[0] != idFile1){//将需要的图片中转一下,直接放formData这个里可能会死循序formData1.append(idFile1,item.value[1]);}}//遍历中转存储器formDataA中的图片var y = formData1.entries();while(item1 = y.next()){if(item1.done) break;//加入formData存储器中,key为input的IDformData.append(idFile1,item1.value[1]);}delParent.remove();}else if(idFile1 == fuA){formDataA.delete((fileName+idFile1));formDataA.delete(idFile1);formDataA1.delete(idFile1);var i = formDataA.entries();while(item = i.next()){if(item.done) break;//因为对象里存储多个类型的图片,需要区分图片单独增删if(item.value[0] != idFile1){//将需要的图片中转一下,直接放formDataA这个里可能会死循序formDataA1.append(idFile1,item.value[1]);}}var y = formDataA1.entries();while(item1 = y.next()){if(item1.done) break;formDataA.append(idFile1,item1.value[1]);}delParent.remove();}else if(idFile1 == fuB){formDataB.delete((fileName+idFile1));formDataB.delete(idFile1);formDataB1.delete(idFile1);var i = formDataB.entries();while(item = i.next()){if(item.done) break;//因为对象里存储多个类型的图片,需要区分图片单独增删if(item.value[0] != idFile1){formDataB1.append(idFile1,item.value[1]);}}var y = formDataB1.entries();while(item1 = y.next()){if(item1.done) break;formDataB.append(idFile1,item1.value[1]);}delParent.remove();}else if(idFile1 == fuC){formDataC.delete((fileName+idFile1));formDataC.delete(idFile1);formDataC1.delete(idFile1);var i = formDataC.entries();while(item = i.next()){if(item.done) break;//因为对象里存储多个类型的图片,需要区分图片单独增删if((item.value[0]+"") != idFile1){formDataC1.append(idFile1,item.value[1]);}}var y = formDataC1.entries();while(item1 = y.next()){if(item1.done) break;formDataC.append(idFile1,item1.value[1]);}delParent.remove();}else if(idFile1 == fuD){formDataD.delete((fileName+idFile1));formDataD.delete(idFile1);formDataD1.delete(idFile1);var i = formDataD.entries();while(item = i.next()){if(item.done) break;//因为对象里存储多个类型的图片,需要区分图片单独增删if((item.value[0]+"") != idFile1){formDataD1.append(idFile1,item.value[1]);}}var y = formDataD1.entries();while(item1 = y.next()){if(item1.done) break;formDataD.append(idFile1,item1.value[1]);}delParent.remove();}});/*删除图片按钮*/$img0.attr({"src":"/assets//upjs/img/a7.png"}).appendTo($section);/*单张图片预览*/var $img = $("<a href=\"javascript:showImgD('"+imgArr[i]+"')\"><img class='up-img up-opcity' src='"+imgArr[i]+"'></a>");/*var $img = $("<img class='up-img up-opcity' >");*/$img.attr("src", imgArr[i]);$img.appendTo($section);var $p = $("<p class='img-name-p'>");$p.html(fileList[i].name).appendTo($section);var $input = $("<input id='taglocation' name='taglocation' value='' type='hidden'>");$input.appendTo($section);var $input2 = $("<input id='tags' name='tags' value='' type='hidden'/>");$input2.appendTo($section);}}setTimeout(function () {$(".up-section").removeClass("loading");$(".up-img").removeClass("up-opcity");}, 450);numUp = imgContainer.find(".up-section").length;if (numUp >= 5) {$(this).parent().hide();}});$(".z_photo").delegate(".close-upimg", "click", function () {$(".works-mask").show();delParent = $(this).parent();});$(".wsdel-ok").click(function () {$(".works-mask").hide();var numUp = delParent.siblings().length;if (numUp < 6) {delParent.parent().find(".z_file").show();}delParent.remove();});$(".wsdel-no").click(function () {$(".works-mask").hide();});function validateUp(files) {var arrFiles = [];//替换的文件数组for (var i = 0, file; file = files[i]; i++) {//获取文件上传的后缀名var newStr = file.name.split("").reverse().join("");if (newStr.split(".")[0] != null) {var type = newStr.split(".")[0].split("").reverse().join("");console.log(type + "===type===");if (jQuery.inArray(type, defaults.fileType) > -1) {// 类型符合,可以上传if (file.size >= defaults.fileSize) {DJMask.msg(file.size);DJMask.msg('您这个"' + file.name + '"文件大小过大');} else {// 在这里需要判断当前所有文件中//判断 增加的图片是哪个input 的ID,把图片加入对应的图片储存器中if(idFile == fu1){//判断 图片储存器中是否已存在该图片,如果存在就不加入,并给与提示;if( !formData.has((file.name+idFile))) {formData.append((file.name + idFile), file);formData.append(idFile, file);arrFiles.push(file);}else{DJMask.msg("文件不能重复上传!");}}else if(idFile == fuA){if( !formDataA.has((file.name+idFile))) {formDataA.append((file.name + idFile), file);formDataA.append(idFile, file);arrFiles.push(file);}else{DJMask.msg("文件不能重复上传!");}}else if(idFile == fuB){if( !formDataB.has((file.name+idFile))) {formDataB.append((file.name + idFile), file);formDataB.append(idFile, file);arrFiles.push(file);}else{DJMask.msg("文件不能重复上传!");}}else if(idFile == fuC){if( !formDataC.has((file.name+idFile))) {formDataC.append((file.name+idFile),file);formDataC.append(idFile,file);arrFiles.push(file);}else{DJMask.msg("文件不能重复上传!");}}else if(idFile == fuD){if( !formDataD.has((file.name+idFile))) {formDataD.append((file.name+idFile),file);formDataD.append(idFile,file);arrFiles.push(file);}else{DJMask.msg("文件不能重复上传!");}}}} else {DJMask.msg('您这个"' + file.name + '"上传类型不符合');}} else {DJMask.msg('您这个"' + file.name + '"没有类型, 无法识别');}}return arrFiles;}})/*================================================实现数据库图片上传==================================================================*//*产品合格证*/
function ProductqualifyurlFileUpload(someAjaxDfd) {/*产品合格证*/$.ajax({url: "/config/create-AllGasCylinderCheckInfoFileurlFileUpload",type: "POST",dataType: 'json',processData: false,contentType: false,data: formData,/*async: false,*/success: function(data){if (data.resultCode == 200) {$("#productqualifyurl").val(data.fieldString);}if (data.resultCode == 505) {DJMask.msg("请图片上传失败");}someAjaxDfd.resolve();},error: function () {}});}/*质量证书*/function qualitycertificateurlFileUpload(ajax1Dfd) {/*质量证书*/$.ajax({url: "/config/create-AllGasCylinderCheckInfoQualitycertificateurlFileUpload",type: "POST",dataType: 'json',processData: false,contentType: false,data: formDataA,/*async: false,*/success: function(data){if (data.resultCode == 200) {$("#qualitycertificateurl").val(data.fieldString);}if(data.resultCode == 505){DJMask.msg("请图片上传失败");}ajax1Dfd.resolve();},error: function () {}});}/* 使用说明书*/
function instructionmanualurlFileUpload(ajax3Dfd) {$.ajax({url: "/config/create-AllGasCylinderCheckInfoInstructionmanualurlUpload",type: "POST",dataType: 'json',processData: false,contentType: false,data: formDataB,/*async: false,*/success: function(data){if (data.resultCode == 200) {$("#instructionmanualurl").val(data.fieldString);}if(data.resultCode == 505){DJMask.msg("请图片上传失败");}ajax3Dfd.resolve();},error: function () {}});}
/* 检验报告*/
function InspectereporturlUpload(ajax4Dfd) {/*===================================== */$.ajax({url: "/config/create-AllGasCylinderCheckInspectereporturlUpload",type: "POST",dataType: 'json',processData: false,contentType: false,data: formDataC,/* async: false,*/success: function(data){if (data.resultCode == 200) {$("#inspectereporturl").val(data.fieldString);}if(data.resultCode == 505){DJMask.msg("请图片上传失败");}ajax4Dfd.resolve();},error: function () {}});}
/*  日常检验记录*/
function DailyinspectrecordurlUpload(ajax5Dfd) {$.ajax({url: "/config/create-AllGasCylinderCheckDailyinspectrecordurlUpload",type: "POST",dataType: 'json',processData: false,contentType: false,data: formDataD,/*async: false,*/success: function(data){if (data.resultCode == 200) {$("#dailyinspectrecordurl").val(data.fieldString);}if(data.resultCode == 505){DJMask.msg("请图片上传失败");}ajax5Dfd.resolve();},error: function () {}});}/*==================================上传图片(产品合格证url)=主页上传图片,更新数据库============================================================*/
function productqualifyurlUploadImage1(id, i) {var ajax1Dfd = $.Deferred();var its_promise = $.when(ajax1Dfd);$("#gasCylinderCheckInfoId").val(id);var files = document.getElementById("productqualifyurlFile" + i + "").files;var f = document.getElementById("productqualifyurlFile" + i + "").value;if ((files.length-0) == 0) {DJMask.msg("请上传图片");return false;}else if( 5 < (files.length-0)  ){DJMask.msg("图片不能超过5张!");return false;} else {if (f != null && !/\.(|jpg|jpeg|png|JPG|PNG)$/.test(f)) {DJMask.msg("图片类型必须是.jpeg,jpg,png中的一种");return false;}}DJMask.msg("请稍等正在处理!");$.ajaxFileUpload({url: "/config/add-GasCylinderCheckInfoProductqualifyurlUpload1?gasCylinderCheckInfoId=" + id + "&ii=" + i,/*data: {'id': id},*/fileElementId: 'productqualifyurlFile' + i,dataType: "json",success: function (data) {if (200 == data.resultCode) {setTimeout(function(){DJMask.msg(data.failDesc);},1500);setTimeout(function(){ajax1Dfd.resolve();},3000);its_promise.done(function(){getAllpage();});} else {setTimeout(function(){DJMask.msg(data.failDesc);},1500);DJMask.msg(data.failDesc);setTimeout(function(){ajax1Dfd.resolve();},3000);its_promise.done(function(){getAllpage();});}}});}
/*==================================上传图片(质量证明书url)=主页上传图片,更新数据库============================================================*/
function qualitycertificateurlUploadImage1(id, i) {var ajax1Dfd = $.Deferred();var its_promise = $.when(ajax1Dfd);$("#gasCylinderCheckInfoId").val(id);var files = document.getElementById("qualitycertificateurlFile" + i + "").files;var f = document.getElementById("qualitycertificateurlFile" + i + "").value;if ((files.length-0) == 0) {DJMask.msg("请上传图片");return false;}else if( 5 < (files.length-0)  ){DJMask.msg("图片不能超过5张!");return false;} else {if (f != null && !/\.(|jpg|jpeg|png|JPG|PNG)$/.test(f)) {DJMask.msg("图片类型必须是.jpeg,jpg,png中的一种");return false;}}DJMask.msg("请稍等正在处理!");$.ajaxFileUpload({url: "/config/add-GasCylinderCheckInfoQualitycertificateurlUpload1?gasCylinderCheckInfoId=" + id + "&ii=" + i,/*data: {'id': id},*/fileElementId: 'qualitycertificateurlFile' + i,dataType: "json",success: function (data) {if (200 == data.resultCode) {setTimeout(function(){DJMask.msg(data.failDesc);},1500);setTimeout(function(){ajax1Dfd.resolve();},3000);its_promise.done(function(){getAllpage();});} else {setTimeout(function(){DJMask.msg(data.failDesc);},1500);DJMask.msg(data.failDesc);setTimeout(function(){ajax1Dfd.resolve();},3000);its_promise.done(function(){getAllpage();});}}});}
/*==================================上传图片(质量说明书)=主页上传图片,更新数据库============================================================*/
function qualityspecifyurlUploadImage1(id, i) {var ajax1Dfd = $.Deferred();var its_promise = $.when(ajax1Dfd);$("#gasCylinderCheckInfoId").val(id);var files = document.getElementById("qualityspecifyurlFile" + i + "").files;var f = document.getElementById("qualityspecifyurlFile" + i + "").value;if ((files.length-0) == 0) {DJMask.msg("请上传图片");return false;}else if( 5 < (files.length-0)  ){DJMask.msg("图片不能超过5张!");return false;} else {if (f != null && !/\.(|jpg|jpeg|png|JPG|PNG)$/.test(f)) {DJMask.msg("图片类型必须是.jpeg,jpg,png中的一种");return false;}}DJMask.msg("请稍等正在处理!");$.ajaxFileUpload({url: "/config/add-GasCylinderCheckInfoQualityspecifyurlUpload1?gasCylinderCheckInfoId=" + id + "&ii=" + i,/*data: {'id': id},*/fileElementId: 'qualityspecifyurlFile' + i,dataType: "json",success: function (data) {if (200 == data.resultCode) {setTimeout(function(){DJMask.msg(data.failDesc);},1500);setTimeout(function(){ajax1Dfd.resolve();},3000);its_promise.done(function(){getAllpage();});} else {setTimeout(function(){DJMask.msg(data.failDesc);},1500);DJMask.msg(data.failDesc);setTimeout(function(){ajax1Dfd.resolve();},3000);its_promise.done(function(){getAllpage();});}}});}
/*==================================上传图片(使用说明书url)=主页上传图片,更新数据库============================================================*/
function instructionmanualurlUploadImage1(id, i) {var ajax1Dfd = $.Deferred();var its_promise = $.when(ajax1Dfd);$("#gasCylinderCheckInfoId").val(id);var files = document.getElementById("instructionmanualurlFile" + i + "").files;var f = document.getElementById("instructionmanualurlFile" + i + "").value;if ((files.length-0) == 0) {DJMask.msg("请上传图片");return false;}else if( 5 < (files.length-0)  ){DJMask.msg("图片不能超过5张!");return false;} else {if (f != null && !/\.(|jpg|jpeg|png|JPG|PNG)$/.test(f)) {DJMask.msg("图片类型必须是.jpeg,jpg,png中的一种");return false;}}DJMask.msg("请稍等正在处理!");$.ajaxFileUpload({url: "/config/add-GasCylinderCheckInfoInstructionmanualurlUpload1?gasCylinderCheckInfoId=" + id + "&ii=" + i,/*data: {'id': id},*/fileElementId: 'instructionmanualurlFile' + i,dataType: "json",success: function (data) {if (200 == data.resultCode) {setTimeout(function(){DJMask.msg(data.failDesc);},1500);setTimeout(function(){ajax1Dfd.resolve();},3000);its_promise.done(function(){getAllpage();});} else {setTimeout(function(){DJMask.msg(data.failDesc);},1500);DJMask.msg(data.failDesc);setTimeout(function(){ajax1Dfd.resolve();},3000);its_promise.done(function(){getAllpage();});}}});}/*==================================================================================================================================================*//*==================================上传图片(检验报告)=主页上传图片,更新数据库============================================================*/function inspectereporturlUploadImage1(id, i) {var ajax1Dfd = $.Deferred();var its_promise = $.when(ajax1Dfd);$("#gasCylinderCheckInfoId").val(id);var files = document.getElementById("inspectereporturlFile" + i + "").files;var f = document.getElementById("inspectereporturlFile" + i + "").value;if ((files.length-0) == 0) {DJMask.msg("请上传图片");return false;}else if( 5 < (files.length-0)  ){DJMask.msg("图片不能超过5张!");return false;} else {if (f != null && !/\.(|jpg|jpeg|png|JPG|PNG)$/.test(f)) {DJMask.msg("图片类型必须是.jpeg,jpg,png中的一种");return false;}}DJMask.msg("请稍等正在处理!");$.ajaxFileUpload({url: "/config/add-GasCylinderCheckInfoInspectereporturlUpload1?gasCylinderCheckInfoId=" + id + "&ii=" + i,/*data: {'id': id},*/fileElementId: 'inspectereporturlFile' + i,dataType: "json",success: function (data) {if (200 == data.resultCode) {setTimeout(function(){DJMask.msg(data.failDesc);},1500);setTimeout(function(){ajax1Dfd.resolve();},3000);its_promise.done(function(){getAllpage();});} else {setTimeout(function(){DJMask.msg(data.failDesc);},1500);DJMask.msg(data.failDesc);setTimeout(function(){ajax1Dfd.resolve();},3000);its_promise.done(function(){getAllpage();});}}});}/*==================================上传图片(日常检验记录)主页上传图片,更新数据库=============================================================*/
function dailyinspectrecordurlUploadImage1(id, i) {var ajax1Dfd = $.Deferred();var its_promise = $.when(ajax1Dfd);$("#gasCylinderCheckInfoId").val(id);var files = document.getElementById("dailyinspectrecordurlFile" + i + "").files;var f = document.getElementById("dailyinspectrecordurlFile" + i + "").value;if ((files.length-0) == 0) {DJMask.msg("请上传图片");return false;}else if(5 < (files.length-0) ){DJMask.msg("图片不能超过5张!");return false;} else {if (f != null && !/\.(|jpg|jpeg|png|JPG|PNG)$/.test(f)) {DJMask.msg("图片类型必须是.jpeg,jpg,png中的一种");return false;}}/*    var id = $("#id").val();*/DJMask.msg("请稍等正在处理!");$.ajaxFileUpload({url: "/config/add-GasCylinderCheckInfoDailyinspectrecordurlFileUpload1?gasCylinderCheckInfoId=" + id + "&ii=" + i,/*data: {'id': id},*/fileElementId: 'dailyinspectrecordurlFile' + i,dataType: "json",success: function (data) {if (200 == data.resultCode) {setTimeout(function(){DJMask.msg(data.failDesc);},1500);setTimeout(function(){ajax1Dfd.resolve();},3000);its_promise.done(function(){getAllpage();});} else {DJMask.msg(data.failDesc);setTimeout(function(){DJMask.msg(data.failDesc);},1500);setTimeout(function(){ajax1Dfd.resolve();},3000);its_promise.done(function(){getAllpage();});}/*    $("#certificateURL5").attr("src", data);$("#dailyinspectrecordurl").val(data);*//* var data2 = data.split("?");*//*       $("#loading").toggle();*/}});
}

 直接把 formData 赋值个ajax的data,后台后根据key 名接收;

 

后台用 CommonsMultipartFile集合对应传过来的名字来接收数据;

图片增加删除页面与用户交互 js 操作:

assets/js/gm/air_parameter_add.js


/*=====================菜单定位=========================*/$(".c-nav .ed").find("li").eq(1).addClass("cur")
$(".c-nav .ed").find("li").eq(1).find(".abx").eq(8).addClass("cur")/*=================日期=============================*/
//日期常规用法
laydate.render({elem: '#testdate'
});/*=============================气瓶id查询,查询气瓶位置编号======================================*/
/*function SelsceGasCylinderpositionnum() {/!*下拉选择气瓶编号时,从value获取气瓶id*!/var gasCylinderId = $("#num").val();$.ajax({type: 'post',dataType: "json",/!*contentType: "application/json; charset=utf-8",*!/url: "/config/showAdd-GasCylinderCheckInfoTwo",data: {"gasCylinderId": gasCylinderId},success: function (data) {if (data.resultCode == 200) {if (0 < data.list.length) {$("#positionnum").val(data.list[0].positionnum);$("#GasCylinderNum").val(data.list[0].num);} else {DJMask.msg("无气瓶数据");}}if (data.resultCode == 505) {$("#messageValue").val(data.failDesc);$("#btn3").click();}}, error: function () {$("#messageValue").val("获取车牌异常!");$("#btn3").click();}});}*//*=============================气瓶编号查询气瓶位置编号和车牌号======================================*/
$(function () {SelsceGasCylinderpositionnum1();
});
function SelsceGasCylinderpositionnum1() {//先清除所有$("#cph").val("");$("#positionnum").val("");$("#num").val("");$("#GasCylinderNum").val("");/*(产品合格证)*/$("#certificateURL1").attr("src", "");$("#productqualifyurl").val("");/*(质量说明书qualityspecifyurl)*/$("#certificateURL").attr("src", "");$("#manufacturingsupervisioninsurl").val("");/*(质量证明书)*/$("#certificateURL2").attr("src", "");$("#qualitycertificateurl").val("");/*(使用说明书)*/$("#certificateURL6").attr("src", "");$("#instructionmanualurl").val("");/*(检验报告)*/$("#certificateURL4").attr("src", "");$("#inspectereporturl").val("");/*(日常检验记录)*/$("#certificateURL5").attr("src", "");$("#dailyinspectrecordurl").val("");$("#gasCylinderCheckInfoId").val("");/*(产品合格证)*/$("#productqualifyurldurlHtml").html("");/*(质量证书)*/$("#qualitycertificateurlHtml").html("");/*(质量说明书)*/$("#manufacturingsupervisioninsurlHtml").html("");/*(使用说明书)*/$("#instructionmanualurlHtml").html("");/*(检验报告)*/$("#inspectereporturldurlHtml").html("");/*(日常检验记录)*/$("#dailyinspectrecordurlHtml").html("");var loadingX = $("#loadingX").val();var num = $("#num1").val();if (null == num || 0 == num.length) {DJMask.msg("请输入气瓶编号!");return;}$.ajax({type: 'post',dataType: "json",/*contentType: "application/json; charset=utf-8",*/url: "/config/SelsceGasCylinderpositionnum1",data: {"num": num},success: function (data) {if (data.resultCode == 200) {if (0 < data.list.length) {$("#cph").val(data.list[0].vehicle.cph);$("#positionnum").val(data.list[0].gasCylinder.positionnum);$("#num").val(data.list[0].gasCylinder.id);$("#GasCylinderNum").val(data.list[0].gasCylinder.num);if (null != data.list[0].gasCylinderCheckInfo) {/*原产品合格证*/if (null != data.list[0].gasCylinderCheckInfo.productqualifyurl && 0 <  data.list[0].gasCylinderCheckInfo.productqualifyurl.length) {$("#productqualifyurl").val(data.list[0].gasCylinderCheckInfo.productqualifyurl);}/*原质量证书*/if (null != data.list[0].gasCylinderCheckInfo.qualitycertificateurl && 0 <  data.list[0].gasCylinderCheckInfo.qualitycertificateurl.length) {$("#qualitycertificateurl").val(data.list[0].gasCylinderCheckInfo.qualitycertificateurl);}/*原质量说明书*//*  if (null != data.list[0].gasCylinderCheckInfo.qualityspecifyurl && 0 < data.list[0].gasCylinderCheckInfo.qualityspecifyurl.length) {$("#manufacturingsupervisioninsurl").val(data.list[0].gasCylinderCheckInfo.qualityspecifyurl);}*//*原使用说明书*/if (null != data.list[0].gasCylinderCheckInfo.instructionmanualurl && 0 < data.list[0].gasCylinderCheckInfo.instructionmanualurl.length) {$("#instructionmanualurl").val(data.list[0].gasCylinderCheckInfo.instructionmanualurl);}}/*产品合格证*/td1 ="<div class=\"img-box full\">" +"<section class=\" img-section\">" +" <p class=\"up-p\">产品合格证:<span class=\"up-span\">最多可以上传5张图片</span></p>" +"<div class=\"z_photo upimg-div clear\" >" +"<section class=\"z_file fl\">" +"<img src=\"/assets/upjs/img/a11.png\" class=\"add-img\">" +"<input type=\"file\" name=\"file\" id=\"productqualifyurlFile1\" class=\"file\" value=\"\" accept=\"image/jpg,image/jpeg,image/png,image/bmp\" multiple />" +"</section>" +"</div>" +"</section>" +"</div>";/*(质量证明书)*/td2 ="<div class=\"img-box full\">" +"<section class=\" img-section\">" +"<p class=\"up-p\">质量证书:<span class=\"up-span\">最多可以上传5张图片</span></p>" +"<div class=\"z_photo upimg-div clear\" >" +"<section class=\"z_file fl\">" +"<img src=\"/assets/upjs/img/a11.png\" class=\"add-img\">" +"<input type=\"file\" name=\"file\" id=\"qualitycertificateurlFile2\" class=\"file\" value=\"\" accept=\"image/jpg,image/jpeg,image/png,image/bmp\" multiple />" +"</section>" +"</div>" +"</section>" +"</div>";/*(质量说明书)*//* td3 ="<div class=\"img-box full\">" +"<section class=\" img-section\">" +"<p class=\"up-p\">质量说明书:<span class=\"up-span\">最多可以上传5张图片</span></p>" +"<div class=\"z_photo upimg-div clear\" >" +"<section class=\"z_file fl\">" +"<img src=\"/assets/upjs/img/a11.png\" class=\"add-img\">" +"<input type=\"file\" name=\"file\" id=\"manufacturingSupervisIoninsurFile2\" class=\"file\" value=\"\" accept=\"image/jpg,image/jpeg,image/png,image/bmp\" multiple />" +"</section>" +"</div>" +"</section>" +"</div>";*//*(使用说明书)*/td4 ="<div class=\"img-box full\">" +"<section class=\" img-section\">" +" <p class=\"up-p\">使用说明书:<span class=\"up-span\">最多可以上传5张图片</span></p>" +"<div class=\"z_photo upimg-div clear\" >" +"<section class=\"z_file fl\">" +"<img src=\"/assets/upjs/img/a11.png\" class=\"add-img\">" +"<input type=\"file\" name=\"file\" id=\"instructionmanualurlFile2\" class=\"file\" value=\"\" accept=\"image/jpg,image/jpeg,image/png,image/bmp\" multiple />" +"</section>" +"</div>" +"</section>" +"</div>";/*(检验报告)*/td5 ="<div class=\"img-box full\">" +"<section class=\" img-section\">" +"<p class=\"up-p\">检验报告:<span class=\"up-span\">最多可以上传5张图片</span></p>" +"<div class=\"z_photo upimg-div clear\" >" +"<section class=\"z_file fl\">" +"<img src=\"/assets/upjs/img/a11.png\" class=\"add-img\">" +"<input type=\"file\" name=\"file\" id=\"inspectereporturlFile2\" class=\"file\" value=\"\" accept=\"image/jpg,image/jpeg,image/png,image/bmp\" multiple />" +"</section>" +"</div>" +"</section>" +"</div>";/*(日常检验记录)*/td6 ="<div class=\"img-box full\">" +"<section class=\" img-section\">" +"<p class=\"up-p\">日常检验记录:<span class=\"up-span\">最多可以上传5张图片</span></p>" +"<div class=\"z_photo upimg-div clear\" >" +"<section class=\"z_file fl\">" +"<img src=\"/assets/upjs/img/a11.png\" class=\"add-img\">" +"<input type=\"file\" name=\"file\" id=\"dailyinspectrecordurlFile2\" class=\"file\" value=\"\" accept=\"image/jpg,image/jpeg,image/png,image/bmp\" multiple />" +"</section>" +"</div>" +"</section>" +"</div>";/*新增必须isfirsttest 写1*/$("#isfirsttest").val(1);/*产品合格证*/$("#productqualifyurldurlHtml").html(td1);/*质量证书*/$("#qualitycertificateurlHtml").html(td2);/*/!*质量说明书*!/$("#manufacturingsupervisioninsurlHtml").html(td3);*//*使用说明书*/$("#instructionmanualurlHtml").html(td4);/*检验报告*/$("#inspectereporturldurlHtml").html(td5);/*日常检验记录*/$("#dailyinspectrecordurlHtml").html(td6);/*   }
*/} else {DJMask.msg(data.failDesc);}}if (data.resultCode == 505) {DJMask.msg(data.failDesc);}}, error: function () {DJMask.msg(data.failDesc);}});}/*=============================添加======================================*/
function go() {$("#btn1").click();
}/*================================================弹出框 =========================================================*/
$(function () {/* 添加提示框和js逻辑!*/$("#btn1").click(function () {var cph = $("#cph").val();/*这个num,是气瓶id*/var num = $("#num").val();/*检验日期*/var firsttestdate = $("#testdate").val();/*检验单位*/var firsttestunit = $("#testunit").val();/*检验结果*/var firsttestresult = $("#testresult").val();if ( 0 == firsttestdate.length) {DJMask.msg("请输入检验日期!");return;}if (0 == firsttestunit.length) {DJMask.msg("请输入检验单位!");return;}if ( 0 == firsttestresult.length) {DJMask.msg("请输入检验结果!");return;}/*================图片上传获得图片id=================*//*===============先上传图片=========================*/var f1 = document.getElementById("productqualifyurlFile1").value;var f2 = document.getElementById("qualitycertificateurlFile2").value;/*  var f3 = document.getElementById("manufacturingSupervisIoninsurFile2").value;*/var f4 = document.getElementById("instructionmanualurlFile2").value;var f5 = document.getElementById("inspectereporturlFile2").value;var f6 = document.getElementById("dailyinspectrecordurlFile2").value;//判断图片是否已经上传/*=============ajax图片上传===========================*/var txt = "确定为车牌号: " + cph + " 添加定检信息?";var option = {title: "添加定检信息",btn: parseInt("0011", 2),onOk: function () {console.log("确认啦");DJMask.msg("正在处理请稍等!");DJMask.show();var someAjaxDfd = $.Deferred();var ajax1Dfd = $.Deferred();var ajax2Dfd = $.Deferred();var ajax3Dfd = $.Deferred();var ajax4Dfd = $.Deferred();var ajax5Dfd = $.Deferred();var ajaxtime = $.Deferred();// 返回这个延迟对象的Promise/*产品合格证*/var its_promise = $.when(someAjaxDfd);/*质量证书*/var its_promise1 = $.when(ajax1Dfd);/* 质量说明书*/var its_promise2 = $.when(ajax2Dfd);/* 使用说明书*/var its_promise3 = $.when(ajax3Dfd);/* 检验报告*/var its_promise4 = $.when(ajax4Dfd);/* 日常检验记录*/var its_promise5 = $.when(ajax5Dfd);/* 添加数据*/var its_promiseTime = $.when(ajaxtime);/* 记录用户总共上传多少组图片*/var FF = 0;/* 记录ajax 上传完成了多少组图片*/var x = 0;/*======================新方法=================================*/if (null != f1 && f1 != ""){if ((!/\.(|jpg|jpeg|png|JPG|PNG)$/.test(f1)) ) {DJMask.msg("图片类型必须是.jpeg,jpg,png中的一种");return false;}FF++;/*产品合格证*/ProductqualifyurlFileUpload(someAjaxDfd);its_promise.done(function () {x++;});}if (null != f2 && f2 != ""){if ((!/\.(|jpg|jpeg|png|JPG|PNG)$/.test(f2)) ) {DJMask.msg("图片类型必须是.jpeg,jpg,png中的一种");return false;}FF++;/*质量证书*/qualitycertificateurlFileUpload(ajax1Dfd);its_promise1.done(function () {x++;});}/* 质量说明书*//*if (null != f3 && f3 != ""){if ((!/\.(|jpg|jpeg|png|JPG|PNG)$/.test(f3)) ) {DJMask.msg("图片类型必须是.jpeg,jpg,png中的一种");return false;}FF++;/!* 质量说明书*!/ManufacturingSupervisionInsurFileUpload(ajax2Dfd);its_promise2.done(function () {x++;});}*/if (null != f4 && f4 != ""){if ((!/\.(|jpg|jpeg|png|JPG|PNG)$/.test(f4)) ) {DJMask.msg("图片类型必须是.jpeg,jpg,png中的一种");return false;}FF++;/* 使用说明书*/instructionmanualurlFileUpload(ajax3Dfd);its_promise3.done(function () {x++;});}if (null != f5 && f5 != ""){if ((!/\.(|jpg|jpeg|png|JPG|PNG)$/.test(f5)) ) {DJMask.msg("图片类型必须是.jpeg,jpg,png中的一种");return false;}FF++;/* 检验报告*/InspectereporturlUpload(ajax4Dfd);its_promise4.done(function () {x++;});}if (null != f6 && f6 != ""){if ((!/\.(|jpg|jpeg|png|JPG|PNG)$/.test(f6)) ) {DJMask.msg("图片类型必须是.jpeg,jpg,png中的一种");return false;}FF++;/*  日常检验记录*/DailyinspectrecordurlUpload(ajax5Dfd);its_promise5.done(function () {x++;});}var time = setInterval(function () {if(FF == x){ajaxtime.resolve();clearTimeout(time);console.log("时间停")}console.log("时间轮")},5000);its_promiseTime.done(function () {/*定检信息数据写入*/createGasCylinderchkInfo(cph);});}}window.wxc.xcConfirm(txt, "custom", option);});/* 添加气瓶定检信息*/function createGasCylinderchkInfo(cph) {var productqualifyurl = $("#productqualifyurl").val();var qualitycertificateurl = $("#qualitycertificateurl").val();var manufacturingsupervisioninsurl = $("#manufacturingsupervisioninsurl").val();var instructionmanualurl = $("#instructionmanualurl").val();var inspectereporturl = $("#inspectereporturl").val();var dailyinspectrecordurl = $("#dailyinspectrecordurl").val();var num = $("#num").val();var GasCylinderNum = $("#GasCylinderNum").val();var positionnum = $("#positionnum").val();var orderByClause = $("#orderByClause").val();var isfirsttest = $("#isfirsttest").val();var testdate = $("#testdate").val();var testunit = $("#testunit").val();var testresult = $("#testresult").val();console.log("确认啦");$.ajax({type: "POST",dataType: "json",async:false,url: "/config/add-GasCylinderCheckInfo",//urldata: {"productqualifyurl": productqualifyurl,"qualitycertificateurl": qualitycertificateurl,"manufacturingsupervisioninsurl": manufacturingsupervisioninsurl,"instructionmanualurl": instructionmanualurl,"inspectereporturl": inspectereporturl,"dailyinspectrecordurl": dailyinspectrecordurl,"num": num,"cph": cph,"GasCylinderNum": GasCylinderNum,"positionnum": positionnum,"orderByClause": orderByClause,"isfirsttest": isfirsttest,"testdate": testdate,"testunit": testunit,"testresult": testresult},success: function (data) {DJMask.hide();console.log("ajax:" + data);if (data.resultCode == 200) {$("#messageValue").val(data.failDesc);$("#btn2").click();}if (data.resultCode == 505) {$("#messageValue").val(data.failDesc);$("#btn3").click();};},error: function () {$("#messageValue").val("系统异常操作不成功!\n");$("#btn3").click();}});}/* 成功提示*/$("#btn2").click(function () {var txt = $("#messageValue").val();var option = {title: "添加定检信息",btn: parseInt("0012", 2),onOk: function () {window.history.go(-1);}}window.wxc.xcConfirm(txt, window.wxc.xcConfirm.typeEnum.success, option);});/* 错误提示!*/$("#btn3").click(function () {var txt = $("#messageValue").val();var option = {title: "添加定检信息",btn: parseInt("0012", 2),onOk: function () {}}window.wxc.xcConfirm(txt, window.wxc.xcConfirm.typeEnum.error, option);});
});

触发图片上传操作的 click function:

关键点说明:

js中定义了两个变量 FF 与 X,分别记录用户总共上传多少组图片与记录ajax 上传完成了多少组图片,

通过setInterval每5秒轮询用户总共上传图片组数量与ajax上传完成了多少组图片数量, 若FF 的数量

与 X 的数量一致相等即表示图片上传完成,获得了图片储存URL,可执行下步数据写入操作;

定义变量 FF 与 X :

setInterval轮询对比两个变量的值,直到两变量值相等为止:

FF与X数值相等时通知下一步数据写人操作:

页面:

<%@ page language="java" pageEncoding="UTF-8"contentType="text/html; charset=UTF-8" %>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %>
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="keywords" content=""/><meta name="description" content=""/><meta name="author" content=""/><meta name="renderer" content="webkit"><meta http-equiv="X-UA-Compatible" content="IE=edge"><title></title><link rel="icon" type="image/x-icon" href="/assets/i/favicon.ico"/><link rel="stylesheet" href="/assets/newPageJs/css/reset.css"><link rel="stylesheet" href="/assets/newPageJs/css/style.css"><script src="/assets/newPageJs/js/jQuery.js"></script><script type="text/javascript" src="/assets/showImg/js/popwin.js"></script>
</head>
<body><!--nave-->
<jsp:include page="../common/newMenu.jsp"></jsp:include><!--header-->
<jsp:include page="../common/newTop.jsp"></jsp:include>
<!--main-->
<div class="over-auto"><form class="am-form am-form-horizontal" action="##" method="post"id="stuForm"><input id="gasCylinderCheckInfoId" name="gasCylinderCheckInfoId"type="hidden" value=""><%--第一次添加为1,第二次添加为0--%><input id="isfirsttest" name="isfirsttest" type="hidden" value=""><%--产品合格证--%><input type="hidden" id="productqualifyurl" name="productqualifyurl"value=""><%--质量证书--%><input type="hidden" id="qualitycertificateurl" name="productqualifyurl"value=""><%--质量说明书--%><input type="hidden" id="manufacturingsupervisioninsurl"name="productqualifyurl" value=""><%--使用说明书--%><input type="hidden" id="instructionmanualurl" name="productqualifyurl"value=""><%--检验报告--%><input type="hidden" id="inspectereporturl" name="productqualifyurl"value=""><%--日常检验记录--%><input type="hidden" id="dailyinspectrecordurl" name="productqualifyurl"value=""><input id="loadingX" name="loadingX" type="hidden"value="${pageContext.request.contextPath}/assets/img/loading.gif"><div class="m-main"><div class="f-cb"><div class="m-title">添加定检信息</div><a href="javascript:history.go(-1);" class="return fr">返回</a><a href="javascript:go()" type="button" class="modify fr"><imgsrc="/assets/newPageJs/img/a8.svg"alt=""/>提交</a></div><div class="kk-box"><div class="box-one"><div class="s-title">基础信息</div><table id="tabe"><%-- ======--%><tr><td class="w320"><div class="same-bx mar-fr"><%--获取的气瓶编号--%><input name="GasCylinderNum"id="GasCylinderNum" type="hidden"><%--这里了的num存放气瓶id--%><input name="num" id="num" type="hidden"><div class="te">气瓶编号</div><input class="pt hover" name="num1"id="num1" value=""onblur="SelsceGasCylinderpositionnum1()"type="text"><span style="color:red;margin-left: 2px">*</span><%--<select class="select hover" id="num" name="num"onchange="SelsceGasCylinderpositionnum();"></select> 按车牌号查询气瓶信息 --%></div></td><td><div class="same-bx mar-fr"><div class="te">气瓶位置编号</div><input class="pt hover" name="positionnum"id="positionnum" value=""readonly="readonly" type="text"></div></td></tr><tr><td><div class="same-bx mar-fr"><div class="te">车牌号</div><%--<input class="pt hover" name="cph" id="cph" value="" onblur="SelectVehicleByCph()"type="text"> 按车牌号查询气瓶信息 --%><input class="pt hover" name="cph" id="cph"value=""readonly="readonly" type="text"></div></td><td></td></tr><%--================--%></table></div><div class="box-one"><div class="s-title">检验信息</div><table><tr><td class="w320"><div class="same-bx mar-fr"><div class="te">检验日期</div><input type="text"class="layui-input pt hover day"name="testdate"id="testdate" value="" lay-key="1"><span style="color:red;margin-left: 2px">*</span></div></td><td><div class="same-bx mar-fr"><div class="te">检验单位</div><input class="pt hover" name="testunit"id="testunit" type="text"><span style="color:red;margin-left: 2px">*</span></div></td></tr><tr><td><div class="same-bx mar-fr"><div class="te">检验结果</div><select class="select1 hover"id="testresult" name="testresult"><option value="">请选择</option><option value="合格">合格</option><option value="不合格">不合格</option></select><span style="color:red;margin-left: 2px">*</span></div></td><td></td></tr></table><table><tr><%--产品合格证--%><%-- <td id="productqualifyurldurlHtml">--%><td id="productqualifyurldurlHtml"><%--    <div class="img-box full"><section class=" img-section"><p class="up-p">产品合格证:<span class="up-span">最多可以上传5张图片</span></p><div class="z_photo upimg-div clear" ><section class="z_file fl"><img src="/assets/upjs/img/a11.png" class="add-img"><input type="file" name="file" id="productqualifyurlFile1" class="file" value="" accept="image/jpg,image/jpeg,image/png,image/bmp" multiple /></section></div></section></div>--%><%--            <aside class="mask works-mask"><div class="mask-content"><p class="del-p">您确定要删除作品图片吗?</p><p class="check-p"><span class="del-com wsdel-ok">确定</span><span class="wsdel-no">取消</span></p></div></aside>--%></td><%--<td id="qualitycertificateurlHtml">--%><td></td></tr><tr><%--质量证明书--%><td id="qualitycertificateurlHtml"><%--<td id="manufacturingsupervisioninsurlHtml">--%><%--   <div class="img-box full"><section class=" img-section"><p class="up-p">质量证书:<span class="up-span">最多可以上传5张图片</span></p><div class="z_photo upimg-div clear" ><section class="z_file fl"><img src="/assets/upjs/img/a11.png" class="add-img"><input type="file" name="file" id="qualitycertificateurlFile1" class="file" value="" accept="image/jpg,image/jpeg,image/png,image/bmp" multiple /></section></div></section></div>--%></td><td><%--<td id="instructionmanualurlHtml">--%></td></tr><tr><%--质量说明书--%><td id="manufacturingsupervisioninsurlHtml"><%--  <div class="img-box full"><section class=" img-section"><p class="up-p">质量说明书:<span class="up-span">最多可以上传5张图片,马上上传</span></p><div class="z_photo upimg-div clear" ><section class="z_file fl"><img src="/assets/upjs/img/a11.png" class="add-img"><input type="file" name="file" id="manufacturingSupervisIoninsurFile1" class="file" value="" accept="image/jpg,image/jpeg,image/png,image/bmp" multiple /></section></div></section></div>--%></td><td></td></tr><tr><%--使用说明书--%><td id="instructionmanualurlHtml"><%--<td id="inspectereporturldurlHtml">--%><%--    <div class="img-box full"><section class=" img-section"><p class="up-p">使用说明书:<span class="up-span">最多可以上传5张图片,马上上传</span></p><div class="z_photo upimg-div clear" ><section class="z_file fl"><img src="/assets/upjs/img/a11.png" class="add-img"><input type="file" name="file" id="instructionmanualurlFile1" class="file" value="" accept="image/jpg,image/jpeg,image/png,image/bmp" multiple /></section></div></section></div>--%></td><td><%-- <td id="dailyinspectrecordurlHtml">--%></td></tr><tr><%--检验报告--%><td id="inspectereporturldurlHtml"><%--  <div class="img-box full"><section class=" img-section"><p class="up-p">检验报告:<span class="up-span">最多可以上传5张图片,马上上传</span></p><div class="z_photo upimg-div clear" ><section class="z_file fl"><img src="/assets/upjs/img/a11.png" class="add-img"><input type="file" name="file" id="inspectereporturlFile1" class="file" value="" accept="image/jpg,image/jpeg,image/png,image/bmp" multiple /></section></div></section></div>--%></td><td></td></tr><tr><%--日常检验记录--%><td id="dailyinspectrecordurlHtml"><%--<div class="img-box full"><section class=" img-section"><p class="up-p">日常检验记录:<span class="up-span">最多可以上传5张图片,马上上传</span></p><div class="z_photo upimg-div clear" ><section class="z_file fl"><img src="/assets/upjs/img/a11.png" class="add-img"><input type="file" name="file" id="dailyinspectrecordurlFile1" class="file" value="" accept="image/jpg,image/jpeg,image/png,image/bmp" multiple /></section></div></section></div>--%></td><td></td></tr><tr><%--========这个没用但去掉会对图片上传样式造成影响=========--%><td class="w320"><div class="same-bx mar-fr"><div class="te"></div><input type="hidden" class="" name=""id="" value="" lay-key="1"></div></td><td></td></tr></table></div><div class="box-one"></div></div></div></form>
</div>
<%--====================================================遮罩========================================================--%>
<input type="hidden" id="messageValue" name="messageValue" value="">
<input type="hidden" id="createVehgroupId" name="createVehgroupId" value="">
<input type="hidden" id="value" name="value" value="">
<input type="hidden" id="id1" name="id1" value="">
<input type="hidden" id="vehId" name="vehId" value="">
<input type="hidden" id="num1" name="num1" value=""><input class="sgBtn" id="btn4" type="hidden" value="弹窗4(自定义)">
<input class="sgBtn" id="btn5" type="hidden" value="弹窗5(自定义)">
<input class="sgBtn" id="btn7" type="hidden" value="弹窗7(自定义)"><input class="sgBtn" id="btn1" type="hidden" value="弹窗1(自定义)">
<input class="sgBtn" id="btn2" type="hidden" value="弹窗2(自定义)">
<input class="sgBtn" id="btn3" type="hidden" value="弹窗3(自定义)"><<%--script src="/assets/js/system/DJMask.js"></script>
<link rel="stylesheet" type="text/css" href="/assets/css/xcConfirm.css"/>
<script src="/assets/js/jquery-1.9.1.js" type="text/javascript" charset="utf-8"></script>
<script src="/assets/js/xcConfirm.js" type="text/javascript" charset="utf-8"></script>
<style type="text/css">.sgBtn{width: 135px; height: 35px; line-height: 35px; margin-left: 10px; margin-top: 10px; text-align: center; background-color: #0095D9; color: #FFFFFF; float: left; border-radius: 5px;}
</style>
<link href="/assets/css/index.css" rel="stylesheet"/>
<script src="http://www.jq22.com/jquery/jquery-1.10.2.js"></script>--%>
<script src="/assets/js/system/DJMask.js"></script>
<link rel="stylesheet" type="text/css" href="/assets/css/xcConfirm.css"/>
<script src="/assets/js/jquery-1.9.1.js" type="text/javascript"charset="utf-8"></script>
<script src="/assets/js/xcConfirm.js" type="text/javascript"charset="utf-8"></script>
<style type="text/css">.sgBtn {width: 135px;height: 35px;line-height: 35px;margin-left: 10px;margin-top: 10px;text-align: center;background-color: #0095D9;color: #FFFFFF;float: left;border-radius: 5px;}
</style>
<%--<link href="/assets/css/index.css" rel="stylesheet"/>--%>
<script src="http://www.jq22.com/jquery/jquery-1.10.2.js"></script>
<script type="text/javascript" src="/assets/js/jquery-DJMask.2.1.1.js"charset="UTF-8"></script><script src="/assets/js/jquery.min.js"></script>
<script src="/assets/js/amazeui.min.js"></script><%--<script src="/assets/js/laydate/laydate.js"></script>--%>
<!-- 日期js改成你的路径 -->
<script src="${pageContext.request.contextPath}/assets/newPageJs/js/laydate/laydate.js"></script>
<%--<script src="/assets/js/app.js"></script>--%></body><script src="/assets/newPageJs/js/main.js"></script>
<script src="/assets/js/gm/air_parameter_add.js"></script><%--图片上传--%>
<link href="/assets/upjs/css/common.css" type="text/css" rel="stylesheet"/>
<link href="/assets/upjs/css/index.css" type="text/css" rel="stylesheet"/>
<%--<script src="http://www.jq22.com/jquery/jquery-1.10.2.js"></script>--%>
<%--<script src="/assets/upjs/js/imgUp.js"></script>--%>
<%--上传--%>
<script src="/assets/js/gm/add-GasCylinderCheckInfoAjaxfileupload.js"></script>
<script src="/assets/js/ajaxfileupload.js"></script></html>

单图片预览js:

assets/showImg/js/popwin.js


var popWin = {scrolling: 'no',//是否显示滚动条 no,yes,autoint: function() {this.mouseClose();this.closeMask();//this.mouseDown();},showWin: function(width, height, title, src) {var iframeHeight = height - 52;var marginLeft = width / 2;var marginTop = height / 2;var inntHtml = '';inntHtml += '<div id="mask" style="width:100%; height:100%; position:fixed; top:0; left:0; z-index:1999;background:#cccccc; filter:alpha(opacity=50); -moz-opacity:0.5; -khtml-opacity: 0.5; opacity:0.5;"></div>'inntHtml += '<div id="maskTop" style="width: ' + width + 'px; height: ' + height + 'px; border: #999999 1px solid; background: #fff; color: #333; position: fixed; top: 50%; left: 50%; margin-left: -' + marginLeft + 'px; margin-top: -' + marginTop + 'px; z-index: 2999; filter: progid:DXImageTransform.Microsoft.Shadow(color=#909090,direction=120,strength=4); -moz-box-shadow: 2px 2px 10px #909090; -webkit-box-shadow: 2px 2px 10px #909090; box-shadow: 2px 2px 10px #909090;">'inntHtml += '<div id="maskTitle" style="height: 50px; line-height: 50px; font-family: Microsoft Yahei; font-size: 20px; color: #333333; padding-left: 20px; background-image: url(); border-bottom: 1px solid #999999; position: relative;">'inntHtml += '' + title + ''inntHtml += '<div id="popWinClose" style="width: 28px; height: 28px; cursor: pointer; position: absolute; top: -12px; right: -9px; background-image: url();"></div>'inntHtml += '</div>'for(var i = 0; i < src.length; i++){if(src[i] != ""){/*inntHtml +=  "<img src=\"" + src[i] + "\" onclick=\"lookProductqualifyurl('"+src[i]+"');\" class=\"add-img\" style=\"list-style:none;margin:8.5px;width: 420px;height: 400px; \">";*/inntHtml +=  "<img src=\"" + src[i] + "\" onclick=\"showImgD('"+src[i]+"');\" class=\"add-img\" style=\"list-style:none;margin:8.5px;width: 300px;height: 250px; \">";}}/*inntHtml += '<iframe width="' + width + '" height="' + iframeHeight + '" frameborder="0" scrolling="' + this.scrolling + '" src="' + url + '"></iframe>';*/$("body").append(inntHtml);this.int();},mouseClose: function() {$("#popWinClose").on('mouseenter', function() {$(this).css("background-image", "url()");});$("#popWinClose").on('mouseleave', function() {$(this).css("background-image", "url()");});},closeMask: function() {$("#popWinClose").on('click', function() {$("#mask,#maskTop").fadeOut(function() {$(this).remove();});});}/*mouseDown : function(){var dragging = false;var iX, iY;//var elmen = $("div#maskTop");$("#maskTop").on('mousedown' , function(e){dragging = true;iX = e.clientX - this.offsetLeft;iY = e.clientY - this.offsetTop;this.setCapture && this.setCapture();return false;});document.onmousemove = function(e) {if (dragging) {var e = e || window.event;var oX = e.clientX - iX;var oY = e.clientY - iY;$("#maskTop").css({"left":oX + "px", "top":oY + "px"});return false;}};$(document).mouseup(function(e) {dragging = false;$("#maskTop")[0].releaseCapture();e.cancelBubble = true;})},*/};/*单图片查看*/
var popWinD = {scrolling: 'no',//是否显示滚动条 no,yes,autoint: function() {this.mouseClose();this.closeMask();//this.mouseDown();},showWin: function(width, height, title, src) {var iframeHeight = height - 52;var marginLeft = width / 2;var marginTop = height / 2;var inntHtml = '';inntHtml += '<div id="mask1" style="width:100%; height:100%; position:fixed; top:0; left:0; z-index:3500;background:#cccccc; filter:alpha(opacity=50); -moz-opacity:0.5; -khtml-opacity: 0.5; opacity:0.5;"></div>'inntHtml += '<div id="maskTop1" style="width: ' + width + 'px; height: ' + height + 'px; border: #999999 1px solid; background: #fff; color: #333; position: fixed; top: 50%; left: 50%; margin-left: -' + marginLeft + 'px; margin-top: -' + marginTop + 'px; z-index: 3600; filter: progid:DXImageTransform.Microsoft.Shadow(color=#909090,direction=120,strength=4); -moz-box-shadow: 2px 2px 10px #909090; -webkit-box-shadow: 2px 2px 10px #909090; box-shadow: 2px 2px 10px #909090;">'inntHtml += '<div id="maskTitle1" style="height: 50px; line-height: 50px; font-family: Microsoft Yahei; font-size: 20px; color: #333333; padding-left: 20px; background-image: url(); border-bottom: 1px solid #999999; position: relative;">'inntHtml += '' + title + ''inntHtml += '<div id="popWinClose1" style="width: 28px; height: 28px; cursor: pointer; position: absolute; top: -12px; right: -9px; background-image: url();"></div>'inntHtml += '</div>'/*inntHtml +=' <div id="outerdiv" style="position:fixed;top:0;left:0;background:rgba(0,0,0,0.7);z-index:2;width:100%;height:100%;display:none;">'inntHtml +=' <div id="innerdiv" style="position:absolute;">'*/if(src != ""){inntHtml +=  "<img src=\"" + src + "\"  class=\"add-img\" style=\"list-style:none;margin:8.5px;width: 580px;height: 524px; \">";}/*inntHtml += '</div>'inntHtml += '</div>'*//*inntHtml += '<iframe width="' + width + '" height="' + iframeHeight + '" frameborder="0" scrolling="' + this.scrolling + '" src="' + src[i] + '"></iframe>';*/$("body").append(inntHtml);this.int();},mouseClose: function() {$("#popWinClose1").on('mouseenter',function() {$(this).css("background-image", "url()");});$("#popWinClose1").on('mouseleave',function() {$(this).css("background-image", "url()");});},closeMask: function() {$("#popWinClose1").on('click',function() {$("#mask1,#maskTop1").fadeOut(function() {$(this).remove();});});}/*mouseDown : function(){var dragging = false;var iX, iY;//var elmen = $("div#maskTop");$("#maskTop").on('mousedown' , function(e){dragging = true;iX = e.clientX - this.offsetLeft;iY = e.clientY - this.offsetTop;this.setCapture && this.setCapture();return false;});document.onmousemove = function(e) {if (dragging) {var e = e || window.event;var oX = e.clientX - iX;var oY = e.clientY - iY;$("#maskTop").css({"left":oX + "px", "top":oY + "px"});return false;}};$(document).mouseup(function(e) {dragging = false;$("#maskTop")[0].releaseCapture();e.cancelBubble = true;})},*/};

 

DJMask弹出提示框js:
assets/js/jquery-DJMask.2.1.1.js

/**DJMask.js* author:Mo* updateTime:2016/12/17* */
DJMask={common:{//公共配置windowW:$(window).width(),//浏览器窗口宽度windowH:$(window).height(),//浏览器窗口高度   closeCssAnimate:function(){//关闭X的动画效果$("[class*=-close]").css({"transition":"all 0.4s ease-in-out","-webkit-transition":"all 0.4s ease-in-out","-ms-transition":"all 0.4s ease-in-out"}).hover(function(){$(this).css({"color":"#ff0000","transform":"rotate(360deg)","-webkit-transform":"rotate(360deg)","-ms-transform":"rotate(360deg)"});},function(){$(this).css({"color":"#666","transform":"rotate(0deg)","-webkit-transform":"rotate(0deg)","-ms-transform":"rotate(0deg)"});})}},maskBackgroundCss:function(){var css={//遮罩的黑色透明背景样式"background":"#000000",                       "opacity":"0.5","-moz-opacity":"0.5","-webkit-opacity":"0.5","filter":"alpha(opacity=50)","width":"100%","height":document.body.scrollHeight,//文档的高度"position": "absolute","top": "0px","left": "0px","z-index": "100","display":"none"};return css;},init:function(){//初始化             var maskHtml='<div id="dj-mask"></div>';                                $(maskHtml).appendTo("body");djMaskDomLoaded=$("#dj-mask");djMaskDomLoaded.css(this.maskBackgroundCss());},show:function(){//展示遮罩this.init();djMaskDomLoaded.show();},hide:function(){//关闭遮罩djMaskDomLoaded.remove();}, loadingCss:function(){this.show();var loadingBoxCenterCss={"position":"absolute","left":"50%","top":"50%","height":"20px","width":"100px","margin-top":"-10px","margin-left":"-50px","z-index":"999999999"};var objectClass={"width":"20px","height":"20px","background-color":"#FFF","-moz-border-radius":"50% 50% 50% 50%","-webkit-border-radius":"50% 50% 50% 50%","border-radius":"50% 50% 50% 50%","margin-right":"20px","margin-bottom":"20px","position":"absolute"};var objectOneCss={"-webkit-animation":"object 2s linear infinite","-ms-animation":"object 2s linear infinite","animation":"object 2s linear infinite"};var objectTwoCss={"-webkit-animation": "object 2s linear infinite -.4s","-ms-animation":"object 2s linear infinite -.4s","animation":"object 2s linear infinite -.4s"};var objectThreeCss={"-webkit-animation": "object 2s linear infinite -.8s","-ms-animation": "object 2s linear infinite -.8s","animation": "object 2s linear infinite -.8s"};var objectFourCss={"-webkit-animation": "object 2s linear infinite -1.2s","-ms-animation": "object 2s linear infinite -1.2s","animation": "object 2s linear infinite -1.2s",};var objectFiveCss={"-webkit-animation": "object 2s linear infinite -1.6s","-ms-animation": "object 2s linear infinite -1.6s","animation":"object 2s linear infinite -1.6s"};var keyframesObj='0% { left: 100px; top:0}'+'80% { left: 0; top:0;}'+'85% { left: 0; top: -20px; width: 20px; height: 20px;}'+'90% { width: 40px; height: 15px; }'+'95% { left: 100px; top: -20px; width: 20px; height: 20px;}'+'100% { left: 100px; top:0; }';document.styleSheets.item(0).insertRule('@-webkit-keyframes object{0% { left: 100px; top:0}80% { left: 0; top:0;}85% { left: 0; top: -20px; width: 20px; height: 20px;}90% { width: 40px; height: 15px; }95% { left: 100px; top: -20px; width: 20px; height: 20px;}100% { left: 100px; top:0; }}',0); document.styleSheets.item(0).insertRule('@keyframes object{0% { left: 100px; top:0}80% { left: 0; top:0;}85% { left: 0; top: -20px; width: 20px; height: 20px;}90% { width: 40px; height: 15px; }95% { left: 100px; top: -20px; width: 20px; height: 20px;}100% { left: 100px; top:0; }    }',0); var html='<div id="dj-mask-loadingBoxCenter">'+'<div class="object" id="objectOne"></div>'+'<div class="object" id="objectTwo" style="left:20px;"></div>'+'<div class="object" id="objectThree" style="left:40px;"></div>'+'<div class="object" id="objectFour" style="left:60px;"></div>'+'<div class="object" id="objectFive" style="left:80px;"></div>''</div>';$(html).css(loadingBoxCenterCss).appendTo("body").children(".object").css(objectClass);$("#objectOne").css(objectOneCss);$("#objectTwo").css(objectTwoCss);$("#objectThree").css(objectThreeCss);$("#objectFour").css(objectFourCss);$("#objectFive").css(objectFiveCss);},loading:function(option){//加载中...if(option=="close"){this.hide();$("#dj-mask-loadingBoxCenter").remove();}else{                                        this.loadingCss();}},closeAll:function(){               $("[class^=dj-mask-]").remove();$("[id^=dj-mask]").remove();            },msg:function(message){//消息提示if(message==undefined||message=="") return false;var msgDom='<div class="dj-msg-number-'+Math.floor(Math.random()*1000000)+'"></div>';                    $(msgDom).css({"overflow":"hidden","background":"rgba(0,0,0,.5)","border-radius":"4px","position": "fixed","top":$(window).height()/2.5+"px","left":$(window).width()/2+"px",   "padding":"15px","color":"#fff","z-index":"999999","display":"none","max-width":"200px","word-break":"break-all"}).appendTo("body").html(message);var msgDomLoaded=$("."+$(msgDom).attr("class"));//获取设置样式后的msg元素msgDomLoaded.css({//消息居中"margin-left":"-"+msgDomLoaded.width()/2+"px","margin-top":"-"+msgDomLoaded.height()/2+"px",}).fadeIn();setTimeout(function(){$("."+$(msgDom).attr("class")).remove();},1500);},alertMask:function(){//弹框遮罩var alertMaskHtml='<div id="dj-mask-alert"></div>';                             $(alertMaskHtml).appendTo("body");alertMaskDomLoaded=$("#dj-mask-alert");alertMaskDomLoaded.css($.extend(this.maskBackgroundCss(),{"z-index":"200"}));},alert:function(message,callback){//弹框提醒             if(message==""||message==undefined) return false;this.alertMask();alertMaskDomLoaded.show(); var alertDom='<div class="dj-mask-alert-'+Math.floor(Math.random()*1000000)+'"></div>';$(alertDom).css({"width":"200px","overflow":"hidden","border":"1px solid #ddd",                 "z-index":"300","background":"#fff","border-radius":"4px","position": "fixed","top":$(window).height()/2.5+"px","left":$(window).width()/2+"px",    }).appendTo("body");var alertDomLoaded=$("."+$(alertDom).attr("class"));alertDomLoaded.css({"margin-left":"-"+alertDomLoaded.width()/2+"px","margin-top":"-"+alertDomLoaded.height()/2+"px",}).append('<div style="height:30px;border-bottom:1px solid #ddd;line-height:30px;padding-left:10px;font-size:14px;color:#666;background:#ebebeb">提示<a style="float:right;margin-right:10px;cursor:pointer;color:#666;font-size:15px;" class="dj-alert-close">X</a></div>').append('<div style="font-size:13px;color:#333;padding:10px;overflow:hidden;word-break:break-all" class="dj-alert-content"></div>').append('<a style="display:block;width:50px;height:25px;line-height:25px;text-align:center;border-radius:4px;background:#428bca;color:#fff;cursor:pointer;float:right;margin:5px;padding:0" class="dj-alert-ok">确定</a>');this.common.closeCssAnimate();$(".dj-alert-content").html(message);$(".dj-alert-close").click(function(){//关闭窗口alertDomLoaded.remove();alertMaskDomLoaded.remove();});$(".dj-alert-ok").click(function(){if(callback)  callback();//有回调函数执行函数内容alertDomLoaded.remove();alertMaskDomLoaded.remove();});},openMask:function(){//自定义弹窗遮罩             var openMaskHtml='<div id="dj-mask-open"></div>';                               $(openMaskHtml).appendTo("body");openMaskDomLoaded=$("#dj-mask-open");openMaskDomLoaded.css($.extend(this.maskBackgroundCss(),{"z-index":"150"}));},open:function(options,callback){//自定义弹窗内容var config={width:"400px",height:"300px",title:"提示",content:"<div>loading.......</div>"},me=$.extend(config, options);this.openMask();openMaskDomLoaded.show();var contentDom='<div class="dj-mask-content-'+Math.floor(Math.random()*1000000)+'"></div>';$(contentDom).css({"width":me.width,"height":me.height,"overflow":"hidden","border":"1px solid #ddd",                    "z-index":"150","background":"#fff","border-radius":"4px","position": "fixed","top":$(window).height()/2.5+"px","left":$(window).width()/2+"px",        }).appendTo("body");var contentDomLoaded=$("."+$(contentDom).attr("class"));contentDomLoaded.css({"margin-left":"-"+contentDomLoaded.width()/2+"px","margin-top":"-"+contentDomLoaded.height()/2+"px",}).append('<div style="height:30px;border-bottom:1px solid #ddd;line-height:30px;padding-left:10px;font-size:14px;color:#666;background:#ebebeb">'+me.title+'<a style="float:right;margin-right:10px;cursor:pointer;color:#666;font-size:15px;" class="dj-content-close">X</a></div>').append('<div style="font-size:13px;color:#333;padding:10px;overflow:hidden;word-break:break-all" class="dj-content-content"></div>');this.common.closeCssAnimate();$(".dj-content-content").html(me.content);$(".dj-content-close").click(function(){//关闭窗口if(callback) callback();//有回调函数执行函数内容contentDomLoaded.remove();openMaskDomLoaded.remove();                  });},doAjaxMthod:(function(){//定义完立即执行  ,ajax遮罩添加   var mss = {};var ajaxStart_default = mss.ajaxStart_default = function() {                       DJMask.loading();};var ajaxStop_default = mss.ajaxStop_default = function() {DJMask.loading("close");};$(document).ajaxStart(ajaxStart_default); // 默认的ajax执行前处理$(document).ajaxStop(ajaxStop_default); // 默认的ajax执行完毕处理}())};

确认弹出框:

<link rel="stylesheet" type="text/css" href="/assets/css/xcConfirm.css"/>

/*垂直居中*/
.verticalAlign{ vertical-align:middle; display:inline-block; height:100%; margin-left:-1px;}.xcConfirm .xc_layer{position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-color: #666666; opacity: 0.5; z-index: 2147000000;}
.xcConfirm .popBox{position: fixed; left: 50%; top: 50%; background-color: #ffffff; z-index: 2147000001; width: 500px; height: 250px; margin-left: -285px; margin-top: -150px; border-radius: 5px; font-weight: bold; color: #535e66;}
.xcConfirm .popBox .ttBox{height: 20px; line-height: 30px; padding: 14px 30px; border-bottom: solid 1px #eef0f1;}
.xcConfirm .popBox .ttBox .tt{font-size: 18px; display: block; float: left; height: 30px; position: relative;}
.xcConfirm .popBox .ttBox .clsBtn{display: block; cursor: pointer; width: 12px; height: 12px; position: absolute; top: 22px; right: 30px; background: url(../img/icons.png) -48px -96px no-repeat;}
.xcConfirm .popBox .txtBox{margin: 40px 100px; height: 100px; overflow: hidden;}
.xcConfirm .popBox .txtBox .bigIcon{float: left; margin-right: 20px; width: 48px; height: 48px; background-image: url(../img/icons.png); background-repeat: no-repeat; background-position: 48px 0;}
.xcConfirm .popBox .txtBox p{ height: 84px; margin-top: 16px; line-height: 26px; overflow-x: hidden; overflow-y: auto;}
.xcConfirm .popBox .txtBox p input{width: 364px; height: 30px; border: solid 1px #eef0f1; font-size: 18px; margin-top: 6px;}
.xcConfirm .popBox .btnArea{border-top: solid 1px #eef0f1;}
.xcConfirm .popBox .btnGroup{float: right;}
.xcConfirm .popBox .btnGroup .sgBtn{margin-top: -25px; margin-right: 12px;}
.xcConfirm .popBox .sgBtn{display: block; cursor: pointer; float: left; width: 95px; height: 35px; line-height: 35px; text-align: center; color: #FFFFFF; border-radius: 5px;}
.xcConfirm .popBox .sgBtn.ok{background-color: #0095d9; color: #FFFFFF;}
.xcConfirm .popBox .sgBtn.cancel{background-color: #546a79; color: #FFFFFF;}

 assets/js/xcConfirm.js

 
/** 使用说明:* window.wxc.Pop(popHtml, [type], [options])* popHtml:html字符串* type:window.wxc.xcConfirm.typeEnum集合中的元素* options:扩展对象* 用法:* 1. window.wxc.xcConfirm("我是弹窗<span>lalala</span>");* 2. window.wxc.xcConfirm("成功","success");* 3. window.wxc.xcConfirm("请输入","input",{onOk:function(){}})* 4. window.wxc.xcConfirm("自定义",{title:"自定义"})*/
(function($){window.wxc = window.wxc || {};window.wxc.xcConfirm = function(popHtml, type, options) {var btnType = window.wxc.xcConfirm.btnEnum;var eventType = window.wxc.xcConfirm.eventEnum;var popType = {info: {title: "信息",icon: "0 0",//蓝色ibtn: btnType.ok},success: {title: "成功",icon: "0 -48px",//绿色对勾btn: btnType.ok},error: {title: "错误",icon: "-48px -48px",//红色叉btn: btnType.ok},confirm: {title: "提示",icon: "-48px 0",//黄色问号btn: btnType.okcancel},warning: {title: "警告",icon: "0 -96px",//黄色叹号btn: btnType.okcancel},input: {title: "输入",icon: "",btn: btnType.ok},custom: {title: "",icon: "",btn: btnType.ok}};var itype = type ? type instanceof Object ? type : popType[type] || {} : {};//格式化输入的参数:弹窗类型var config = $.extend(true, {//属性title: "", //自定义的标题icon: "", //图标btn: btnType.ok, //按钮,默认单按钮//事件onOk: $.noop,//点击确定的按钮回调onCancel: $.noop,//点击取消的按钮回调onClose: $.noop//弹窗关闭的回调,返回触发事件}, itype, options);var $txt = $("<p>").html(popHtml);//弹窗文本domvar $tt = $("<span>").addClass("tt").text(config.title);//标题var icon = config.icon;var $icon = icon ? $("<div>").addClass("bigIcon").css("backgroundPosition",icon) : "";var btn = config.btn;//按钮组生成参数var popId = creatPopId();//弹窗索引var $box = $("<div>").addClass("xcConfirm");//弹窗插件容器var $layer = $("<div>").addClass("xc_layer");//遮罩层var $popBox = $("<div>").addClass("popBox");//弹窗盒子var $ttBox = $("<div>").addClass("ttBox");//弹窗顶部区域var $txtBox = $("<div>").addClass("txtBox");//弹窗内容主体区var $btnArea = $("<div>").addClass("btnArea");//按钮区域var $ok = $("<a>").addClass("sgBtn").addClass("ok").text("确定");//确定按钮var $cancel = $("<a>").addClass("sgBtn").addClass("cancel").text("取消");//取消按钮var $input = $("<input>").addClass("inputBox");//输入框var $clsBtn = $("<a>").addClass("clsBtn");//关闭按钮//建立按钮映射关系var btns = {ok: $ok,cancel: $cancel};init();function init(){//处理特殊类型inputif(popType["input"] === itype){$txt.append($input);}creatDom();bind();}function creatDom(){$popBox.append($ttBox.append($clsBtn).append($tt)).append($txtBox.append($icon).append($txt)).append($btnArea.append(creatBtnGroup(btn)));$box.attr("id", popId).append($layer).append($popBox);$("body").append($box);}function bind(){//点击确认按钮$ok.click(doOk);//回车键触发确认按钮事件$(window).bind("keydown", function(e){if(e.keyCode == 13) {if($("#" + popId).length == 1){doOk();}}});//点击取消按钮$cancel.click(doCancel);//点击关闭按钮$clsBtn.click(doClose);}//确认按钮事件function doOk(){var $o = $(this);var v = $.trim($input.val());if ($input.is(":visible"))config.onOk(v);elseconfig.onOk();$("#" + popId).remove(); config.onClose(eventType.ok);}//取消按钮事件function doCancel(){var $o = $(this);config.onCancel();$("#" + popId).remove(); config.onClose(eventType.cancel);}//关闭按钮事件function doClose(){$("#" + popId).remove();config.onClose(eventType.close);$(window).unbind("keydown");}//生成按钮组function creatBtnGroup(tp){var $bgp = $("<div>").addClass("btnGroup");$.each(btns, function(i, n){if( btnType[i] == (tp & btnType[i]) ){$bgp.append(n);}});return $bgp;}//重生popId,防止id重复function creatPopId(){var i = "pop_" + (new Date()).getTime()+parseInt(Math.random()*100000);//弹窗索引if($("#" + i).length > 0){return creatPopId();}else{return i;}}};//按钮类型window.wxc.xcConfirm.btnEnum = {ok: parseInt("0001",2), //确定按钮cancel: parseInt("0010",2), //取消按钮okcancel: parseInt("0011",2) //确定&&取消};//触发事件类型window.wxc.xcConfirm.eventEnum = {ok: 1,cancel: 2,close: 3};//弹窗类型window.wxc.xcConfirm.typeEnum = {info: "info",success: "success",error:"error",confirm: "confirm",warning: "warning",input: "input",custom: "custom"};})(jQuery);

后台:

package com.tc.lvmsm.controller.gm;import com.tc.common.bean.cm.CmService;
import com.tc.common.log.BaseController;
import com.tc.common.log.ModuleLogger;
import com.tc.common.log.ModuleLoggerFactory;import com.tc.common.page.Page;
import com.tc.common.pic.OSSUploadUtil;
import com.tc.lvmsm.serv.itf.GasCylinderCheckInfoService;
import com.tc.lvmsm.serv.itf.GasService;
import com.tc.lvmsm.vo.cm.VehicleAndGasCylinderAndGasCylinderCheckInfo;
import com.tc.lvmsm.vo.gm.*;
import com.tc.lvmsm.vo.vm.Vehicle;
import com.tc.lvmsm.vo.vm.VehicleExample;
import com.tc.util.DateUtils;
import com.tc.util.ExcelUtil;
import org.apache.shiro.SecurityUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.multipart.MultipartFile;
import org.springframework.web.multipart.commons.CommonsMultipartFile;import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.*;
import java.net.URLDecoder;
import java.net.URLEncoder;
import java.util.*;/*** <p>* <p>* FileName: GasCylinderCheckInfoController* Author:    苏凯* Date:     2018/3/22 19:08* Description: 气瓶定检信息Controller**/
@Controller
public class GasCylinderCheckInfoController
{/*** 配置管理、Service层各模块接口bean*/@Autowiredprivate CmService cmServiceFactory;/*** 气瓶管理、气瓶定检service*/@Autowiredprivate GasCylinderCheckInfoService gasCylinderCheckInfoService;/*** 配置管理 气瓶service*/@Autowiredprivate GasService gasService;/*** 获得日志句柄*/private ModuleLogger logger = ModuleLoggerFactory.getDefinedLogger("GM\\GasCylinderCheckInfoController ");/*** Description: 查询所有数据+分页(ajax WEB-INF/jsp/gm/air_test_info.jsp);** @param cph       车辆条件做查询条件* @param num       气瓶编号* @param pageNow   查询当前第几页的数据* @param pageSize1 显示每页多少条数据* @return page*/@RequestMapping(value = "/config/show-GasCylinderCheckInfo", produces = "application/json;charset=UTF-8")@ResponseBodypublic Page showAllGasCylinderCheckInfo(HttpServletRequest request,Integer pageNow, Integer pageSize1, String cph, String num,String positionnum, String firsttestdate1, String firsttestdate2,String orderByClause){String startTime = DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss");String CALLER = "GasCylinderCheckInfoController_/config/show-GasCylinderCheckInfo ";// 创建分页对象Page page = null;try{// 排序 默认idif (null == orderByClause || 0 == orderByClause.length()){orderByClause = "testdate DESC";}// 转换positionnum查询条件if (null != positionnum && "气瓶已卸载!".equals(positionnum.trim())){positionnum = "待配置气瓶!";}if (null != positionnum && "气瓶已卸载".equals(positionnum.trim())){positionnum = "待配置气瓶!";}// 创建气瓶定检信息的List容器List<GasCylinderCheckInfo> gasCylinderCheckInfos = new ArrayList<GasCylinderCheckInfo>();// 如果页面有传入气瓶参数做查询条件,需要获取车队IDList<Integer> vehicleIds = new ArrayList<Integer>();// 获取气瓶idList<Integer> GasCylinderIds = new ArrayList<Integer>();// 存放关联数据的集合List<VehicleAndGasCylinderAndGasCylinderCheckInfo> vehicleAndGasCylinderAndGasCylinderCheckInfos = new ArrayList<VehicleAndGasCylinderAndGasCylinderCheckInfo>();// 通过车辆查条件查询数据if ((null != cph && 0 < cph.trim().length())){VehicleExample vehicleExample = new VehicleExample();VehicleExample.Criteria vehicleExampleCriteria = vehicleExample.createCriteria();// 车牌号vehicleExampleCriteria.andCphLike("%" +cph.trim()+ "%");List<Vehicle> vehicles = cmServiceFactory.getVmVehicleService().selectByExample(CALLER, vehicleExample);if (0 < vehicles.size()){for (int j = 0; j < vehicles.size(); j++){// 通过车辆条件获取到已配置气瓶的车辆id(车辆id放容器中用做获取气瓶信息的条件)vehicleIds.add(vehicles.get(j).getId().intValue());}}else{vehicleIds.add(0);}}// 页面有传入气瓶编号或气瓶位置编号做查询条件// 创建气瓶查询条件if ((null != num && 0 < num.trim().length())|| (null != positionnum && 0 < positionnum.trim().length())|| (0 < vehicleIds.size())){GasCylinderExample gasCylinderExample = new GasCylinderExample();GasCylinderExample.Criteria criteria2 = gasCylinderExample.createCriteria();// 气瓶编号numif (null != num && 0 < num.trim().length()){criteria2.andNumLike("%" +num.trim()+ "%");}// 气瓶位置编号positionnumif (null != positionnum && 0 < positionnum.trim().length()){criteria2.andPositionnumEqualTo(positionnum.trim());}// 通过车辆id获取已经配置的配置信息if (0 < vehicleIds.size()){List<Long> vehicleIdsL = new ArrayList<Long>();for (int i = 0; i < vehicleIds.size(); i++){vehicleIdsL.add(vehicleIds.get(i).longValue());}if (0 < vehicleIdsL.size()){criteria2.andVehidIn(vehicleIdsL);}}// 必须显示已安装的气瓶,排除(Vehid= -1状态 为未安装的气瓶)long i = -1;/* criteria2.andVehidNotEqualTo(i); */ // 如果只需要显示已配置车辆的气瓶信息,把这条注释打开即可List<GasCylinder> gasCylinders = gasService.selectByExample(CALLER, gasCylinderExample);if (0 < gasCylinders.size()){for (int j = 0; j < gasCylinders.size(); j++){GasCylinderIds.add(gasCylinders.get(j).getId());}}else{GasCylinder gasCylinder = new GasCylinder();gasCylinder.setNum("无气瓶信息");// 当气瓶编号未查询到数据时,页面不应当有数据,所以这边的车辆ID集合中写入0;GasCylinderIds.add(0);}}// 构造气瓶定检查询条件GasCylinderCheckInfoExample gasCylinderCheckInfoExample = new GasCylinderCheckInfoExample();GasCylinderCheckInfoExample.Criteria criteria2 = gasCylinderCheckInfoExample.createCriteria();if (0 < GasCylinderIds.size()){criteria2.andGascylinderidIn(GasCylinderIds);}// 按日期查询if (null != firsttestdate1 && 0 < firsttestdate1.length()){criteria2.andTestdateEqualTo(firsttestdate1);}int i1 = gasCylinderCheckInfoService.countByExample(CALLER,gasCylinderCheckInfoExample);if (null != pageNow){page = new Page(i1, pageNow);if (null != pageSize1){page.setPageSize(pageSize1);}gasCylinderCheckInfos = gasCylinderCheckInfoService.selectGasCylinderCheckInfoeByExampleNoUrlList(CALLER,page.getStartPos(), page.getPageSize(),gasCylinderCheckInfoExample, orderByClause);if (0 < gasCylinderCheckInfos.size()){for (int i = 0; i < gasCylinderCheckInfos.size(); i++){VehicleAndGasCylinderAndGasCylinderCheckInfo vehicleAndGasCylinderAndGasCylinderCheckInfo = getVehicleAndGasCylinderAndGasCylinderCheckInfo(CALLER, request,vehicleAndGasCylinderAndGasCylinderCheckInfos,gasCylinderCheckInfos, cph, i);vehicleAndGasCylinderAndGasCylinderCheckInfos.add(vehicleAndGasCylinderAndGasCylinderCheckInfo);}}else{BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息","气瓶定检信息", "查询", 0, 1, "未找到气瓶定检数据!" + CALLER);}}else{page = new Page(i1, 1);if (null != pageSize1){page.setPageSize(pageSize1);}gasCylinderCheckInfos = gasCylinderCheckInfoService.selectGasCylinderCheckInfoeByExample(CALLER,page.getStartPos(), page.getPageSize(),gasCylinderCheckInfoExample, orderByClause);if (0 < gasCylinderCheckInfos.size()){for (int i = 0; i < gasCylinderCheckInfos.size(); i++){VehicleAndGasCylinderAndGasCylinderCheckInfo vehicleAndGasCylinderAndGasCylinderCheckInfo = getVehicleAndGasCylinderAndGasCylinderCheckInfo(CALLER, request,vehicleAndGasCylinderAndGasCylinderCheckInfos,gasCylinderCheckInfos, cph, i);vehicleAndGasCylinderAndGasCylinderCheckInfos.add(vehicleAndGasCylinderAndGasCylinderCheckInfo);}}else{BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息","气瓶定检信息", "查询", 0, 1, "未找到气瓶定检数据!" + CALLER);}}page.setList(vehicleAndGasCylinderAndGasCylinderCheckInfos);page.setResultCode(200);logger.writeLog(logger.LOG_LEVEL_DEBUG, logger.getExitMethodHint());BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime, DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息", "气瓶定检信息","查询", 1, 1, "" + CALLER);}catch (Exception e){BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime, DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息", "气瓶定检信息","查询", 0, 1, "" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR, "" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR,logger.getExceptionMethodHint(), e);}finally{logger.writeLog(logger.LOG_LEVEL_DEBUG, logger.getExitMethodHint());return page;}}/*** Description: 查询数据(修改详情[获取图片])** @param gasCylinderCheckInfoId 气瓶定检id* @return Page*/@RequestMapping(value = "/config/showAdd-GasCylinderCheckInfoBytsByGasCylinderCheckInfoId", produces = "application/json;charset=UTF-8")@ResponseBodypublic Page GasCylinderCheckInfoBytsByGasCylinderCheckInfoId(HttpServletRequest request, Integer gasCylinderCheckInfoId){String startTime = DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss");String CALLER = "GasCylinderCheckInfoController_GasCylinderCheckInfoBytsByGasCylinderCheckInfoId";Page page = new Page();try{GasCylinderCheckInfo gasCylinderCheckInfo = gasCylinderCheckInfoService.selectByPrimaryKey(CALLER, gasCylinderCheckInfoId);if (null != gasCylinderCheckInfo){page.setResultCode(200);page.getList().add(gasCylinderCheckInfo);BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息", "气瓶定检信息","气瓶定检详情", 1, 1, "显示图片!" + CALLER);}else{page.setResultCode(505);page.setFailDesc("未获取到定检信息!");}}catch (Exception e){BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime, DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息", "气瓶定检信息","气瓶定检详情", 0, 1, "显示图片!" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR, "" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR,logger.getExceptionMethodHint(), e);}finally{logger.writeLog(logger.LOG_LEVEL_DEBUG, logger.getExitMethodHint());return page;}};/*** Description: 查询数据(修改详情)** @param gasCylinderCheckInfoId 气瓶定检id* @return String ("/gm/air_parameter_g")*/@RequestMapping(value = "/config/Update-GasCylinderCheckInfo", produces = "application/json;charset=UTF-8")public String showGasCylinderCheckInfo(HttpServletRequest request,Integer gasCylinderCheckInfoId){String startTime = DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss");String CALLER = "GasCylinderCheckInfoController_/config/Update-GasCylinderCheckInfo ";try{// 创建(车辆 气瓶 气瓶定检信息 )对象VehicleAndGasCylinderAndGasCylinderCheckInfo vehicleAndGasCylinderAndGasCylinderCheckInfo = new VehicleAndGasCylinderAndGasCylinderCheckInfo();if (null != gasCylinderCheckInfoId && 0 < gasCylinderCheckInfoId){GasCylinderCheckInfo gasCylinderCheckInfo = gasCylinderCheckInfoService.selectByPrimaryKey(CALLER, gasCylinderCheckInfoId);/** GasCylinderCheckInfo gasCylinderCheckInfo =* gasCylinderCheckInfoService.* getPictureDataByGasCylinderCheckInfo(CALLER,* gasCylinderCheckInfo1);*/if (null != gasCylinderCheckInfo){vehicleAndGasCylinderAndGasCylinderCheckInfo.setGasCylinderCheckInfo(gasCylinderCheckInfo);GasCylinder gasCylinder = gasService.selectByPrimaryKey(CALLER, gasCylinderCheckInfo.getGascylinderid());if (null != gasCylinder){vehicleAndGasCylinderAndGasCylinderCheckInfo.setGasCylinder(gasCylinder);Vehicle vehicle = cmServiceFactory.getVmVehicleService().selectByPrimaryKey(CALLER,gasCylinder.getVehid().intValue());if (null != vehicle){vehicleAndGasCylinderAndGasCylinderCheckInfo.setVehicle(vehicle);}else{BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request),"气瓶信息", "气瓶定检信息", "气瓶定检详情", 0, 1,"从数据库中未获取到车辆信息" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR,"" + CALLER);}}else{BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息","气瓶定检信息", "气瓶定检详情", 0, 1,"从数据库中未获取到气瓶定检信息" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR, "" + CALLER);}}else{BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息","气瓶定检信息", "气瓶定检详情", 0, 1, "从数据库中未获取到气瓶信息" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR, "" + CALLER);}request.setAttribute("vehicleAndGasCylinderAndGasCylinderCheckInfo",vehicleAndGasCylinderAndGasCylinderCheckInfo);logger.writeLog(logger.LOG_LEVEL_DEBUG,logger.getExitMethodHint());BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息", "气瓶定检信息","气瓶定检详情", 1, 1, "" + CALLER);}else{BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息", "气瓶定检信息","气瓶定检详情", 0, 1, "未接收到气瓶定检参数id" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR, "" + CALLER);}}catch (Exception e){BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime, DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息", "气瓶定检信息","气瓶定检详情", 0, 1, "" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR, "" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR,logger.getExceptionMethodHint(), e);}finally{logger.writeLog(logger.LOG_LEVEL_DEBUG, logger.getExitMethodHint());return "/gm/air_parameter_g";/* return "/gm/Update-GasCylinderCheckInfo"; */}}/*** Description:添加气瓶定检信息(ajax WEB-INF/jsp/gm/add-GasCylinderCheckInfo.jsp);** @param gasCylinderCheckInfo           气瓶定检对象* @param gasCylinderId                  气瓶id* @param cph                            车辆牌照* @param GasCylinderNum                 气瓶编码* @param positionnum                    气瓶位置编号* @param manufacturingsupervisioninsurl 质量说明书URL* @param orderByClause                  字段排序* @return page*/@RequestMapping(value = "/config/add-GasCylinderCheckInfo", produces = "application/json;charset=UTF-8")@ResponseBodypublic Page addGasCylinderCheckInfo(HttpServletRequest request,GasCylinderCheckInfo gasCylinderCheckInfo,@RequestParam("num") Integer gasCylinderId, String cph,String GasCylinderNum, String positionnum,String manufacturingsupervisioninsurl, String orderByClause){String startTime = DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss");String CALLER = "GasCylinderCheckInfoController_/config/add-GasCylinderCheckInfo ";Integer a = gasCylinderId;Page page = new Page();try{// 排序 默认idif (null == orderByClause || 0 == orderByClause.length()){orderByClause = "ID DESC";}if (null != manufacturingsupervisioninsurl&& 0 < manufacturingsupervisioninsurl.length()){gasCylinderCheckInfo.setQualityspecifyurl(manufacturingsupervisioninsurl);}page = gasCylinderCheckInfoService.addGasCylinderCheckInfo(CALLER,request, gasCylinderCheckInfo, gasCylinderId, cph,GasCylinderNum, positionnum, orderByClause);}catch (Exception e){page.setResultCode(502);page.setFailDesc("请检查!");BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime, DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息", "气瓶定检信息","添加定检信息", 0, 1, "" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR, "" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR,logger.getExceptionMethodHint(), e);}finally{logger.writeLog(logger.LOG_LEVEL_DEBUG, logger.getExitMethodHint());return page;}}/*** Description:修改气瓶定检信息;** @param gasCylinderCheckInfo           气瓶定检信息* @param cph                            车辆牌照* @param positionnum                    气瓶位置编号* @param num                            气瓶编号* @param manufacturingsupervisioninsurl 质量说明书URL* @param orderByClause                  字段排序* @return page*/@RequestMapping(value = "/config/Update-GasCylinderCheckInfoT", produces = "application/json;charset=UTF-8")@ResponseBodypublic Page updateGasCylinderCheckInfo(HttpServletRequest request,GasCylinderCheckInfo gasCylinderCheckInfo, String cph, String num,String positionnum, String manufacturingsupervisioninsurl,String orderByClause){String startTime = DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss");String CALLER = "GasCylinderCheckInfoController_/config/Update-GasCylinderCheckInfoT ";Page page = new Page();// 排序 默认idif (null == orderByClause || 0 == orderByClause.length()){orderByClause = "ID DESC";}try{if (null != manufacturingsupervisioninsurl&& 0 < manufacturingsupervisioninsurl.length()){gasCylinderCheckInfo.setQualityspecifyurl(manufacturingsupervisioninsurl);}page = gasCylinderCheckInfoService.updateGasCylinderCheckInfo(CALLER, request, gasCylinderCheckInfo, cph, num,positionnum, orderByClause);/** page =* gasCylinderCheckInfoService.addGasCylinderCheckInfo(CALLER,* request, gasCylinderCheckInfo, gasCylinderId, cph,* GasCylinderNum, positionnum);*/}catch (Exception e){BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime, DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息", "气瓶定检信息","修改气瓶定检信息", 0, 1, "" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR, "" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR,logger.getExceptionMethodHint(), e);}finally{logger.writeLog(logger.LOG_LEVEL_DEBUG, logger.getExitMethodHint());return page;}}/*** Description:删除气瓶定检信息;** @param id 气瓶定检信息id* @return page*/@RequestMapping(value = "/config/delete-GasCylinderCheckInfo", produces = "application/json;charset=UTF-8")@ResponseBodypublic Page deleteGasCylinderCheckInfo(HttpServletRequest request,Integer id){String startTime = DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss");String CALLER = "GasCylinderCheckInfoController_/config/delete-GasCylinderCheckInfo";Page page = new Page();try{if (null != id && 0 < id){int i = 0;/** gasCylinderCheckInfoService.* deletePictureDataByGasCylinderCheckInfo(CALLER,id);*/i = gasCylinderCheckInfoService.deleteByPrimaryKey(CALLER, id);if (0 < i){BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息","气瓶定检信息", "修改气瓶定检信息/删除气瓶定检信息", 1, 1,"气瓶定检信息删除失败,请检查数据库" + CALLER);page.setResultCode(200);page.setFailDesc("气瓶定检信息删除成功!");}else{BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息","气瓶定检信息", "修改气瓶定检信息/删除气瓶定检信息", 0, 1,"气瓶定检信息删除失败,请检查数据库" + CALLER);page.setResultCode(505);page.setFailDesc("气瓶定检信息删除失败!");return page;}}else{BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息", "气瓶定检信息","修改气瓶定检信息/删除气瓶定检信息", 0, 1,"气瓶定检信息删除失败,未获取到页面传来的气瓶定检id参数!" + CALLER);page.setResultCode(505);page.setFailDesc("气瓶定检信息删除失败!");return page;}}catch (Exception e){BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime, DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息", "气瓶定检信息","修改气瓶定检信息/删除气瓶定检信息", 0, 1, "系统异常删除气瓶定检信息失败!" + CALLER);page.setResultCode(505);page.setFailDesc("系统异常删除气瓶定检信息失败!");logger.writeLog(logger.LOG_LEVEL_ERROR, "" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR,logger.getExceptionMethodHint(), e);}finally{logger.writeLog(logger.LOG_LEVEL_DEBUG, logger.getExitMethodHint());return page;}}//==============================文件上传======================================/*** 产品合格证文件上传*/@RequestMapping(value = "/config/create-AllGasCylinderCheckInfoFileurlFileUpload", method = RequestMethod.POST)@ResponseBodypublic Page AllGasCylinderCheckInfoProductqualifyurlFileUpload(@RequestParam("productqualifyurlFile1") List<CommonsMultipartFile> files,HttpServletRequest request) throws IOException{String CALLER = "GasCylinderCheckInfoController_/config/create-AllGasCylinderCheckInfoFileurlFileUpload ";String startTime = DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss");String fileName = "";String fileType = "";Page page = new Page();String urls = "";try{if (null != files && 0 < files.size()){for (int i = 0; i < files.size(); i++){if (!files.get(i).isEmpty()){// 文件保存路径CommonsMultipartFile file = (CommonsMultipartFile) files.get(i);fileName = file.getOriginalFilename();if (null != fileName && 0 < fileName.length()){fileType = fileName.substring(fileName.lastIndexOf(".") + 1);}String url = OSSUploadUtil.uploadFile(file, fileType);System.out.println(url);if (null != url && 0 < url.length()){urls += url + ",";}else{page.setFailDesc("图片上传不成功!");page.setResultCode(505);}}}if (null != urls && 0 < urls.length()){page.setFieldString(urls);page.setFailDesc("图片上传成功!");page.setResultCode(200);}}else{page.setFailDesc("未获取到文件信息!");page.setResultCode(505);}}catch (Exception e){e.printStackTrace();BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime, DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息", "气瓶定检信息","增加气瓶定检信息/文件上传", 0, 1, "系统异常文件上传失败!" + CALLER);}finally{return page;}}/***质量证书文件上传*/@RequestMapping(value = "/config/create-AllGasCylinderCheckInfoQualitycertificateurlFileUpload", method = RequestMethod.POST)@ResponseBodypublic Page AllGasCylinderCheckInfoQualitycertificateurlFileUpload(@RequestParam("qualitycertificateurlFile2") List<CommonsMultipartFile> files,HttpServletRequest request) throws IOException{String CALLER = "GasCylinderCheckInfoController_/config/create-AllGasCylinderCheckInfoFileurlFileUpload ";String startTime = DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss");String fileName = "";String fileType = "";Page page = new Page();String urls = "";try{if (null != files && 0 < files.size()){for (int i = 0; i < files.size(); i++){if (!files.get(i).isEmpty()){// 文件保存路径CommonsMultipartFile file = (CommonsMultipartFile) files.get(i);fileName = file.getOriginalFilename();if (null != fileName && 0 < fileName.length()){fileType = fileName.substring(fileName.lastIndexOf(".") + 1);}String url = OSSUploadUtil.uploadFile(file, fileType);System.out.println(url);if (null != url && 0 < url.length()){urls += url + ",";}else{page.setFailDesc("图片上传不成功!");page.setResultCode(505);}}}if (null != urls && 0 < urls.length()){page.setFieldString(urls);page.setFailDesc("图片上传成功!");page.setResultCode(200);}}else{page.setFailDesc("未获取到文件信息!");page.setResultCode(505);}}catch (Exception e){e.printStackTrace();BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime, DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息", "气瓶定检信息","增加气瓶定检信息/文件上传", 0, 1, "系统异常文件上传失败!" + CALLER);}finally{return page;}}/*** 使用说明书文件上传*/
@RequestMapping(value = "/config/create-AllGasCylinderCheckInfoInstructionmanualurlUpload", method = RequestMethod.POST)
@ResponseBody
public Page AllGasCylinderCheckInfoInstructionmanualurlFileUpload(@RequestParam("instructionmanualurlFile2") List<CommonsMultipartFile> files,HttpServletRequest request) throws IOException
{String CALLER = "GasCylinderCheckInfoController_/config/create-AllGasCylinderCheckInfoFileurlFileUpload ";String startTime = DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss");String fileName = "";String fileType = "";Page page = new Page();String urls = "";try{if (null != files && 0 < files.size()){for (int i = 0; i < files.size(); i++){if (!files.get(i).isEmpty()){// 文件保存路径CommonsMultipartFile file = (CommonsMultipartFile) files.get(i);fileName = file.getOriginalFilename();if (null != fileName && 0 < fileName.length()){fileType = fileName.substring(fileName.lastIndexOf(".") + 1);}String url = OSSUploadUtil.uploadFile(file, fileType);System.out.println(url);if (null != url && 0 < url.length()){urls += url + ",";}else{page.setFailDesc("图片上传不成功!");page.setResultCode(505);}}}if (null != urls && 0 < urls.length()){page.setFieldString(urls);page.setFailDesc("图片上传成功!");page.setResultCode(200);}}else{page.setFailDesc("未获取到文件信息!");page.setResultCode(505);}}catch (Exception e){e.printStackTrace();BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime, DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息", "气瓶定检信息","增加气瓶定检信息/文件上传", 0, 1, "系统异常文件上传失败!" + CALLER);}finally{return page;}
}/*** 检验报告文件上传*/@RequestMapping(value = "/config/create-AllGasCylinderCheckInspectereporturlUpload", method = RequestMethod.POST)@ResponseBodypublic Page AllGasCylinderCheckInspectereporturlFileUpload(@RequestParam("inspectereporturlFile2") List<CommonsMultipartFile> files,HttpServletRequest request) throws IOException{String CALLER = "GasCylinderCheckInfoController_/config/create-AllGasCylinderCheckInfoFileurlFileUpload ";String startTime = DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss");String fileName = "";String fileType = "";Page page = new Page();String urls = "";try{if (null != files && 0 < files.size()){for (int i = 0; i < files.size(); i++){if (!files.get(i).isEmpty()){// 文件保存路径CommonsMultipartFile file = (CommonsMultipartFile) files.get(i);fileName = file.getOriginalFilename();if (null != fileName && 0 < fileName.length()){fileType = fileName.substring(fileName.lastIndexOf(".") + 1);}String url = OSSUploadUtil.uploadFile(file, fileType);System.out.println(url);if (null != url && 0 < url.length()){urls += url + ",";}else{page.setFailDesc("图片上传不成功!");page.setResultCode(505);}}}if (null != urls && 0 < urls.length()){page.setFieldString(urls);page.setFailDesc("图片上传成功!");page.setResultCode(200);}}else{page.setFailDesc("未获取到文件信息!");page.setResultCode(505);}}catch (Exception e){e.printStackTrace();BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime, DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息", "气瓶定检信息","增加气瓶定检信息/文件上传", 0, 1, "系统异常文件上传失败!" + CALLER);}finally{return page;}}/*** 日常检验记录文件上传*/@RequestMapping(value = "/config/create-AllGasCylinderCheckDailyinspectrecordurlUpload", method = RequestMethod.POST)@ResponseBodypublic Page AllGasCylinderCheckDailyinspectrecordurlFileUpload(@RequestParam("dailyinspectrecordurlFile2") List<CommonsMultipartFile> files,HttpServletRequest request) throws IOException{String CALLER = "GasCylinderCheckInfoController_/config/create-AllGasCylinderCheckInfoFileurlFileUpload ";String startTime = DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss");String fileName = "";String fileType = "";Page page = new Page();String urls = "";try{if (null != files && 0 < files.size()){for (int i = 0; i < files.size(); i++){if (!files.get(i).isEmpty()){// 文件保存路径CommonsMultipartFile file = (CommonsMultipartFile) files.get(i);fileName = file.getOriginalFilename();if (null != fileName && 0 < fileName.length()){fileType = fileName.substring(fileName.lastIndexOf(".") + 1);}String url = OSSUploadUtil.uploadFile(file, fileType);System.out.println(url);if (null != url && 0 < url.length()){urls += url + ",";}else{page.setFailDesc("图片上传不成功!");page.setResultCode(505);}}}if (null != urls && 0 < urls.length()){page.setFieldString(urls);page.setFailDesc("图片上传成功!");page.setResultCode(200);}}else{page.setFailDesc("未获取到文件信息!");page.setResultCode(505);}}catch (Exception e){e.printStackTrace();BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime, DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息", "气瓶定检信息","增加气瓶定检信息/文件上传", 0, 1, "系统异常文件上传失败!" + CALLER);}finally{return page;}}/*** Description:气瓶定检查询分页** @param vehicleAndGasCylinderAndGasCylinderCheckInfos (车辆、气瓶、气瓶定检信息)封装对象* @param gasCylinderCheckInfos                         (气瓶定检信息集合)* @param cph                                           车牌号* @param i                                             遍历索引* @param*/public VehicleAndGasCylinderAndGasCylinderCheckInfo getVehicleAndGasCylinderAndGasCylinderCheckInfo(String CALLER, HttpServletRequest request,List<VehicleAndGasCylinderAndGasCylinderCheckInfo> vehicleAndGasCylinderAndGasCylinderCheckInfos,List<GasCylinderCheckInfo> gasCylinderCheckInfos, String cph, int i)throws Exception{String startTime = DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss");VehicleAndGasCylinderAndGasCylinderCheckInfo vehicleAndGasCylinderAndGasCylinderCheckInfo = new VehicleAndGasCylinderAndGasCylinderCheckInfo();vehicleAndGasCylinderAndGasCylinderCheckInfo.setGasCylinderCheckInfo(gasCylinderCheckInfos.get(i));if (null != gasCylinderCheckInfos.get(i).getGascylinderid()&& 0 < gasCylinderCheckInfos.get(i).getGascylinderid()){// 获取气瓶信息GasCylinderExample gasCylinderExample = new GasCylinderExample();GasCylinderExample.Criteria criteria1 = gasCylinderExample.createCriteria();criteria1.andIdEqualTo(gasCylinderCheckInfos.get(i).getGascylinderid());List<GasCylinder> gasCylinders = gasService.selectByExample(CALLER,gasCylinderExample);if (0 < gasCylinders.size()){vehicleAndGasCylinderAndGasCylinderCheckInfo.setGasCylinder(gasCylinders.get(0));// 获取车辆信息VehicleExample vehicleExample = new VehicleExample();VehicleExample.Criteria criteria = vehicleExample.createCriteria();if (null != gasCylinders.get(0).getVehid()&& 0 < gasCylinders.get(0).getVehid()){criteria.andIdEqualTo(gasCylinders.get(0).getVehid().intValue());}else{criteria.andIdEqualTo(0);}List<Vehicle> vehicles = cmServiceFactory.getVmVehicleService().selectByExample(CALLER, vehicleExample);if (0 < vehicles.size()){for (int j = 0; j < vehicles.size(); j++){vehicleAndGasCylinderAndGasCylinderCheckInfo.setVehicle(vehicles.get(0));logger.writeLog(logger.LOG_LEVEL_DEBUG,logger.getExitMethodHint());}}else{Vehicle vehicle = new Vehicle();vehicle.setCph("无");vehicle.setOwnno("无");vehicleAndGasCylinderAndGasCylinderCheckInfo.setVehicle(vehicle);BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息","气瓶定检信息", "查询", 0, 1, "未找到车辆数据" + CALLER);}}else{GasCylinder gasCylinder = new GasCylinder();gasCylinder.setNum("-1");gasCylinder.setPositionnum("-1");vehicleAndGasCylinderAndGasCylinderCheckInfo.setGasCylinder(gasCylinder);BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息", "气瓶定检信息","查询", 0, 1, "未找到气瓶数据" + CALLER);}}return vehicleAndGasCylinderAndGasCylinderCheckInfo;}/*** Description: 文件下载功能** @param request* @param response* @throws Exception*/@RequestMapping("/down")public void down(HttpServletRequest request, HttpServletResponse response)throws Exception{// 模拟文件,myfile.txt为需要下载的文件String fileName = request.getSession().getServletContext().getRealPath("upload") + "/myfile.txt";// 获取输入流InputStream bis = new BufferedInputStream(new FileInputStream(new File(fileName)));// 假如以中文名下载的话String filename = "下载文件.txt";// 转码,免得文件名中文乱码filename = URLEncoder.encode(filename, "UTF-8");// 设置文件下载头response.addHeader("Content-Disposition","attachment;filename=" + filename);// 1.设置文件ContentType类型,这样设置,会自动判断下载文件类型response.setContentType("multipart/form-data");BufferedOutputStream out = new BufferedOutputStream(response.getOutputStream());int len = 0;while ((len = bis.read()) != -1){out.write(len);out.flush();}out.close();}/*** Description: 导出文件(WEB-INF/jsp/gm/air_test_info.jsp)** @param cph 车辆条件做查询条件* @param num 气瓶编号* @return String null*/@RequestMapping(value = "/config/export-GasCylinderCheckInfoExcel", produces = "application/json;charset=UTF-8")@ResponseBodypublic String exportAllGasCylinderCheckInfoExcel(HttpServletRequest request,HttpServletResponse response,@RequestParam(value = "cph", required = false) String cph,@RequestParam(value = "num", required = false) String num,@RequestParam(value = "positionnum", required = false) String positionnum,@RequestParam(value = "firsttestdate1", required = false) String firsttestdate1,@RequestParam(value = "firsttestdate2", required = false) String firsttestdate2,@RequestParam(value = "orderByClause", required = false) String orderByClause){String fileName = "气瓶定检";// 排序 默认idif (null == orderByClause || 0 == orderByClause.length()){orderByClause = "testdate DESC";}String startTime = DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss");String CALLER = "GasCylinderCheckInfoController_/config/export-GasCylinderCheckInfoExcel ";// 创建分页对象Page page = new Page();// 创建气瓶定检信息的List容器List<GasCylinderCheckInfo> gasCylinderCheckInfos = new ArrayList<GasCylinderCheckInfo>();try{request.setCharacterEncoding("utf-8");// 如果页面有传入气瓶参数做查询条件,需要获取车队IDList<Integer> vehicleIds = new ArrayList<Integer>();// 获取气瓶idList<Integer> GasCylinderIds = new ArrayList<Integer>();// 存放关联数据的集合List<VehicleAndGasCylinderAndGasCylinderCheckInfo> vehicleAndGasCylinderAndGasCylinderCheckInfos = new ArrayList<VehicleAndGasCylinderAndGasCylinderCheckInfo>();// 通过车辆查条件查询数据if ((null != cph && 0 < cph.trim().length())){/* cph = new String(cph.getBytes("iso8859-1"),"utf-8"); */cph = URLDecoder.decode(cph, "UTF-8");VehicleExample vehicleExample = new VehicleExample();VehicleExample.Criteria vehicleExampleCriteria = vehicleExample.createCriteria();// 车牌号vehicleExampleCriteria.andCphEqualTo(cph.trim());List<Vehicle> vehicles = cmServiceFactory.getVmVehicleService().selectByExample(CALLER, vehicleExample);if (0 < vehicles.size()){for (int j = 0; j < vehicles.size(); j++){// 通过车辆条件获取到已配置气瓶的车辆id(车辆id放容器中用做获取气瓶信息的条件)vehicleIds.add(vehicles.get(j).getId().intValue());}}else{vehicleIds.add(0);}}/** =================================================================*/// 页面有传入气瓶编号或气瓶位置编号做查询条件// 创建气瓶查询条件if ((null != num && 0 < num.trim().length())|| (null != positionnum && 0 < positionnum.trim().length())|| (0 < vehicleIds.size())){GasCylinderExample gasCylinderExample = new GasCylinderExample();GasCylinderExample.Criteria criteria2 = gasCylinderExample.createCriteria();// 气瓶编号numif (null != num && 0 < num.trim().length()){criteria2.andNumEqualTo(num.trim());}// 气瓶位置编号positionnumif (null != positionnum && 0 < positionnum.trim().length()){/** positionnum = new String(* positionnum.getBytes("iso8859-1"),"utf-8");*/criteria2.andPositionnumEqualTo(positionnum.trim());}// 通过车辆id获取已经配置的配置信息if (0 < vehicleIds.size()){List<Long> vehicleIdsL = new ArrayList<Long>();for (int i = 0; i < vehicleIds.size(); i++){vehicleIdsL.add(vehicleIds.get(i).longValue());}if (0 < vehicleIdsL.size()){criteria2.andVehidIn(vehicleIdsL);}}// 必须显示已安装的气瓶,排除(Vehid= -1状态 为未安装的气瓶)long i = -1;/* criteria2.andVehidNotEqualTo(i); */List<GasCylinder> gasCylinders = gasService.selectByExample(CALLER, gasCylinderExample);if (0 < gasCylinders.size()){for (int j = 0; j < gasCylinders.size(); j++){GasCylinderIds.add(gasCylinders.get(j).getId());}}else{GasCylinder gasCylinder = new GasCylinder();gasCylinder.setNum("无气瓶信息");// 当气瓶编号未查询到数据时,页面不应当有数据,所以这边的车辆ID集合中写入0;GasCylinderIds.add(0);}}/** =================================================================*/// 构造气瓶定检查询条件GasCylinderCheckInfoExample gasCylinderCheckInfoExample = new GasCylinderCheckInfoExample();GasCylinderCheckInfoExample.Criteria criteria2 = gasCylinderCheckInfoExample.createCriteria();if (0 < GasCylinderIds.size()){criteria2.andGascylinderidIn(GasCylinderIds);}// 按日期查询if (null != firsttestdate1 && 0 < firsttestdate1.length()){criteria2.andTestdateEqualTo(firsttestdate1);}/** if(null != firsttestdate1 && 0 < firsttestdate1.length() && null* != firsttestdate2 && 0 < firsttestdate2.length()){* criteria2.andFirsttestdateBetween(firsttestdate1,firsttestdate2);* } if((null != firsttestdate1 && 0 < firsttestdate1.length()) &&* (null == firsttestdate2 || 0 == firsttestdate2.length())){* criteria2.andFirsttestdateEqualTo(firsttestdate1); } if((null !=* firsttestdate2 && 0 < firsttestdate2.length()) && (null ==* firsttestdate1 || 0 == firsttestdate1.length())){* criteria2.andFirsttestdateEqualTo(firsttestdate2); }*/gasCylinderCheckInfos = gasCylinderCheckInfoService.selectByExample(CALLER, gasCylinderCheckInfoExample, orderByClause);if (0 < gasCylinderCheckInfos.size()){for (int i = 0; i < gasCylinderCheckInfos.size(); i++){VehicleAndGasCylinderAndGasCylinderCheckInfo vehicleAndGasCylinderAndGasCylinderCheckInfo = getVehicleAndGasCylinderAndGasCylinderCheckInfo(CALLER, request,vehicleAndGasCylinderAndGasCylinderCheckInfos,gasCylinderCheckInfos, cph, i);vehicleAndGasCylinderAndGasCylinderCheckInfos.add(vehicleAndGasCylinderAndGasCylinderCheckInfo);}/** ============================================Excel导出==========*/// 创建存放需要导出数据的map容器Map<String, Object> vehicleAndGasCylinderAndGasCylinderCheckInfopMap = new HashMap<String, Object>();// 创建存放map的list容器List<Map<String, Object>> vehicleAndVehGroupsList = new ArrayList<Map<String, Object>>();vehicleAndGasCylinderAndGasCylinderCheckInfopMap.put("sheetName", "sheet1");vehicleAndVehGroupsList.add(vehicleAndGasCylinderAndGasCylinderCheckInfopMap);if (0 < vehicleAndGasCylinderAndGasCylinderCheckInfos.size()){// 导出方法excelOut(request, response, fileName,vehicleAndGasCylinderAndGasCylinderCheckInfos,vehicleAndVehGroupsList);}else{page.setResultCode(505);page.setFailDesc("未获得数据!");BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息","气瓶定检信息", "导出", 0, 1, "未获得数据!" + CALLER);}}else{BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息", "气瓶定检信息","导出", 0, 1, "未找到气瓶定检数据!" + CALLER);}page.setResultCode(200);logger.writeLog(logger.LOG_LEVEL_DEBUG, logger.getExitMethodHint());BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime, DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息", "气瓶定检信息","导出", 1, 1, "" + CALLER);}catch (Exception e){BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime, DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息", "气瓶定检信息","导出", 0, 1, "" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR, "" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR,logger.getExceptionMethodHint(), e);}finally{logger.writeLog(logger.LOG_LEVEL_DEBUG, logger.getExitMethodHint());return null;}}// excel导出private void excelOut(HttpServletRequest request,HttpServletResponse response, String fileName,List<VehicleAndGasCylinderAndGasCylinderCheckInfo> vehicleAndGasCylinderAndGasCylinderCheckInfos,List<Map<String, Object>> vehicleAndVehGroupsList)throws IOException{Map<String, Object> vehicleAndGasCylinderAndGasCylinderCheckInfopMap;for (int i = 0; i < vehicleAndGasCylinderAndGasCylinderCheckInfos.size(); i++){vehicleAndGasCylinderAndGasCylinderCheckInfopMap = new HashMap<String, Object>();vehicleAndGasCylinderAndGasCylinderCheckInfopMap.put("cph",vehicleAndGasCylinderAndGasCylinderCheckInfos.get(i).getVehicle().getCph()); // 车牌号vehicleAndGasCylinderAndGasCylinderCheckInfopMap.put("num",vehicleAndGasCylinderAndGasCylinderCheckInfos.get(i).getGasCylinder().getNum()); // 气瓶编号if ("待配置气瓶!".equals(vehicleAndGasCylinderAndGasCylinderCheckInfos.get(i).getGasCylinder().getPositionnum())){vehicleAndGasCylinderAndGasCylinderCheckInfopMap.put("positionnum", "气瓶已经卸载!"); // 气瓶位置编号}else{vehicleAndGasCylinderAndGasCylinderCheckInfopMap.put("positionnum",vehicleAndGasCylinderAndGasCylinderCheckInfos.get(i).getGasCylinder().getPositionnum()); // 气瓶位置编号}vehicleAndGasCylinderAndGasCylinderCheckInfopMap.put("testdate",vehicleAndGasCylinderAndGasCylinderCheckInfos.get(i).getGasCylinderCheckInfo().getTestdate()); // 首次检验日期vehicleAndGasCylinderAndGasCylinderCheckInfopMap.put("testunit",vehicleAndGasCylinderAndGasCylinderCheckInfos.get(i).getGasCylinderCheckInfo().getTestunit()); // 首次检验单位vehicleAndGasCylinderAndGasCylinderCheckInfopMap.put("testresult",vehicleAndGasCylinderAndGasCylinderCheckInfos.get(i).getGasCylinderCheckInfo().getTestresult()); // 首次检验结果/** vehicleAndGasCylinderAndGasCylinderCheckInfopMap.put(* "recenttestdate",* vehicleAndGasCylinderAndGasCylinderCheckInfos.get(i).* getGasCylinderCheckInfo().getRecenttestdate()); //最近检验日期* * * vehicleAndGasCylinderAndGasCylinderCheckInfopMap.put(* "recentinspectunit",* vehicleAndGasCylinderAndGasCylinderCheckInfos.get(i).* getGasCylinderCheckInfo().getRecentinspectunit()); //最近检验单位*** * * vehicleAndGasCylinderAndGasCylinderCheckInfopMap.put(* "recentinspectresult",* vehicleAndGasCylinderAndGasCylinderCheckInfos.get(i).* getGasCylinderCheckInfo().getRecentinspectresult()); //最近检验结果* * *//** vehicleAndGasCylinderAndGasCylinderCheckInfopMap.put(* "nexttesttime",* vehicleAndGasCylinderAndGasCylinderCheckInfos.get(i).* getGasCylinderCheckInfo().getNexttesttime()); //下次定检日期*/vehicleAndVehGroupsList.add(vehicleAndGasCylinderAndGasCylinderCheckInfopMap);}String[][] columnNames ={{},{ "车牌号", "气瓶编号", "位置编号", "检验日期", "检验单位", "检验结果" } }; // 列名String[] keys ={ "cph", "num", "positionnum", "testdate", "testunit", "testresult" }; // map中的keyByteArrayOutputStream os = new ByteArrayOutputStream();ExcelUtil.createWorkBook(vehicleAndVehGroupsList, keys, columnNames).write(os);ExcelUtil.inputExcel(request, response, fileName, os);}/*=================主页文件上传功能(上传完图片直接将URL更新数到据库)、上传图片==================================*//*** Description:主页文件上传功能(上传完图片直接将URL更新数到据库)、上传图片(产品合格证url)* 此图片保存后需要,将其它同气瓶编号的气瓶信息一并同步成同一图片;* @return page* @throws IOException* @RequestParam("productqualifyurlFile") CommonsMultipartFile file*/@RequestMapping(value = "/config/add-GasCylinderCheckInfoProductqualifyurlUpload1", method = RequestMethod.POST)@ResponseBodypublic Page GasCylinderCheckInfoProductqualifyurlUpload1(@RequestParam("file") List<CommonsMultipartFile> files,HttpServletRequest request, Integer gasCylinderCheckInfoId,Integer ii) throws IOException{/** =====================================================================*/String startTime = DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss");String CALLER = "GasCylinderCheckInfoController_/config/add-GasCylinderCheckInfoProductqualifyurlUpload1 ";String fileName = "";String fileType = "";Page page = new Page();String urls = "";try{if (null != files && 0 < files.size()){for (int i = 0; i < files.size(); i++){if (!files.get(i).isEmpty()){// 文件保存路径CommonsMultipartFile file = (CommonsMultipartFile) files.get(i);fileName = file.getOriginalFilename();if (null != fileName && 0 < fileName.length()){fileType = fileName.substring(fileName.lastIndexOf(".") + 1);}String url = OSSUploadUtil.uploadFile(file, fileType);if (null != url && 0 < url.length()){urls += url + ",";System.out.println(url);}else{page.setFailDesc("图片上传不成功!");page.setResultCode(505);return page;}}}if (null != gasCylinderCheckInfoId&& 0 < gasCylinderCheckInfoId){if (null != urls && 0 < urls.length()){GasCylinderCheckInfo gasCylinderCheckInfo = new GasCylinderCheckInfo();gasCylinderCheckInfo.setId(gasCylinderCheckInfoId);gasCylinderCheckInfo.setProductqualifyurl(urls.toString());int i = gasCylinderCheckInfoService.updateImageByPrimaryKeySelective(CALLER,gasCylinderCheckInfo);if (0 < i){page.setResultCode(200);page.setFailDesc("上传成功!");BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request),"气瓶信息", "气瓶定检信息", "点击上传(检验报告)", 1, 1,"" + CALLER);}else{page.setResultCode(505);page.setFailDesc("上传失败!");BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request),"气瓶信息", "气瓶定检信息", "点击上传", 0, 1,"上传失败!" + CALLER);}}else{page.setResultCode(505);page.setFailDesc("上传失败,未返回文件路径!");BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息","气瓶定检信息", "点击上传", 0, 1, "未返回文件路径" + CALLER);}}else{page.setResultCode(505);page.setFailDesc("上传失败,未获得气瓶定检id");BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息","气瓶定检信息", "点击上传", 0, 1, "未获得气瓶定检id" + CALLER);}page.setFieldString(urls);page.setFailDesc("图片上传成功!");page.setResultCode(200);}else{page.setFailDesc("未获取到文件信息!");page.setResultCode(505);}}catch (Exception e){e.printStackTrace();BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime, DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息", "气瓶定检信息","点击上传", 0, 1, "" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR, "" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR,logger.getExceptionMethodHint(), e);}finally{logger.writeLog(logger.LOG_LEVEL_DEBUG, logger.getExitMethodHint());return page;}}/*** Description:主页文件上传功能(上传完图片直接将URL更新数到据库)、上传图片(质量证明书url)** @return page* @throws IOException* @RequestParam("qualitycertificateurlFile") CommonsMultipartFile file*/@RequestMapping(value = "/config/add-GasCylinderCheckInfoQualitycertificateurlUpload1", method = RequestMethod.POST)@ResponseBodypublic Page GasCylinderCheckInfoQualitycertificateurlUpload1(@RequestParam("file") List<CommonsMultipartFile> files,HttpServletRequest request, Integer gasCylinderCheckInfoId,Integer ii) throws IOException{/** =====================================================================*/String startTime = DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss");String CALLER = "GasCylinderCheckInfoController_/config/add-GasCylinderCheckInfoQualitycertificateurlUpload1 ";String fileName = "";String fileType = "";Page page = new Page();String urls = "";try{if (null != files && 0 < files.size()){for (int i = 0; i < files.size(); i++){if (!files.get(i).isEmpty()){// 文件保存路径CommonsMultipartFile file = (CommonsMultipartFile) files.get(i);fileName = file.getOriginalFilename();if (null != fileName && 0 < fileName.length()){fileType = fileName.substring(fileName.lastIndexOf(".") + 1);}String url = OSSUploadUtil.uploadFile(file, fileType);if (null != url && 0 < url.length()){urls += url + ",";System.out.println(url);}else{page.setFailDesc("图片上传不成功!");page.setResultCode(505);return page;}}}if (null != gasCylinderCheckInfoId&& 0 < gasCylinderCheckInfoId){if (null != urls && 0 < urls.length()){GasCylinderCheckInfo gasCylinderCheckInfo = new GasCylinderCheckInfo();gasCylinderCheckInfo.setId(gasCylinderCheckInfoId);gasCylinderCheckInfo.setQualitycertificateurl(urls.toString());int i = gasCylinderCheckInfoService.updateImageByPrimaryKeySelective(CALLER,gasCylinderCheckInfo);if (0 < i){page.setResultCode(200);page.setFailDesc("上传成功!");BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request),"气瓶信息", "气瓶定检信息", "点击上传(检验报告)", 1, 1,"" + CALLER);}else{page.setResultCode(505);page.setFailDesc("上传失败!");BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request),"气瓶信息", "气瓶定检信息", "点击上传", 0, 1,"上传失败!" + CALLER);}}else{page.setResultCode(505);page.setFailDesc("上传失败,未返回文件路径!");BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息","气瓶定检信息", "点击上传", 0, 1, "未返回文件路径" + CALLER);}}else{page.setResultCode(505);page.setFailDesc("上传失败,未获得气瓶定检id");BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息","气瓶定检信息", "点击上传", 0, 1, "未获得气瓶定检id" + CALLER);}page.setFieldString(urls);page.setFailDesc("图片上传成功!");page.setResultCode(200);}else{page.setFailDesc("未获取到文件信息!");page.setResultCode(505);}}catch (Exception e){e.printStackTrace();BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime, DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息", "气瓶定检信息","点击上传", 0, 1, "" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR, "" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR,logger.getExceptionMethodHint(), e);}finally{logger.writeLog(logger.LOG_LEVEL_DEBUG, logger.getExitMethodHint());return page;}}/*** Description:主页文件上传功能(上传完图片直接将URL更新数到据库)、上传图片(质量说明书)** @return page* @throws IOException* @RequestParam("qualityspecifyurlFile") CommonsMultipartFile file*/@RequestMapping(value = "/config/add-GasCylinderCheckInfoQualityspecifyurlUpload1", method = RequestMethod.POST)@ResponseBodypublic Page GasCylinderCheckInfoQualityspecifyurlUpload1(@RequestParam("file") List<CommonsMultipartFile> files,HttpServletRequest request, Integer gasCylinderCheckInfoId,Integer ii) throws IOException{/** =====================================================================*/String startTime = DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss");String CALLER = "GasCylinderCheckInfoController_/config/add-GasCylinderCheckInfoQualityspecifyurlUpload1 ";String fileName = "";String fileType = "";Page page = new Page();String urls = "";try{if (null != files && 0 < files.size()){for (int i = 0; i < files.size(); i++){if (!files.get(i).isEmpty()){// 文件保存路径CommonsMultipartFile file = (CommonsMultipartFile) files.get(i);fileName = file.getOriginalFilename();if (null != fileName && 0 < fileName.length()){fileType = fileName.substring(fileName.lastIndexOf(".") + 1);}String url = OSSUploadUtil.uploadFile(file, fileType);if (null != url && 0 < url.length()){urls += url + ",";System.out.println(url);}else{page.setFailDesc("图片上传不成功!");page.setResultCode(505);return page;}}}if (null != gasCylinderCheckInfoId&& 0 < gasCylinderCheckInfoId){if (null != urls && 0 < urls.length()){GasCylinderCheckInfo gasCylinderCheckInfo = new GasCylinderCheckInfo();gasCylinderCheckInfo.setId(gasCylinderCheckInfoId);gasCylinderCheckInfo.setQualityspecifyurl(urls.toString());int i = gasCylinderCheckInfoService.updateImageByPrimaryKeySelective(CALLER,gasCylinderCheckInfo);if (0 < i){page.setResultCode(200);page.setFailDesc("上传成功!");BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request),"气瓶信息", "气瓶定检信息", "点击上传(检验报告)", 1, 1,"" + CALLER);}else{page.setResultCode(505);page.setFailDesc("上传失败!");BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request),"气瓶信息", "气瓶定检信息", "点击上传", 0, 1,"上传失败!" + CALLER);}}else{page.setResultCode(505);page.setFailDesc("上传失败,未返回文件路径!");BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息","气瓶定检信息", "点击上传", 0, 1, "未返回文件路径" + CALLER);}}else{page.setResultCode(505);page.setFailDesc("上传失败,未获得气瓶定检id");BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息","气瓶定检信息", "点击上传", 0, 1, "未获得气瓶定检id" + CALLER);}page.setFieldString(urls);page.setFailDesc("图片上传成功!");page.setResultCode(200);}else{page.setFailDesc("未获取到文件信息!");page.setResultCode(505);}}catch (Exception e){e.printStackTrace();BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime, DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息", "气瓶定检信息","点击上传", 0, 1, "" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR, "" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR,logger.getExceptionMethodHint(), e);}finally{logger.writeLog(logger.LOG_LEVEL_DEBUG, logger.getExitMethodHint());return page;}}/*** Description:主页文件上传功能(上传完图片直接将URL更新数到据库)、上传图片(使用说明书url)** @return page* @throws IOException* @RequestParam("instructionmanualurlFile") CommonsMultipartFile file*/@RequestMapping(value = "/config/add-GasCylinderCheckInfoInstructionmanualurlUpload1", method = RequestMethod.POST)@ResponseBodypublic Page GasCylinderCheckInfoInstructionmanualurlUpload1(@RequestParam("file") List<CommonsMultipartFile> files,HttpServletRequest request, Integer gasCylinderCheckInfoId,Integer ii) throws IOException{/** =====================================================================*/String startTime = DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss");String CALLER = "GasCylinderCheckInfoController_/config/add-GasCylinderCheckInfoInstructionmanualurlUpload1 ";String fileName = "";String fileType = "";Page page = new Page();String urls = "";try{if (null != files && 0 < files.size()){for (int i = 0; i < files.size(); i++){if (!files.get(i).isEmpty()){// 文件保存路径CommonsMultipartFile file = (CommonsMultipartFile) files.get(i);fileName = file.getOriginalFilename();if (null != fileName && 0 < fileName.length()){fileType = fileName.substring(fileName.lastIndexOf(".") + 1);}String url = OSSUploadUtil.uploadFile(file, fileType);if (null != url && 0 < url.length()){urls += url + ",";System.out.println(url);}else{page.setFailDesc("图片上传不成功!");page.setResultCode(505);return page;}}}if (null != gasCylinderCheckInfoId&& 0 < gasCylinderCheckInfoId){if (null != urls && 0 < urls.length()){GasCylinderCheckInfo gasCylinderCheckInfo = new GasCylinderCheckInfo();gasCylinderCheckInfo.setId(gasCylinderCheckInfoId);gasCylinderCheckInfo.setInstructionmanualurl(urls.toString());int i = gasCylinderCheckInfoService.updateImageByPrimaryKeySelective(CALLER,gasCylinderCheckInfo);if (0 < i){page.setResultCode(200);page.setFailDesc("上传成功!");BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request),"气瓶信息", "气瓶定检信息", "点击上传(检验报告)", 1, 1,"" + CALLER);}else{page.setResultCode(505);page.setFailDesc("上传失败!");BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request),"气瓶信息", "气瓶定检信息", "点击上传", 0, 1,"上传失败!" + CALLER);}}else{page.setResultCode(505);page.setFailDesc("上传失败,未返回文件路径!");BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息","气瓶定检信息", "点击上传", 0, 1, "未返回文件路径" + CALLER);}}else{page.setResultCode(505);page.setFailDesc("上传失败,未获得气瓶定检id");BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息","气瓶定检信息", "点击上传", 0, 1, "未获得气瓶定检id" + CALLER);}page.setFieldString(urls);page.setFailDesc("图片上传成功!");page.setResultCode(200);}else{page.setFailDesc("未获取到文件信息!");page.setResultCode(505);}}catch (Exception e){e.printStackTrace();BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime, DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息", "气瓶定检信息","点击上传", 0, 1, "" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR, "" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR,logger.getExceptionMethodHint(), e);}finally{logger.writeLog(logger.LOG_LEVEL_DEBUG, logger.getExitMethodHint());return page;}}/*** Description:主页文件上传功能(上传完图片直接将URL更新数到据库)、上传图片(检验报告)** @return page* @throws IOException* @RequestParam("inspectereporturlFile") CommonsMultipartFile file*/@RequestMapping(value = "/config/add-GasCylinderCheckInfoInspectereporturlUpload1", method = RequestMethod.POST)@ResponseBodypublic Page GasCylinderCheckInfoInspectereporturlUpload1(@RequestParam("file") List<CommonsMultipartFile> files,HttpServletRequest request, Integer gasCylinderCheckInfoId,Integer ii) throws IOException{/** =====================================================================*/String startTime = DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss");String CALLER = "GasCylinderCheckInfoController_/config/add-GasCylinderCheckInfoInspectereporturlUpload1 ";String fileName = "";String fileType = "";Page page = new Page();String urls = "";try{if (null != files && 0 < files.size()){for (int i = 0; i < files.size(); i++){if (!files.get(i).isEmpty()){// 文件保存路径CommonsMultipartFile file = (CommonsMultipartFile) files.get(i);fileName = file.getOriginalFilename();if (null != fileName && 0 < fileName.length()){fileType = fileName.substring(fileName.lastIndexOf(".") + 1);}String url = OSSUploadUtil.uploadFile(file, fileType);if (null != url && 0 < url.length()){urls += url + ",";System.out.println(url);}else{page.setFailDesc("图片上传不成功!");page.setResultCode(505);return page;}}}if (null != gasCylinderCheckInfoId&& 0 < gasCylinderCheckInfoId){if (null != urls && 0 < urls.length()){GasCylinderCheckInfo gasCylinderCheckInfo = new GasCylinderCheckInfo();gasCylinderCheckInfo.setId(gasCylinderCheckInfoId);gasCylinderCheckInfo.setInspectereporturl(urls.toString());int i = gasCylinderCheckInfoService.updateByPrimaryKeySelective(CALLER,gasCylinderCheckInfo);if (0 < i){page.setResultCode(200);page.setFailDesc("上传成功!");BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request),"气瓶信息", "气瓶定检信息", "点击上传(检验报告)", 1, 1,"" + CALLER);}else{page.setResultCode(505);page.setFailDesc("上传失败!");BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request),"气瓶信息", "气瓶定检信息", "点击上传", 0, 1,"上传失败!" + CALLER);}}else{page.setResultCode(505);page.setFailDesc("上传失败,未返回文件路径!");BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息","气瓶定检信息", "点击上传", 0, 1, "未返回文件路径" + CALLER);}}else{page.setResultCode(505);page.setFailDesc("上传失败,未获得气瓶定检id");BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息","气瓶定检信息", "点击上传", 0, 1, "未获得气瓶定检id" + CALLER);}page.setFieldString(urls);page.setFailDesc("图片上传成功!");page.setResultCode(200);}else{page.setFailDesc("未获取到文件信息!");page.setResultCode(505);}}catch (Exception e){e.printStackTrace();BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime, DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息", "气瓶定检信息","点击上传", 0, 1, "" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR, "" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR,logger.getExceptionMethodHint(), e);}finally{logger.writeLog(logger.LOG_LEVEL_DEBUG, logger.getExitMethodHint());return page;}}/*** Description:主页文件上传功能(上传完图片直接将URL更新数到据库)、上传图片(日常检验记录)* @return page* @throws IOException* @RequestParam("dailyinspectrecordurlFile") CommonsMultipartFile file*/@RequestMapping(value = "/config/add-GasCylinderCheckInfoDailyinspectrecordurlFileUpload1", method = RequestMethod.POST)@ResponseBodypublic Page GasCylinderCheckInfoDailyinspectrecordurlFileUpload1(@RequestParam("file") List<CommonsMultipartFile> files,HttpServletRequest request, Integer gasCylinderCheckInfoId,Integer ii) throws IOException{String startTime = DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss");String CALLER = "GasCylinderCheckInfoController_GasCylinderCheckInfoDailyinspectrecordurlFileUpload1 ";String fileName = "";String fileType = "";Page page = new Page();String urls = "";try{if (null != files && 0 < files.size()){for (int i = 0; i < files.size(); i++){if (!files.get(i).isEmpty()){// 文件保存路径CommonsMultipartFile file = (CommonsMultipartFile) files.get(i);fileName = file.getOriginalFilename();if (null != fileName && 0 < fileName.length()){fileType = fileName.substring(fileName.lastIndexOf(".") + 1);}String url = OSSUploadUtil.uploadFile(file, fileType);if (null != url && 0 < url.length()){urls += url + ",";System.out.println(url);}else{page.setFailDesc("图片上传不成功!");page.setResultCode(505);return page;}}}if (null != gasCylinderCheckInfoId&& 0 < gasCylinderCheckInfoId){if (null != urls && 0 < urls.length()){GasCylinderCheckInfo gasCylinderCheckInfo = new GasCylinderCheckInfo();gasCylinderCheckInfo.setId(gasCylinderCheckInfoId);gasCylinderCheckInfo.setDailyinspectrecordurl(urls.toString());int i = gasCylinderCheckInfoService.updateByPrimaryKeySelective(CALLER,gasCylinderCheckInfo);if (0 < i){page.setResultCode(200);page.setFailDesc("上传成功!");BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request),"气瓶信息", "气瓶定检信息", "点击上传(日常检验记录)", 1, 1,"" + CALLER);}else{page.setResultCode(505);page.setFailDesc("上传失败!");BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request),"气瓶信息", "气瓶定检信息", "点击上传", 0, 1,"上传失败!" + CALLER);}}else{page.setResultCode(505);page.setFailDesc("上传失败,未返回文件路径!");BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息","气瓶定检信息", "点击上传", 0, 1, "未返回文件路径" + CALLER);}}else{page.setResultCode(505);page.setFailDesc("上传失败,未获得气瓶定检id");BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime,DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息","气瓶定检信息", "点击上传", 0, 1, "未获得气瓶定检id" + CALLER);}page.setFieldString(urls);page.setFailDesc("图片上传成功!");page.setResultCode(200);}else{page.setFailDesc("未获取到文件信息!");page.setResultCode(505);}}catch (Exception e){BaseController.saveLog(SecurityUtils.getSubject().getPrincipals().toString(),startTime, DateUtils.getCurrentDate("yyyy-MM-dd HH:mm:ss"),BaseController.getRequestIp(request), "气瓶信息", "气瓶定检信息","点击上传", 0, 1, "" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR, "" + CALLER);logger.writeLog(logger.LOG_LEVEL_ERROR,logger.getExceptionMethodHint(), e);}finally{logger.writeLog(logger.LOG_LEVEL_DEBUG, logger.getExitMethodHint());return page;}}}

多组input文件,每组 multiple选择多张图片上传可增删其中任意一张图片,用formData对象实现;(ajax做异步,自己做延时同步)相关推荐

  1. 多组input文件,每组 multiple选择多张图片上传可增删其中任意一张图片,用formData对象实现(ajax,sync: false同步)

    input .multiple选择多张图片时,需要删除其中的一张图片怎么做,大家都知道 input 中的文件是不能删除和更改的,只能清空,这里我的做法是 定义一个对象储存器把需要的文件存在储存器中 f ...

  2. 微信小程序拍照视频上传php,微信小程序-拍照或选择图片并上传文件

    微信小程序-拍照或选择图片并上传文件 调用拍照API:https://mp.weixin.qq.com/debug/wxadoc/dev/api/media-picture.html?t=201612 ...

  3. uni-app uni-file-picker文件上传实现拍摄从相册选择获取图片上传文档服务器(H5上传-微信小程序上传)

    前言 最近在使用uni-app写H5移动端,有一个从手机拍摄从相册选择获取图片上传到文档服务器功能. 查阅uni-app发现关于上传图片,uni-file-picker文件上传,uni.chooseI ...

  4. 文件服务器异常 选择签名,OSS上传文件后,服务器签名验证失败

    关于 OSS上传文件后,服务器签名验证失败的搜索结果 回答 指定该Header后,在响应头中也会返回该Header,OSS会对上传的Object进行加密编码存储,当这个Object被下载时,响应头中会 ...

  5. php多图片上传并回显,如何用input标签和jquery实现多图片的上传和回显功能

    本文主要记录如何用input标签和jquery实现多图片的上传和回显,不会涉及后端的交互,大概的效果看图 效果图 我们从零来做一个这样的demo 第一步: 我们先完善一下我们的页面,默认的input- ...

  6. 利用FormData对象实现AJAX文件上传功能及后端实现

    包括HTML基础设置.CSS界面优化.JS利用FormData对象和AJAX进行上传.后端接收文件并存储到指定路径以及删除文件操作. FE HTML 基础的设置: <form enctype=& ...

  7. LayUI upload上传组件上传文件的两种方式(手动上传、自动上传)

    1 手动上传 上传文件分为两步,第一步选择文件,第二步上传文件. HTML代码: <input type='button' id='selectFile' value='选择文件'> &l ...

  8. WebUploader 上传文件的两种方式(手动上传,自动上传)

    1 手动上传 上传文件分为两步,第一步选择文件,第二步上传文件. HTML代码: <input type='button' id='selectFile' value='选择文件'> &l ...

  9. android h5 多图上传源码,JS移动端/H5同时选择多张图片上传并使用canvas压缩图片...

    最近在做一个H5的项目,里边涉及到拍照上传图片的功能以及识别图片的功能,这里对识别图片的功能不做赘述,不属本文范畴.我在做完并上线项目后,同事跟我提了一个要求是可不可以同时选择多张图片上传,我做的时候 ...

最新文章

  1. Python标准库:内置函数tuple([iterable])
  2. 请选择JAVA中有效的标识_Java中有效的标识符是什么?
  3. Linux_LEMP
  4. 网络编程学习笔记(Unix域套接口地址)
  5. 未发现数据源名称并且未指定默认驱动程序_10个有用的HTML5功能,您可能未使用
  6. 基于用例的工作量估计
  7. python之绝对导入和相对导入
  8. 逸出 java_【java】知识系谱-基础篇-线程-发布、逸出
  9. JAVA进阶教学之(StringBuider进行字符串拼接)
  10. 面试官:自己搭建过vue开发环境吗?
  11. epic打开一直闪_教你用意派Epub360做酷炫的快闪H5!(附快闪H5模板)
  12. java模拟面试题目_JAVA模拟面试题库
  13. Extjs中EditorGridPanel修改并获取数据的两种方式
  14. 多类别车辆跟踪-模型训练、评估、预测、优化到部署的全流程方案_副本
  15. HTML制作虾米音乐,如何用jQuery仿虾米音乐网完整源码
  16. linux终端里面的光标很粗,怎么调细
  17. 从信息传播角度来看链路预测
  18. 计算机微程序控制器实验报告,计算机组成原理实验报告三:微程序控制器实验.doc...
  19. 计算机应用研究被ei检索吗,SCI/EI检索的国内计算机期刊
  20. 小黑leetcode清爽雨天之旅,刚吃完宇飞牛肉面、麻辣烫和啤酒:112. 路径总和

热门文章

  1. 【Jetson-Nano】SD卡重新格式化
  2. 真气APPiOS隐私策略
  3. 【BZOJ 3083】遥远的国度 树剖
  4. 酷6网李善友主题演讲:创业与哲学
  5. python语言画图代码_零: python matplotlib 画图进阶(含完整代码)
  6. LRS+XAPI教育学习记录(安装lrs,以及用xapi传输数据到lrs)
  7. c语言输入一批正整数 求其中的偶数和,编写程序,输入一批正整数(以零或负数为结束标志),求其中的偶数和。...
  8. 一个简单的加密解密程序
  9. vuecli相关命令
  10. Putty完全使用方法