Spring mvc 集成 plupload 上传图片

2024-03-12 19:48

本文主要是介绍Spring mvc 集成 plupload 上传图片,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

plupload

gObjectName = ''
gObjectNames = new Array() //多图片上传保持
currentUrl = window.location.href;
baseBackend = window.location.protocol + "//" +window.location.host;
uploadUrl = 'http://127.0.0.1:8082/';$(document).ready(function() {//上传$('.media-picker').each(function() {var el = $(this);var elbtn = el.find('.media-picker-button');var multiSelection = false;// 上传目录var inputField = el.find('input[type=hidden]');var token = $("meta[name='_csrf']").attr("content");var header = $("meta[name='_csrf_header']").attr("content");console.log(header)// 类型var mediaType = elbtn.attr('data-type');var mimeTypes = [{ title: "Image files", extensions: "jpg,jpeg,gif,png,bmp" },{ title: "Video files", extensions: "mp4,3gp" },{ title: "Video files", extensions: "pdf,doc,docx,ppt,pptx,xls,xlsx,zip,rar" }];if(mediaType == 'video') {mimeTypes = [{ title: "Video files", extensions: "mp4,3gp" }];} else if(mediaType == 'file') {mimeTypes = [{ title: "Video files", extensions: "pdf,doc,docx,ppt,pptx,xls,xlsx,zip,rar" }];} else if(mediaType == 'image') {mimeTypes = [{ title: "Image files", extensions: "jpg,jpeg,gif,png,bmp" }];}// 是否多文件上传if (elbtn.attr('data-multiple') == 'multiple') {multiSelection = true;// 如果已经有文件var oldFiles = inputField.val();if (oldFiles != '') {var oldFilesArr = $.parseJSON(oldFiles);for (var x = 0; x < oldFilesArr.length; x++) {gObjectNames.push(oldFilesArr[x]);}}}var updir = elbtn.attr('data-oss-path');var uploader = new plupload.Uploader({runtimes: 'html5,flash,silverlight,html4',browse_button: elbtn.attr('data-id') + '_uploader',url: 'http://127.0.0.1:8082/backend/upload',file_data_name: 'file',multi_selection: multiSelection,auto_start: true,flash_swf_url: '../plugins/plupload/js/Moxie.swf',silverlight_xap_url: '../plugins/plupload/js/Moxie.xap',//只允许上传图片和zip,rar文件filters: {mime_types: mimeTypes,max_file_size: '50mb', //最大只能上传10mb的文件prevent_duplicates: false //不允许选取重复文件},init: {PostInit: function() {gObjectNames = new Array() //多图片上传保持},FilesAdded: function(up) {uploader.setOption("multipart_params", {"updir": updir, "_csrf": token});up.start(); //选择完后直接上传},FileUploaded: function(up, file, info) {if (info.status == 200) {var fileType = file.type;var isImage = fileType.indexOf('image');var isVideo = fileType.indexOf('video');var isApplication = fileType.indexOf('application');// 获取返回德数据var fileInfos = $.parseJSON(info.response);if(fileInfos.error == 0) {var fileUrl = fileInfos.url;if (multiSelection) {// 多文件转为jsongObjectNames.push(fileUrl);inputField.val(JSON.stringify(gObjectNames));var imageHtml = '';for (var i = 0; i < gObjectNames.length; i++) {if (isImage > -1) {imageHtml += '<li class="image-info"><div class="info"><img src="' +  gObjectNames[i] + '"/><p>' + gObjectNames[i] + '</p><div class="delete-image"> X </div></div></li>';}if (isVideo > -1) {imageHtml += '<li class="video-info"><div class="info"><video controls src="' +  gObjectNames[i] + '"></video><p>' + gObjectNames[i] + '</p><div class="delete-image"> X </div></div></li>';}if (isApplication > -1) {imageHtml += '<li class="file-info"><div class="info"><div class="attachment-file">' +  gObjectNames[i] + '</div><p>' + gObjectNames[i] + '</p><div class="delete-image"> X </div></div></li>';}}el.find('.media-list ul').html(imageHtml);} else {// 单文件直接用名称,inputField.val(fileUrl);gObjectName = fileUrl// 把图片显示出来var imageHtml = '';if (isImage > -1) {imageHtml = '<li class="image-info"><div class="info"><img src="' +  gObjectName + '"/><p>' + gObjectName + '</p><div class="delete-image"> X </div></div></li>';}if (isVideo > -1) {imageHtml = '<li class="video-info"><div class="info"><video controls src="' +  gObjectName + '"></video><p>' + gObjectName + '</p><div class="delete-image"> X </div></div></li>';}if (isApplication > -1) {imageHtml += '<li class="file-info"><div class="info"><div class="attachment-file">' +  gObjectName + '</div><p>' + gObjectName + '</p><div class="delete-image"> X </div></div></li>';}el.find('.media-list ul').html(imageHtml);}} else {alert(fileInfos.msg);}} else {alert(info.response);}},Error: function(up, err) {if (err.code == -600) {alert("\n选择的文件太大了,可以根据应用情况,在upload.js 设置一下上传的最大大小");} else if (err.code == -601) {alert("\n选择的文件后缀不对,可以根据应用情况,在upload.js进行设置可允许的上传文件类型");} else if (err.code == -602) {alert("\n这个文件已经上传过一遍了");} else {alert("\nError xml:" + err.response);}}}})uploader.init();})// 删除$('.media-picker').each(function() {var el = $(this)var inputField = el.find('input[type=hidden]');var fileUrl = inputField.val();var elbtn = el.find('.media-picker-button');var multiSelection = false;// 是否多文件上传if (elbtn.attr('data-multiple') == 'multiple') {multiSelection = true;}if (multiSelection) {el.on('click', '.delete-image', function() {var elDel = $(this);// 得到filenamevar currentFileName = elDel.prev('p').html();// 删除当前的父级lielDel.parent().parent().remove();// 重新赋值数组// 去掉url数组中的当前urlfor(var i in gObjectNames) {if(gObjectNames[i] == currentFileName) {gObjectNames.splice(i,1);break;}}// 后端不做删除/*$.ajaxSetup({headers: {'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')},});$.ajax({type: "POST",url: baseBackend + "uploader/deluploader",data: "attachement_id=" + currentAttachementId,success: function(msg) {}});*/inputField.val(JSON.stringify(gObjectNames));})} else {el.on('click', '.delete-image', function() {// 显示值为空el.find('.media-list ul').html('');inputField.val('');// oss删除if (gObjectName != '') {fileAttachement = gObjectName;}// 后端不做删除/*$.ajaxSetup({headers: {'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')},});$.ajax({type: "POST",url: baseBackend + "uploader/deluploader",data: "attachement_id=" + fileAttachement,success: function(msg) {}});*/})}})
})

 

上传注意时需要注意加入csrf

 

后端

@Controller
@RequestMapping(value = "/backend")
public class UploadController {@PostMapping(value = "/upload", produces = "application/json;charset=UTF-8")@ResponseBodypublic String upload(@RequestParam("file") MultipartFile file, HttpServletRequest request){Map<String, String> jres = new HashMap<String, String>();Gson gson = new Gson();if(!file.isEmpty()) {// 文件夹路径// 这里正是环境要处理,spring boot每次重启都会重新生成临时目录String uploadPath = request.getSession().getServletContext().getRealPath("upload/");String currentDatePath = ToolUtils.makeDatePath();String savePath = uploadPath.concat("/").concat(currentDatePath);// 获取文件名String fileName = file.getOriginalFilename();String newFileName = ToolUtils.makeFileName(fileName);String showUrl = "/upload/".concat(currentDatePath).concat("/").concat(newFileName);File saveFile = new File(savePath, newFileName);if (!saveFile.exists()) {saveFile.mkdirs();}try {file.transferTo(saveFile);jres.put("error", "0");jres.put("url", showUrl);gson.toJson(jres);} catch (Exception e) {jres.put("error", "1");jres.put("msg", "wrong");}return gson.toJson(jres);}jres.put("error", "1");jres.put("msg", "wrong");return gson.toJson(jres);}
}

 

这篇关于Spring mvc 集成 plupload 上传图片的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/802393

相关文章

SpringBoot项目删除Bean或者不加载Bean的问题解决

《SpringBoot项目删除Bean或者不加载Bean的问题解决》文章介绍了在SpringBoot项目中如何使用@ComponentScan注解和自定义过滤器实现不加载某些Bean的方法,本文通过实... 使用@ComponentScan注解中的@ComponentScan.Filter标记不加载。@C

Java读取InfluxDB数据库的方法详解

《Java读取InfluxDB数据库的方法详解》本文介绍基于Java语言,读取InfluxDB数据库的方法,包括读取InfluxDB的所有数据库,以及指定数据库中的measurement、field、... 首先,创建一个Java项目,用于撰写代码。接下来,配置所需要的依赖;这里我们就选择可用于与Infl

SpringBoot生成和操作PDF的代码详解

《SpringBoot生成和操作PDF的代码详解》本文主要介绍了在SpringBoot项目下,通过代码和操作步骤,详细的介绍了如何操作PDF,希望可以帮助到准备通过JAVA操作PDF的你,项目框架用的... 目录本文简介PDF文件简介代码实现PDF操作基于PDF模板生成,并下载完全基于代码生成,并保存合并P

springboot 加载本地jar到maven的实现方法

《springboot加载本地jar到maven的实现方法》如何在SpringBoot项目中加载本地jar到Maven本地仓库,使用Maven的install-file目标来实现,本文结合实例代码给... 在Spring Boothttp://www.chinasem.cn项目中,如果你想要加载一个本地的ja

SpringCloud配置动态更新原理解析

《SpringCloud配置动态更新原理解析》在微服务架构的浩瀚星海中,服务配置的动态更新如同魔法一般,能够让应用在不重启的情况下,实时响应配置的变更,SpringCloud作为微服务架构中的佼佼者,... 目录一、SpringBoot、Cloud配置的读取二、SpringCloud配置动态刷新三、更新@R

springboot健康检查监控全过程

《springboot健康检查监控全过程》文章介绍了SpringBoot如何使用Actuator和Micrometer进行健康检查和监控,通过配置和自定义健康指示器,开发者可以实时监控应用组件的状态,... 目录1. 引言重要性2. 配置Spring Boot ActuatorSpring Boot Act

使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)

《使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)》在现代软件开发中,处理JSON数据是一项非常常见的任务,无论是从API接口获取数据,还是将数据存储为JSON格式,解析... 目录1. 背景介绍1.1 jsON简介1.2 实际案例2. 准备工作2.1 环境搭建2.1.1 添加

Java实现任务管理器性能网络监控数据的方法详解

《Java实现任务管理器性能网络监控数据的方法详解》在现代操作系统中,任务管理器是一个非常重要的工具,用于监控和管理计算机的运行状态,包括CPU使用率、内存占用等,对于开发者和系统管理员来说,了解这些... 目录引言一、背景知识二、准备工作1. Maven依赖2. Gradle依赖三、代码实现四、代码详解五

java如何分布式锁实现和选型

《java如何分布式锁实现和选型》文章介绍了分布式锁的重要性以及在分布式系统中常见的问题和需求,它详细阐述了如何使用分布式锁来确保数据的一致性和系统的高可用性,文章还提供了基于数据库、Redis和Zo... 目录引言:分布式锁的重要性与分布式系统中的常见问题和需求分布式锁的重要性分布式系统中常见的问题和需求

SpringBoot基于MyBatis-Plus实现Lambda Query查询的示例代码

《SpringBoot基于MyBatis-Plus实现LambdaQuery查询的示例代码》MyBatis-Plus是MyBatis的增强工具,简化了数据库操作,并提高了开发效率,它提供了多种查询方... 目录引言基础环境配置依赖配置(Maven)application.yml 配置表结构设计demo_st