图片压缩上传Thumbnailator 插件
一,接口已经写死
public static String upload(String appCode, MultipartFile inputFile)
public static String upload(String appCode, File inputFile)
后台已经写死成这两种格式了
MultipartFile inputFile = multipartRequest.getFile(fileElementId); CommonsMultipartFile cf= (CommonsMultipartFile)inputFile; DiskFileItem fi = (DiskFileItem)cf.getFileItem(); String storeLocation = fi.getStoreLocation().toString(); originalFilename = inputFile.getOriginalFilename(); imageType = originalFilename.substring(originalFilename.lastIndexOf(".") + 1).trim().toLowerCase(); long sizeOther = inputFile.getSize(); size = sizeOther +"kb"; double scale = 1.0d ; if(sizeOther >= 3*1024*1024){ if(sizeOther > 0){ scale = (3*1024*1024f) / sizeOther ; } Thumbnails.of(inputFile.getInputStream()).scale(1f).outputQuality(scale).outputFormat("jpg").toFile(storeLocation); File file = new File(storeLocation+".jpg"); fssId = FssFileClient.upload("app-weixin", file); file.delete(); }else{ fssId = FssFileClient.upload("app-weixin", inputFile); }
StoreLocation=/opt/oracle/tomcat/t-2/work/Catalina/localhost/weixin/upload_6af40051_15fc4efb752__7ffd_00000001.tmp
StoreLocation=D:\workspace\.metadata\.plugins\org.eclipse.wst.server.core\tmp5\work\Catalina\localhost\weixin\upload__ad6bac5_15fc4f98fa1__8000_00000000.tmp
去找到这个路径,因为在这个路径下会产生一个缓存文件,对这个缓存文件进行压缩,压缩完了之上传,上传至后在删除。
二,就是自己创建一个文件,然后在进行修改
MultipartFile inputFile = multipartRequest.getFile(fileElementId); originalFilename = inputFile.getOriginalFilename(); imageType = originalFilename.substring(originalFilename.lastIndexOf(".") + 1).trim().toLowerCase(); long sizeOther = inputFile.getSize(); size = sizeOther +"kb"; double scale = 1.0d ; if(sizeOther >= 3*1024*1024){ if(sizeOther > 0){ scale = (3*1024*1024f) / sizeOther ; } String path=request.getSession().getServletContext().getRealPath("/")+"js" + System.getProperty("file.separator") + "upload"+System.getProperty("file.separator")+"yasuo."+imageType; Thumbnails.of(inputFile.getInputStream()).scale(1f).outputQuality(scale).toFile(path); File file = new File(path); fssId = FssFileClient.upload("app-weixin", file); }else{ fssId = FssFileClient.upload("app-weixin", inputFile); }
自己创建了一个upload的文件,在这个里面进行修改。
三,详细的 讲解
<!-- 图片缩略图 --> <dependency> <groupId>net.coobird</groupId> <artifactId>thumbnailator</artifactId> <version>0.4.8</version> </dependency>
3.1,按指定大小把图片进行缩放(会遵循原图高宽比例)
//按指定大小把图片进行缩和放(会遵循原图高宽比例) //此处把图片压成400×500的缩略图 Thumbnails.of(fromPic).size(400,500).toFile(toPic);//变为400*300,遵循原图比例缩或放到400*某个高度
3.2,按照指定比例进行缩小和放大
//按照比例进行缩小和放大 Thumbnails.of(fromPic).scale(0.2f).toFile(toPic);//按比例缩小 Thumbnails.of(fromPic).scale(2f);//按比例放大
图片尺寸不变,压缩图片文件大小
//图片尺寸不变,压缩图片文件大小outputQuality实现,参数1为最高质量 Thumbnails.of(fromPic).scale(1f).outputQuality(0.25f).toFile(toPic);
我这里只使用了 图片尺寸不变,压缩文件大小 源码
/** * * @Description:保存图片并且生成缩略图 * @param imageFile 图片文件 * @param request 请求对象 * @param uploadPath 上传目录 * @return */ public static BaseResult uploadFileAndCreateThumbnail(MultipartFile imageFile,HttpServletRequest request,String uploadPath) { if(imageFile == null ){ return new BaseResult(false, "imageFile不能为空"); } if (imageFile.getSize() >= 10*1024*1024) { return new BaseResult(false, "文件不能大于10M"); } String uuid = UUID.randomUUID().toString(); String fileDirectory = CommonDateUtils.date2string(new Date(), CommonDateUtils.YYYY_MM_DD); //拼接后台文件名称 String pathName = fileDirectory + File.separator + uuid + "." + FilenameUtils.getExtension(imageFile.getOriginalFilename()); //构建保存文件路劲 //2016-5-6 yangkang 修改上传路径为服务器上 String realPath = request.getServletContext().getRealPath("uploadPath"); //获取服务器绝对路径 linux 服务器地址 获取当前使用的配置文件配置 //String urlString=PropertiesUtil.getInstance().getSysPro("uploadPath"); //拼接文件路劲 String filePathName = realPath + File.separator + pathName; log.info("图片上传路径:"+filePathName); //判断文件保存是否存在 File file = new File(filePathName); if (file.getParentFile() != null || !file.getParentFile().isDirectory()) { //创建文件 file.getParentFile().mkdirs(); } InputStream inputStream = null; FileOutputStream fileOutputStream = null; try { inputStream = imageFile.getInputStream(); fileOutputStream = new FileOutputStream(file); //写出文件 //2016-05-12 yangkang 改为增加缓存 // IOUtils.copy(inputStream, fileOutputStream); byte[] buffer = new byte[2048]; IOUtils.copyLarge(inputStream, fileOutputStream, buffer); buffer = null; } catch (IOException e) { filePathName = null; return new BaseResult(false, "操作失败", e.getMessage()); } finally { try { if (inputStream != null) { inputStream.close(); } if (fileOutputStream != null) { fileOutputStream.flush(); fileOutputStream.close(); } } catch (IOException e) { filePathName = null; return new BaseResult(false, "操作失败", e.getMessage()); } } // String fileId = FastDFSClient.uploadFile(file, filePathName); /** * 缩略图begin */ //拼接后台文件名称 String thumbnailPathName = fileDirectory + File.separator + uuid + "small." + FilenameUtils.getExtension(imageFile.getOriginalFilename()); //added by yangkang 2016-3-30 去掉后缀中包含的.png字符串 if(thumbnailPathName.contains(".png")){ thumbnailPathName = thumbnailPathName.replace(".png", ".jpg"); } long size = imageFile.getSize(); double scale = 1.0d ; if(size >= 200*1024){ if(size > 0){ scale = (200*1024f) / size ; } } //拼接文件路劲 String thumbnailFilePathName = realPath + File.separator + thumbnailPathName; try { //added by chenshun 2016-3-22 注释掉之前长宽的方式,改用大小 // Thumbnails.of(filePathName).size(width, height).toFile(thumbnailFilePathName); if(size < 200*1024){ Thumbnails.of(filePathName).scale(1f).outputFormat("jpg").toFile(thumbnailFilePathName); }else{ Thumbnails.of(filePathName).scale(1f).outputQuality(scale).outputFormat("jpg").toFile(thumbnailFilePathName); } } catch (Exception e1) { return new BaseResult(false, "操作失败", e1.getMessage()); } /** * 缩略图end */ Map<String, Object> map = new HashMap<String, Object>(); //原图地址 map.put("originalUrl", pathName); //缩略图地址 map.put("thumbnailUrl", thumbnailPathName); return new BaseResult(true, "操作成功", map); }
获取当前使用的配置文件信息
/** * 根据key从gzt.properties配置文件获取配置信息 * @param key 键值 * @return */ public String getSysPro(String key){ return getSysPro(key, null); } /** * 根据key从gzt.properties配置文件获取配置信息 * @param key 键值 * @param defaultValue 默认值 * @return */ public String getSysPro(String key,String defaultValue){ return getValue("spring/imageserver-"+System.getProperty("spring.profiles.active")+".properties", key, defaultValue); }
例:
//获取服务器绝对路径 linux 服务器地址 String urlString=PropertiesUtil.getInstance().getSysPro("uploadPath");
PropertiesUtil 类
package com.xyz.imageserver.common.properties; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; import java.util.Properties; import java.util.concurrent.ConcurrentHashMap; /** * * @ClassName PropertiesUtil.java * @Description 系统配置工具类 * @author caijy * @date 2015年6月9日 上午10:50:38 * @version 1.0.0 */ public class PropertiesUtil { private Logger logger = LoggerFactory.getLogger(PropertiesUtil.class); private ConcurrentHashMap<String, Properties> proMap; private PropertiesUtil() { proMap = new ConcurrentHashMap<String, Properties>(); } private static PropertiesUtil instance = new PropertiesUtil(); /** * 获取单例对象 * @return */ public static PropertiesUtil getInstance() { return instance; } /** * 根据key从gzt.properties配置文件获取配置信息 * @param key 键值 * @return */ public String getSysPro(String key){ return getSysPro(key, null); } /** * 根据key从gzt.properties配置文件获取配置信息 * @param key 键值 * @param defaultValue 默认值 * @return */ public String getSysPro(String key,String defaultValue){ return getValue("spring/imageserver-"+System.getProperty("spring.profiles.active")+".properties", key, defaultValue); } /** * 从配置文件中获取对应key值 * @param fileName 配置文件名 * @param key key值 * @param defaultValue 默认值 * @return */ public String getValue(String fileName,String key,String defaultValue){ String val = null; Properties properties = proMap.get(fileName); if(properties == null){ InputStream inputStream = PropertiesUtil.class.getClassLoader().getResourceAsStream(fileName); try { properties = new Properties(); properties.load(new InputStreamReader(inputStream,"UTF-8")); proMap.put(fileName, properties); val = properties.getProperty(key,defaultValue); } catch (IOException e) { logger.error("getValue",e); }finally{ try { if (inputStream != null) { inputStream.close(); } } catch (IOException e1) { logger.error(e1.toString()); } } }else{ val = properties.getProperty(key,defaultValue); } return val; } }
图片压缩上传Thumbnailator 插件的更多相关文章
- 三款不错的图片压缩上传插件(webuploader+localResizeIMG4+LUploader)
涉及到网页图片的交互,少不了图片的压缩上传,相关的插件有很多,相信大家都有用过,这里我就推荐三款,至于好处就仁者见仁喽: 1.名气最高的WebUploader,由Baidu FEX 团队开发,以H5为 ...
- 纯原生js移动端图片压缩上传插件
前段时间,同事又来咨询一个问题了,说手机端动不动拍照就好几M高清大图,上传服务器太慢,问问我有没有可以压缩图片并上传的js插件,当然手头上没有,别慌,我去网上搜一搜. 结果呢,呵呵...诶~又全是基于 ...
- Html5+asp.net mvc 图片压缩上传
在做图片上传时,大图片如果没有压缩直接上传时间会非常长,因为有的图片太大,传到服务器上再压缩太慢了,而且损耗流量. 思路是将图片抽样显示在canvas上,然后用通过canvas.toDataURL方法 ...
- springMVC多图片压缩上传的实现
首先需要在配置文件中添加配置: <!--配置文件的视图解析器,用于文件上传,其中ID是固定的:multipartResolver--> <bean id="multipar ...
- 基于vue + axios + lrz.js 微信端图片压缩上传
业务场景 微信端项目是基于Vux + Axios构建的,关于图片上传的业务场景有以下几点需求: 1.单张图片上传(如个人头像,实名认证等业务) 2.多张图片上传(如某类工单记录) 3.上传图片时期望能 ...
- 基于H5+ API手机相册图片压缩上传
// 母函数 function App(){} /** * 图片压缩,默认同比例压缩 * @param {Object} path * pc端传入的路径可以为相对路径,但是在移动端上必须传入的路径是照 ...
- 分享图片压缩上传demo,可以选择一张或多张图片也可以拍摄照片
2016-08-05更新: 下方的代码是比较OLD的了,是通过js进行图片的剪切 旋转 再生成,效率较低. 后来又整合了一个利用native.js本地接口的压缩代码 ,链接在这 .页面中有详细的说明, ...
- js 图片压缩上传(base64位)以及上传类型分类
一.input file上传类型 1.指明只需要图片 <input type="file" accept='image/*'> 2.指明需要多张图片 <input ...
- HTML多图片压缩上传
本文介绍的是多张图片在前端统一压缩后再通过ajax提交给后台处理的业务,使用到的是LocalResizeIMG.js插件. 一.首先介绍项目结构 二.分享引用核心文件,这里没有分享CSS文件,因为没有 ...
随机推荐
- BZOJ 3040: 最短路(road) [Dijkstra + pb_ds]
3040: 最短路(road) Time Limit: 60 Sec Memory Limit: 200 MBSubmit: 2476 Solved: 814[Submit][Status][Di ...
- 设计模式之“Decorator”注疏#02
装饰模式在某种意义上来说也是挺原始的, 它首先需要一个你被装饰的基础类, 再来是需要一个基于这个基础类的原始包装器,可以看作是其它包装器的基础类 进而通过继承这个包装器,来构建出多个具有各自功能的特定 ...
- My97DatePicker选择两个日期范围不超过30天的demo
需求 ExtJs下使用My97DatePicker对时间范围不超过30天进行选择. 关键点 使用全局变量. 对选择完的第一个日期进行逻辑判断.(我的逻辑能力还有待加强啊) 因为当选择了第一个框范围在超 ...
- web前端 ajax请求上传图片数据类型处理
form: function (url, paras, files, success) {//上传的文件类型是MultipartFile[]//如果把需要的参数直接传入,则会请求错误//设置请求参数的 ...
- bzoj 2120 带修改莫队
2120: 数颜色 Time Limit: 6 Sec Memory Limit: 259 MBSubmit: 7340 Solved: 2982[Submit][Status][Discuss] ...
- LOJ116 - 有源汇有上下界最大流
原题链接 Description 模板题啦~ Code //有源汇有上下界最大流 #include <cstdio> #include <cstring> #include & ...
- windows NLB实现MSSQL读写分离--从数据库集群读负载均衡
主从模式,几乎大部分出名的数据库都支持的一种集群模式. 当Web站点的访问量上去之后,很多站点,选择读写分离,减轻主数据库的的压力.当然,一主多从也可以作用多个功能,比如备份.这里主要演示如何实现从数 ...
- MAC地址表配置与绑定
MAC地址表分类 ---静态MAC地址表项由用户手工配置,表项不老化: ---黑洞MAC地址表项包括源黑洞MAC地址表项和目的黑洞MAC地址表项,用于丢弃含有特定源MAC地址或目的MAC地址的报文(例 ...
- Hive分区和桶
SMB 存在的目的主要是为了解决大表与大表间的 Join 问题,分桶其实就是把大表化成了“小表”,然后 Map-Side Join 解决之,这是典型的分而治之的思想.在聊 SMB Join 之前,我们 ...
- csrf
什么是CSRF: CSRF(Cross-site request forgery),中文名称:跨站请求伪造 攻击者盗用了你的身份,以你的名义发送恶意请求.CSRF能够做的事情包括:以你名义发送邮件,发 ...