基于spring 的ssi-uploader的多图片上传

2024-02-07 12:48

本文主要是介绍基于spring 的ssi-uploader的多图片上传,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

今天帮一个朋友做了一个多图片上传的demo,前端插件用的是ssi-uploader,后台是spring,详细看代码:

 

 

package com.controller;import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Map;import javax.servlet.ServletContext;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.ModelMap;
import org.springframework.web.bind.annotation.RequestMapping;
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.MultipartHttpServletRequest;
import org.springframework.web.multipart.commons.CommonsMultipartFile;
@Controller
@RequestMapping("upload")
public class FileUploadUtil {@Autowiredprivate FileUploadUtilService service;@RequestMapping("testFileUpload")@ResponseBodypublic String testFileUpload(HttpServletRequest request,HttpServletResponse response,Map<String, Object> model){MultipartHttpServletRequest Murequest = (MultipartHttpServletRequest)request;Map<String, MultipartFile> files = Murequest.getFileMap();//得到文件map对象String upaloadUrl ="D:/upload/photo/";//得到当前工程路径拼接上文件名File dir = new File(upaloadUrl);if(!dir.exists())//目录不存在则创建dir.mkdirs();for(MultipartFile file :files.values()){String  fileName=file.getOriginalFilename();//相片的名字File tagetFile = new File(upaloadUrl+fileName);//创建文件对象if(!tagetFile.exists()){//文件名不存在 则新建文件,并将文件复制到新建文件中try {tagetFile.createNewFile();} catch (IOException e) {e.printStackTrace();}try {file.transferTo(tagetFile);//到这里就可以上传了,以下是处理图片及允许gif的上传//图片扩展名String types=fileName.substring(fileName.lastIndexOf(".")+1).toLowerCase();//以1024*768大小改变图片,如果是gif则放开限制,如果需要存储原图则不需要处理if(!types.contains("gif")){
//                       Thumbnails.of(tagetFile).size(1024,768).toFile(tagetFile);}} catch (IllegalStateException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();}}}return "根据需要返回的页面";}
}

前端页面:

 

 

<%@ page language="Java" import="java.util.*" pageEncoding="utf-8"%>
<%    String path = request.getContextPath();String basePath = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort()+ path + "/";String error = (String) request.getAttribute("error0");
%>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head><meta charset="UTF-8"><title></title><link rel="stylesheet" href="${pageContext.request.contextPath}/css/ssi-uploader.css"/><script src="${pageContext.request.contextPath}/js/jquery-2.1.1.min.js" type="text/javascript"></script><script src="${pageContext.request.contextPath}/js/ssi-uploader.js"></script></head><body><!--右半部分--><div class="right"><!--头部导航栏--><div class="right_top"><p id="location">位置>图片上传</p><a href="${pageContext.request.contextPath}/admin/exit"><p id="exit">退出</p></a></div><!--右部主要内容--><div class="right_main"><!--图片上传--><div class="row"><div class="col-md-12"><h3>图片上传:</h3><input type="file" multiple id="ssi-upload3"/><input type="hidden" id="albumId" value="3"/></div></div><script type="text/javascript">//下一行的url即为你后台所走的action路径$('#ssi-upload3').ssi_uploader({url:'<%=request.getContextPath() %>/upload/testFileUpload.action',dropZone:false,allowed:['jpg','gif','txt','png','pdf']});</script></div> <script type="text/javascript" src="${pageContext.request.contextPath}/js/jquery-2.1.1.min.js"></script><script type="text/javascript">$(".menu dt").css({"background-color":"#404040"});$(".menu dt img").attr("src","images/left/select_xl01.png");$(function(){$(".menu dd").hide();$(".menu dt").click(function(){$(".menu dt").css({"background-color":"#404040"})$(this).css({"background-color": "#FF5258"});$(this).parent().find('dd').removeClass("menu_chioce");$(".menu dt img").attr("src","images/left/select_xl01.png");$(this).parent().find('img').attr("src","images/left/select_xl.png");$(".menu_chioce").slideUp(); $(this).parent().find('dd').slideToggle();$(this).parent().find('dd').addClass("menu_chioce");});})</script></body>
</html>


最后别忘了要注解spring的MultipartResolver

 
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <property name="maxUploadSize"> <value>104857600</value> </property> <property name="maxInMemorySize"> <value>4096</value> </property> <property name="defaultEncoding"> <value>UTF-8</value> </property> </bean>

 

 


附上文件下载链接:点击打开链接

 

 

 

 

 

 


 

这篇关于基于spring 的ssi-uploader的多图片上传的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/687774

相关文章

springboot自定义注解RateLimiter限流注解技术文档详解

《springboot自定义注解RateLimiter限流注解技术文档详解》文章介绍了限流技术的概念、作用及实现方式,通过SpringAOP拦截方法、缓存存储计数器,结合注解、枚举、异常类等核心组件,... 目录什么是限流系统架构核心组件详解1. 限流注解 (@RateLimiter)2. 限流类型枚举 (

Java Thread中join方法使用举例详解

《JavaThread中join方法使用举例详解》JavaThread中join()方法主要是让调用改方法的thread完成run方法里面的东西后,在执行join()方法后面的代码,这篇文章主要介绍... 目录前言1.join()方法的定义和作用2.join()方法的三个重载版本3.join()方法的工作原

Spring AI使用tool Calling和MCP的示例详解

《SpringAI使用toolCalling和MCP的示例详解》SpringAI1.0.0.M6引入ToolCalling与MCP协议,提升AI与工具交互的扩展性与标准化,支持信息检索、行动执行等... 目录深入探索 Spring AI聊天接口示例Function CallingMCPSTDIOSSE结束语

Java获取当前时间String类型和Date类型方式

《Java获取当前时间String类型和Date类型方式》:本文主要介绍Java获取当前时间String类型和Date类型方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录Java获取当前时间String和Date类型String类型和Date类型输出结果总结Java获取

Spring Boot Actuator应用监控与管理的详细步骤

《SpringBootActuator应用监控与管理的详细步骤》SpringBootActuator是SpringBoot的监控工具,提供健康检查、性能指标、日志管理等核心功能,支持自定义和扩展端... 目录一、 Spring Boot Actuator 概述二、 集成 Spring Boot Actuat

OpenCV在Java中的完整集成指南分享

《OpenCV在Java中的完整集成指南分享》本文详解了在Java中集成OpenCV的方法,涵盖jar包导入、dll配置、JNI路径设置及跨平台兼容性处理,提供了图像处理、特征检测、实时视频分析等应用... 目录1. OpenCV简介与应用领域1.1 OpenCV的诞生与发展1.2 OpenCV的应用领域2

在Java中使用OpenCV实践

《在Java中使用OpenCV实践》用户分享了在Java项目中集成OpenCV4.10.0的实践经验,涵盖库简介、Windows安装、依赖配置及灰度图测试,强调其在图像处理领域的多功能性,并计划后续探... 目录前言一 、OpenCV1.简介2.下载与安装3.目录说明二、在Java项目中使用三 、测试1.测

Spring Bean初始化及@PostConstruc执行顺序示例详解

《SpringBean初始化及@PostConstruc执行顺序示例详解》本文给大家介绍SpringBean初始化及@PostConstruc执行顺序,本文通过实例代码给大家介绍的非常详细,对大家的... 目录1. Bean初始化执行顺序2. 成员变量初始化顺序2.1 普通Java类(非Spring环境)(

Spring Boot 中的默认异常处理机制及执行流程

《SpringBoot中的默认异常处理机制及执行流程》SpringBoot内置BasicErrorController,自动处理异常并生成HTML/JSON响应,支持自定义错误路径、配置及扩展,如... 目录Spring Boot 异常处理机制详解默认错误页面功能自动异常转换机制错误属性配置选项默认错误处理

java如何实现高并发场景下三级缓存的数据一致性

《java如何实现高并发场景下三级缓存的数据一致性》这篇文章主要为大家详细介绍了java如何实现高并发场景下三级缓存的数据一致性,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 下面代码是一个使用Java和Redisson实现的三级缓存服务,主要功能包括:1.缓存结构:本地缓存:使