oss对zip包中的所有文件进行上传并且对每个获取文件md5值

2024-05-25 19:18

本文主要是介绍oss对zip包中的所有文件进行上传并且对每个获取文件md5值,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 上传zip包方法

 public static List<String> uploadZipMultiFile(MultipartFile fileData) {List<String> urls = new ArrayList<>();ZipInputStream zip = new ZipInputStream(fileData.getInputStream(), Charset.forName("UTF-8"));ZipEntry fileEntry;String env = "resource/";while ((fileEntry = zip.getNextEntry()) != null) {if (!fileEntry.isDirectory()) {String filename = fileEntry.getName();String suffix = StringUtils.substringAfterLast(filename, ".");filename = env + filename;@Cleanup ByteArrayOutputStream byteArrayOutputStream=new ByteArrayOutputStream();byte[] byte_s=new byte[1024];int num;while((num=zip.read(byte_s,0,byte_s.length))>-1) {//通过read方法来读取文件内容byteArrayOutputStream.write(byte_s, 0, num);}byte[] byte_s_=byteArrayOutputStream.toByteArray();String md5 = DigestUtils.md5Hex(byte_s_);createFolder(env);uploadFile(filename,byte_s_);filename= filename+"?md5="+md5;if (StringUtils.contains(contentType(suffix), "image")) {urls.add(OSS_IMAGE_HOST + filename);} else {urls.add( OSS_HOST + filename);}}}zip.close();return urls;}/*** @param key* @param content 文件内容* @throws Exception*/private static void uploadFile(String key, byte[] content) throws Exception {ObjectMetadata objectMeta = new ObjectMetadata();objectMeta.setContentLength(content.length);@Cleanup InputStream input = new ByteArrayInputStream(content);client.putObject(OSS_BUCKET, key, input, objectMeta);}/*** 创建目录** @param path 目录结构,这个有要求必须是 "xxx/xxx/" 以目录名开头,/结尾* @throws IOException*/private static void createFolder(String path) throws IOException {if (folderCache.containsKey(path)) return;ObjectMetadata objectMeta = new ObjectMetadata();byte[] buffer = new byte[0];objectMeta.setContentLength(0);try (ByteArrayInputStream in = new ByteArrayInputStream(buffer)) {client.putObject(OSS_BUCKET, path, in, objectMeta);}folderCache.put(path, true);}

 

这篇关于oss对zip包中的所有文件进行上传并且对每个获取文件md5值的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

SpringBoot实现不同接口指定上传文件大小的具体步骤

《SpringBoot实现不同接口指定上传文件大小的具体步骤》:本文主要介绍在SpringBoot中通过自定义注解、AOP拦截和配置文件实现不同接口上传文件大小限制的方法,强调需设置全局阈值远大于... 目录一  springboot实现不同接口指定文件大小1.1 思路说明1.2 工程启动说明二 具体实施2

SpringBoot 获取请求参数的常用注解及用法

《SpringBoot获取请求参数的常用注解及用法》SpringBoot通过@RequestParam、@PathVariable等注解支持从HTTP请求中获取参数,涵盖查询、路径、请求体、头、C... 目录SpringBoot 提供了多种注解来方便地从 HTTP 请求中获取参数以下是主要的注解及其用法:1

Nginx中配置使用非默认80端口进行服务的完整指南

《Nginx中配置使用非默认80端口进行服务的完整指南》在实际生产环境中,我们经常需要将Nginx配置在其他端口上运行,本文将详细介绍如何在Nginx中配置使用非默认端口进行服务,希望对大家有所帮助... 目录一、为什么需要使用非默认端口二、配置Nginx使用非默认端口的基本方法2.1 修改listen指令

MySQL按时间维度对亿级数据表进行平滑分表

《MySQL按时间维度对亿级数据表进行平滑分表》本文将以一个真实的4亿数据表分表案例为基础,详细介绍如何在不影响线上业务的情况下,完成按时间维度分表的完整过程,感兴趣的小伙伴可以了解一下... 目录引言一、为什么我们需要分表1.1 单表数据量过大的问题1.2 分表方案选型二、分表前的准备工作2.1 数据评估

MySQL进行分片合并的实现步骤

《MySQL进行分片合并的实现步骤》分片合并是指在分布式数据库系统中,将不同分片上的查询结果进行整合,以获得完整的查询结果,下面就来具体介绍一下,感兴趣的可以了解一下... 目录环境准备项目依赖数据源配置分片上下文分片查询和合并代码实现1. 查询单条记录2. 跨分片查询和合并测试结论分片合并(Shardin

SpringBoot结合Knife4j进行API分组授权管理配置详解

《SpringBoot结合Knife4j进行API分组授权管理配置详解》在现代的微服务架构中,API文档和授权管理是不可或缺的一部分,本文将介绍如何在SpringBoot应用中集成Knife4j,并进... 目录环境准备配置 Swagger配置 Swagger OpenAPI自定义 Swagger UI 底

基于Python Playwright进行前端性能测试的脚本实现

《基于PythonPlaywright进行前端性能测试的脚本实现》在当今Web应用开发中,性能优化是提升用户体验的关键因素之一,本文将介绍如何使用Playwright构建一个自动化性能测试工具,希望... 目录引言工具概述整体架构核心实现解析1. 浏览器初始化2. 性能数据收集3. 资源分析4. 关键性能指

Nginx进行平滑升级的实战指南(不中断服务版本更新)

《Nginx进行平滑升级的实战指南(不中断服务版本更新)》Nginx的平滑升级(也称为热升级)是一种在不停止服务的情况下更新Nginx版本或添加模块的方法,这种升级方式确保了服务的高可用性,避免了因升... 目录一.下载并编译新版Nginx1.下载解压2.编译二.替换可执行文件,并平滑升级1.替换可执行文件