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

input 、multiple选择多张图片时,需要删除其中的一张图片怎么做,大家都知道 input 中的文件是不能删除和更改的,只能清空,这里我的做法是 定义一个对象储存器把需要的文件存在储存器中 formData,后台不从Input中读取,从对象存储器中获取文件,一组图片使用一个储存器中formData,存储器中的 key 我们用文件名加Input的ID 拼接,而后在取出来用 key 为Input的ID,存入所有的图片,用ajax 需要sync: false,同步操作a与后台交互,后台根据 key 获取所有图片;

效果:

添加图片:

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

删除其中一张图片:

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

重复图片提示:

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

单图片预览:

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

图片增删 与后台交互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 = $("
"); imgContainer.prepend($section); var $span = $(""); $span.appendTo($section); /* 删除图片*/ var $img0 = $("").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的ID formData.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 = $(""); /*var $img = $("");*/ $img.attr("src", imgArr[i]); $img.appendTo($section); var $p = $("

"); $p.html(fileList[i].name).appendTo($section); var $input = $(""); $input.appendTo($section); var $input2 = $(""); $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() { /*产品合格证*/ $.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("请图片上传失败"); } }, error: function () { } }); } /*质量证书*/ function qualitycertificateurlFileUpload() { /*质量证书*/ $.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("请图片上传失败"); } }, error: function () { } }); } /* 质量说明书*/ function ManufacturingSupervisionInsurFileUpload() { /* 质量说明书*/ $.ajax({ url: "/config/create-AllGasCylinderCheckInfoQualitycertificateurlFileUpload", type: "POST", dataType: 'json', processData: false, contentType: false, data: formData, async: false, success: function(data){ if (data.resultCode == 200) { $("#manufacturingsupervisioninsurl").val(data.fieldString); } if(data.resultCode == 505){ DJMask.msg("请图片上传失败"); } }, error: function () { } }); } /* 使用说明书*/ function instructionmanualurlFileUpload() { $.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("请图片上传失败"); } }, error: function () { } }); } /* 检验报告*/ function InspectereporturlUpload() { $.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("请图片上传失败"); } }, error: function () { } }); } /* 日常检验记录*/ function DailyinspectrecordurlUpload() { $.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("请图片上传失败"); } }, error: function () { } }); } /*==================================定检证书查看=============================================================*/ /*(产品合格证)*/ function lookProductqualifyurl(href) { /*var productqualifyurl = $("#productqualifyurl").val();*/ window.location.href = href; } /*(质量证明书)*/ function lookQualitycertificateurl(href) { /* var qualitycertificateurl = $("#qualitycertificateurl").val();*/ window.location.href = href; } /*质量说明书*/ function lookManufacturingsupervisioninsurl(href) { /*var manufacturingsupervisioninsurl = $("#manufacturingsupervisioninsurl").val();*/ window.location.href = href; } /*使用说明书*/ function lookinstructionmanualurl(href) { /*var instructionmanualurl = $("#instructionmanualurl").val();*/ window.location.href = href; } /*==================================上传图片(产品合格证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 名接收;

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

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

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

图片增加删除页面与用户交互 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'
});

/*=======================(一)======车牌查询车辆和气瓶信息,去气瓶的controller中查询数据,必须是要配置好车辆的======================================*/

function SelectVehicleByCph() {
    $("#num").empty();
    var cph = $("#cph").val();
    $.ajax({
        type: 'post',
        dataType: "json",
        /*contentType: "application/json; charset=utf-8",*/
        /*GasCylindeController*/
        url: "/config/showAdd-GasCylinderCheckInfo",
        data: {"cph": cph},
        success: function (data) {
            if (data.resultCode == 200) {
                if (0 < data.list.length) {
                    DJMask.msg(data.failDesc);
                    /*  for (var i = 0; i < data.list.length; i++) {*/
                    for (var j = 0; j < data.list[0].gasCylinders.length; j++) {
                        $("#num").append(" ");
                    }
                    SelsceGasCylinderpositionnum();
                } else {
                    DJMask.msg(data.failDesc);
                }
            }
            if (data.resultCode == 505) {
                /*   $("#num").remove("selector");*/
                /*      $("#num").remove("selector","option");*/
                $("#num").empty();
                $("#positionnum").val("");
                DJMask.msg(data.failDesc);
                /* $("#messageValue").val(data.failDesc);
                 $("#btn3").click();*/
            }

        }, error: function () {
            DJMask.msg("获取车牌异常!\n")
        }
    });
}

/*=======================(二)======气瓶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 =
                            "
" + "
" + "

产品合格证:最多可以上传5张图片

" + "
" + "
" + "" + "" + "
" + "
" + "
" + "
"; /*(质量证明书)*/ td2 = "
" + "
" + "

质量证书:最多可以上传5张图片

" + "
" + "
" + "" + "" + "
" + "
" + "
" + "
"; /*(质量说明书)*/ /* td3 = "
" + "
" + "

质量说明书:最多可以上传5张图片

" + "
" + "
" + "" + "" + "
" + "
" + "
" + "
";*/ /*(使用说明书)*/ td4 = "
" + "
" + "

使用说明书:最多可以上传5张图片

" + "
" + "
" + "" + "" + "
" + "
" + "
" + "
"; /*(检验报告)*/ td5 = "
" + "
" + "

检验报告:最多可以上传5张图片

" + "
" + "
" + "" + "" + "
" + "
" + "
" + "
"; /*(日常检验记录)*/ td6 = "
" + "
" + "

日常检验记录:最多可以上传5张图片

" + "
" + "
" + "" + "" + "
" + "
" + "
" + "
"; /*新增必须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("正在处理请稍等!"); /*======================新方法=================================*/ /*产品合格证*/ if (null != f1 && f1 != ""){ if ((!/\.(|jpg|jpeg|png|JPG|PNG)$/.test(f1)) ) { DJMask.msg("图片类型必须是.jpeg,jpg,png中的一种"); return false; } /*产品合格证*/ ProductqualifyurlFileUpload(someAjaxDfd); } /*质量证书*/ if (null != f2 && f2 != ""){ if ((!/\.(|jpg|jpeg|png|JPG|PNG)$/.test(f2)) ) { DJMask.msg("图片类型必须是.jpeg,jpg,png中的一种"); return false; } /*质量证书*/ qualitycertificateurlFileUpload(ajax1Dfd); } /* 质量说明书*/ /*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; } /* 使用说明书*/ instructionmanualurlFileUpload(ajax3Dfd); } if (null != f5 && f5 != ""){ if ((!/\.(|jpg|jpeg|png|JPG|PNG)$/.test(f5)) ) { DJMask.msg("图片类型必须是.jpeg,jpg,png中的一种"); return false; } /* 检验报告*/ InspectereporturlUpload(ajax4Dfd); } /* 日常检验记录*/ if (null != f6 && f6 != ""){ if ((!/\.(|jpg|jpeg|png|JPG|PNG)$/.test(f6)) ) { DJMask.msg("图片类型必须是.jpeg,jpg,png中的一种"); return false; } /* 日常检验记录*/ DailyinspectrecordurlUpload(); } /*定检信息数据写入*/ 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",//url data: { "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) { 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); }); }); /*=================================================弹出页面js===============================================================*/

页面:

<%@ 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" %>



    
    
    
    
    
    
    
    
    
    

    
    









<%--第一次添加为1,第二次添加为0--%> <%--产品合格证--%> <%--质量证书--%> <%--质量说明书--%> <%--使用说明书--%> <%--检验报告--%> <%--日常检验记录--%>
添加定检信息
返回 提交
基础信息
<%-- ======--%> <%--================--%>
<%--获取的气瓶编号--%> <%--这里了的num存放气瓶id--%>
气瓶编号
* <%-- 按车牌号查询气瓶信息 --%>
气瓶位置编号
车牌号
<%-- 按车牌号查询气瓶信息 --%>
检验信息
检验日期
*
检验单位
*
检验结果
*
<%--产品合格证--%> <%-- <%-- <%--质量证明书--%> <%--质量说明书--%> <%--使用说明书--%> <%--检验报告--%> <%--日常检验记录--%> <%--========这个没用但去掉会对图片上传样式造成影响=========--%>
--%> <%--

产品合格证:最多可以上传5张图片

--%> <%-- --%>
--%>
<%----%> <%--

质量证书:最多可以上传5张图片

--%>
<%----%>
<%--

质量说明书:最多可以上传5张图片,马上上传

--%>
<%----%> <%--

使用说明书:最多可以上传5张图片,马上上传

--%>
<%-- --%>
<%--

检验报告:最多可以上传5张图片,马上上传

--%>
<%--

日常检验记录:最多可以上传5张图片,马上上传

--%>
<%--====================================================遮罩========================================================--%> <<%--script src="/assets/js/system/DJMask.js"> --%> <%----%> <%----%> <%----%> <%--图片上传--%> <%----%> <%----%> <%--上传--%>

 

 

单图片预览js:

assets/showImg/js/popwin.js


var popWin = {
    scrolling: 'no',
    //是否显示滚动条 no,yes,auto

int: 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 += '
' inntHtml += '
' inntHtml += '
' inntHtml += '' + title + '' inntHtml += '
' inntHtml += '
' for(var i = 0; i < src.length; i++){ if(src[i] != ""){ /*inntHtml += "";*/ inntHtml += ""; } } /*inntHtml += '';*/ $("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,auto int: 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 += '
' inntHtml += '
' inntHtml += '
' inntHtml += '' + title + '' inntHtml += '
' inntHtml += '
' /*inntHtml +=' '*/ /*inntHtml += '';*/ $("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='
'; $(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='
'+ '
'+ '
'+ '
'+ '
'+ '
' '
'; $(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='
'; $(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='
'; $(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='
'; $(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('
提示X
') .append('
') .append('确定'); 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='
'; $(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:"
loading.......
" }, me=$.extend(config, options); this.openMask(); openMaskDomLoaded.show(); var contentDom='
'; $(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('
'+me.title+'X
') .append('
'); 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执行完毕处理 }()) };

后台:

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.*;

/**
 * 

*

* FileName: GasCylinderCheckInfoController * Author: 苏凯 * Date: 2018/3/22 19:08 * Description: 气瓶定检信息Controller * */ @Controller public class GasCylinderCheckInfoController { /** * 配置管理、Service层各模块接口bean */ @Autowired private CmService cmServiceFactory; /** * 气瓶管理、气瓶定检service */ @Autowired private GasCylinderCheckInfoService gasCylinderCheckInfoService; /** * 配置管理 气瓶service */ @Autowired private 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") @ResponseBody public 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 { // 排序 默认id if (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 gasCylinderCheckInfos = new ArrayList(); // 如果页面有传入气瓶参数做查询条件,需要获取车队ID List vehicleIds = new ArrayList(); // 获取气瓶id List GasCylinderIds = new ArrayList(); // 存放关联数据的集合 List vehicleAndGasCylinderAndGasCylinderCheckInfos = new ArrayList(); // 通过车辆查条件查询数据 if ((null != cph && 0 < cph.trim().length())) { VehicleExample vehicleExample = new VehicleExample(); VehicleExample.Criteria vehicleExampleCriteria = vehicleExample .createCriteria(); // 车牌号 vehicleExampleCriteria.andCphLike("%" +cph.trim()+ "%"); List 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(); // 气瓶编号num if (null != num && 0 < num.trim().length()) { criteria2.andNumLike("%" +num.trim()+ "%"); } // 气瓶位置编号positionnum if (null != positionnum && 0 < positionnum.trim().length()) { criteria2.andPositionnumEqualTo(positionnum.trim()); } // 通过车辆id获取已经配置的配置信息 if (0 < vehicleIds.size()) { List vehicleIdsL = new ArrayList(); 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 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") @ResponseBody public 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") @ResponseBody public 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 { // 排序 默认id if (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") @ResponseBody public 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(); // 排序 默认id if (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") @ResponseBody public 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) @ResponseBody public Page AllGasCylinderCheckInfoProductqualifyurlFileUpload( @RequestParam("productqualifyurlFile1") List 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) @ResponseBody public Page AllGasCylinderCheckInfoQualitycertificateurlFileUpload( @RequestParam("qualitycertificateurlFile2") List 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 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) @ResponseBody public Page AllGasCylinderCheckInspectereporturlFileUpload( @RequestParam("inspectereporturlFile2") List 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) @ResponseBody public Page AllGasCylinderCheckDailyinspectrecordurlFileUpload( @RequestParam("dailyinspectrecordurlFile2") List 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 vehicleAndGasCylinderAndGasCylinderCheckInfos, List 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 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 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") @ResponseBody public 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 = "气瓶定检"; // 排序 默认id if (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 gasCylinderCheckInfos = new ArrayList(); try { request.setCharacterEncoding("utf-8"); // 如果页面有传入气瓶参数做查询条件,需要获取车队ID List vehicleIds = new ArrayList(); // 获取气瓶id List GasCylinderIds = new ArrayList(); // 存放关联数据的集合 List vehicleAndGasCylinderAndGasCylinderCheckInfos = new ArrayList(); // 通过车辆查条件查询数据 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 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(); // 气瓶编号num if (null != num && 0 < num.trim().length()) { criteria2.andNumEqualTo(num.trim()); } // 气瓶位置编号positionnum if (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 vehicleIdsL = new ArrayList(); 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 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 vehicleAndGasCylinderAndGasCylinderCheckInfopMap = new HashMap(); // 创建存放map的list容器 List> vehicleAndVehGroupsList = new ArrayList>(); 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 vehicleAndGasCylinderAndGasCylinderCheckInfos, List> vehicleAndVehGroupsList) throws IOException { Map vehicleAndGasCylinderAndGasCylinderCheckInfopMap; for (int i = 0; i < vehicleAndGasCylinderAndGasCylinderCheckInfos .size(); i++) { vehicleAndGasCylinderAndGasCylinderCheckInfopMap = new HashMap(); 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中的key ByteArrayOutputStream 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) @ResponseBody public Page GasCylinderCheckInfoProductqualifyurlUpload1( @RequestParam("file") List 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) @ResponseBody public Page GasCylinderCheckInfoQualitycertificateurlUpload1( @RequestParam("file") List 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) @ResponseBody public Page GasCylinderCheckInfoQualityspecifyurlUpload1( @RequestParam("file") List 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) @ResponseBody public Page GasCylinderCheckInfoInstructionmanualurlUpload1( @RequestParam("file") List 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) @ResponseBody public Page GasCylinderCheckInfoInspectereporturlUpload1( @RequestParam("file") List 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) @ResponseBody public Page GasCylinderCheckInfoDailyinspectrecordurlFileUpload1( @RequestParam("file") List 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; } } }

 

 

确认弹出框:

 assets/js/xcConfirm.js

/*
 * 使用说明:
 * window.wxc.Pop(popHtml, [type], [options])
 * popHtml:html字符串
 * type:window.wxc.xcConfirm.typeEnum集合中的元素
 * options:扩展对象
 * 用法:
 * 1. window.wxc.xcConfirm("我是弹窗lalala");
 * 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",//蓝色i
				btn: 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 = $("

").html(popHtml);//弹窗文本dom var $tt = $("").addClass("tt").text(config.title);//标题 var icon = config.icon; var $icon = icon ? $("

").addClass("bigIcon").css("backgroundPosition",icon) : ""; var btn = config.btn;//按钮组生成参数 var popId = creatPopId();//弹窗索引 var $box = $("
").addClass("xcConfirm");//弹窗插件容器 var $layer = $("
").addClass("xc_layer");//遮罩层 var $popBox = $("
").addClass("popBox");//弹窗盒子 var $ttBox = $("
").addClass("ttBox");//弹窗顶部区域 var $txtBox = $("
").addClass("txtBox");//弹窗内容主体区 var $btnArea = $("
").addClass("btnArea");//按钮区域 var $ok = $("").addClass("sgBtn").addClass("ok").text("确定");//确定按钮 var $cancel = $("").addClass("sgBtn").addClass("cancel").text("取消");//取消按钮 var $input = $("").addClass("inputBox");//输入框 var $clsBtn = $("").addClass("clsBtn");//关闭按钮 //建立按钮映射关系 var btns = { ok: $ok, cancel: $cancel }; init(); function init(){ //处理特殊类型input if(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); else config.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 = $("
").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);

 

你可能感兴趣的:(js,jsp,java,Jquery,javaScript,html)