【2】从零玩转OSS阿里云存储服务之Java代码操作

本文涉及的产品
对象存储 OSS,20GB 3个月
对象存储 OSS,内容安全 1000次 1年
对象存储 OSS,恶意文件检测 1000次 1年
简介: 【2】从零玩转OSS阿里云存储服务之Java代码操作

接上一个文章讲解还有一个东西忘记说

AccessKey 这玩意用来搞认证的 差不多

开通就好了…等会要用到

1735255-20200812230814175-1361287855.png

步入正题创建oss模块也就是一个项目

1735255-20200812231132735-1864665807.png

导入依赖

    <dependencies>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
        </dependency>
        <!-- 上传文件依赖组件 -->
        <dependency>
            <groupId>commons-io</groupId>
            <artifactId>commons-io</artifactId>
            <version>2.5</version>
        </dependency>
        <dependency>
            <groupId>commons-fileupload</groupId>
            <artifactId>commons-fileupload</artifactId>
            <version>1.2.2</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!-- aliyun oss -->
        <dependency>
            <groupId>com.aliyun.oss</groupId>
            <artifactId>aliyun-sdk-oss</artifactId>
            <version>3.6.0</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-test</artifactId>
            <version>5.2.7.RELEASE</version>
            <scope>test</scope>
        </dependency>
    </dependencies>
    <repositories>
        <repository>
            <id>aliyun</id>
            <name>aliyun Repository</name>
            <url>http://maven.aliyun.com/nexus/content/groups/public</url>
            <snapshots>
                <enabled>false</enabled>
            </snapshots>
        </repository>
    </repositories>

创建OSSUploadUtil.java

package top.yangbuyi.utils;
import com.aliyun.oss.ClientException;
import com.aliyun.oss.OSSClient;
import com.aliyun.oss.OSSException;
import com.aliyun.oss.model.*;
import top.yangbuyi.utils.config.OSSConfig;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
import java.util.UUID;
/**
 * @description: 杨不易网站:www.yby6.com
 * @program: yangbuyispringcloudparent
 * @ClassName: OSSUtils
 * @create: 2020-08-11 23:09
 * @author: yangbuyi
 * @since: JDK1.8
 * @OSSUploadUtil: 阿里云OSS文件上传工具类
 **/
public class OSSUploadUtil {
    private static OSSConfig config = null;
    /**
     *
     * @MethodName: uploadFile
     * @Description: OSS单文件上传
     * @param file
     * @param fileType 文件后缀
     * @return String 文件地址
     */
    public static String uploadFile(File file, String fileType){
      config = config==null?new OSSConfig():config;
      String fileName = config.getPicLocation()+ UUID.randomUUID().toString().toUpperCase().replace("-", "")+"."+fileType; //文件名,根据UUID来
      return putObject(file,fileType,fileName);
    }
    /**
     *
     * @MethodName: updateFile
     * @Description: 更新文件:只更新内容,不更新文件名和文件地址。
     *      (因为地址没变,可能存在浏览器原数据缓存,不能及时加载新数据,例如图片更新,请注意)
     * @param file
     * @param fileType
     * @param oldUrl
     * @return String
     */
    public static String updateFile(File file,String fileType,String oldUrl){
      String fileName = getFileName(oldUrl);
      if(fileName==null) return null;
      return putObject(file,fileType,fileName);
    }
    /**
     *
     * @MethodName: replaceFile
     * @Description: 替换文件:删除原文件并上传新文件,文件名和地址同时替换
     *      解决原数据缓存问题,只要更新了地址,就能重新加载数据)
     * @param file
     * @param fileType 文件后缀
     * @param oldUrl 需要删除的文件地址
     * @return String 文件地址
     */
    public static String replaceFile(File file,String fileType,String oldUrl){
      boolean flag = deleteFile(oldUrl);      //先删除原文件
      if(!flag){
          //更改文件的过期时间,让他到期自动删除。
      }
      return uploadFile(file, fileType);
    }
    /**
     *
     * @MethodName: deleteFile
     * @Description: 单文件删除
     * @param fileUrl 需要删除的文件url
     * @return boolean 是否删除成功
     */
    public static boolean deleteFile(String fileUrl){
      config = config==null?new OSSConfig():config;
      String bucketName = OSSUploadUtil.getBucketName(fileUrl);       //根据url获取bucketName
      String fileName = OSSUploadUtil.getFileName(fileUrl);           //根据url获取fileName
      if(bucketName==null||fileName==null) return false;
      OSSClient ossClient = null;
      try {
          ossClient = new OSSClient(config.getEndpoint(), config.getAccessKeyId(), config.getAccessKeySecret());
          GenericRequest request = new DeleteObjectsRequest(bucketName).withKey(fileName);
          ossClient.deleteObject(request);
      } catch (Exception oe) {
          oe.printStackTrace();
          return false;
      } finally {
          ossClient.shutdown();
      }
      return true;
    }
    /**
     *
     * @MethodName: batchDeleteFiles
     * @Description: 批量文件删除(较快):适用于相同endPoint和BucketName
     * @param fileUrls 需要删除的文件url集合
     * @return int 成功删除的个数
     */
    public static int deleteFile(List<String> fileUrls){
      int deleteCount = 0;    //成功删除的个数
      String bucketName = OSSUploadUtil.getBucketName(fileUrls.get(0));       //根据url获取bucketName
      List<String> fileNames = OSSUploadUtil.getFileName(fileUrls);         //根据url获取fileName
      if(bucketName==null||fileNames.size()<=0) return 0;
      OSSClient ossClient = null;
      try {
          ossClient = new OSSClient(config.getEndpoint(), config.getAccessKeyId(), config.getAccessKeySecret());
          DeleteObjectsRequest request = new DeleteObjectsRequest(bucketName).withKeys(fileNames);
          DeleteObjectsResult result = ossClient.deleteObjects(request);
          deleteCount = result.getDeletedObjects().size();
      } catch (OSSException oe) {
          oe.printStackTrace();
          throw new RuntimeException("OSS服务异常:", oe);
      } catch (ClientException ce) {
          ce.printStackTrace();
          throw new RuntimeException("OSS客户端异常:", ce);
      } finally {
          ossClient.shutdown();
      }
      return deleteCount;
    }
    /**
     *
     * @MethodName: batchDeleteFiles
     * @Description: 批量文件删除(较慢):适用于不同endPoint和BucketName
     * @param fileUrls 需要删除的文件url集合
     * @return int 成功删除的个数
     */
    public static int deleteFiles(List<String> fileUrls){
      int count = 0;
      for (String url : fileUrls) {
          if(deleteFile(url)){
            count++;
          }
      }
      return count;
    }
    /**
     *
     * @MethodName: putObject
     * @Description: 上传文件
     * @param file
     * @param fileType
     * @param fileName
     * @return String
     */
    private static String putObject(File file,String fileType,String fileName){
      config = config==null?new OSSConfig():config;
      String url = null;      //默认null
      OSSClient ossClient = null;
      try {
          ossClient = new OSSClient(config.getEndpoint(), config.getAccessKeyId(), config.getAccessKeySecret());
          InputStream input = new FileInputStream(file);
          ObjectMetadata meta = new ObjectMetadata();             // 创建上传Object的Metadata
          meta.setContentType(OSSUploadUtil.contentType(fileType));       // 设置上传内容类型
          meta.setCacheControl("no-cache");                   // 被下载时网页的缓存行为
          PutObjectRequest request = new PutObjectRequest(config.getBucketName(), fileName,input,meta);           //创建上传请求
          ossClient.putObject(request);
          url = config.getEndpoint().replaceFirst("https://","https://"+config.getBucketName()+"."+ config.getEndpoint())+"/"+fileName;       //上传成功再返回的文件路径
      } catch (OSSException oe) {
          oe.printStackTrace();
          return null;
      } catch (ClientException ce) {
          ce.printStackTrace();
          return null;
      } catch (FileNotFoundException e) {
          e.printStackTrace();
          return null;
      } finally {
          ossClient.shutdown();
      }
      return url;
    }
    /**
     *
     * @MethodName: contentType
     * @Description: 获取文件类型
     * @param FileType
     * @return String
     */
    private static String contentType(String fileType){
      fileType = fileType.toLowerCase();
      String contentType = "";
      switch (fileType) {
          case "bmp": contentType = "image/bmp";
            break;
          case "gif": contentType = "image/gif";
            break;
          case "png":
          case "jpeg":
          case "jpg": contentType = "image/jpeg";
            break;
          case "html":contentType = "text/html";
            break;
          case "txt": contentType = "text/plain";
            break;
          case "vsd": contentType = "application/vnd.visio";
            break;
          case "ppt":
          case "pptx":contentType = "application/vnd.ms-powerpoint";
            break;
          case "doc":
          case "docx":contentType = "application/msword";
            break;
          case "xml":contentType = "text/xml";
            break;
          case "mp4":contentType = "video/mp4";
            break;
          default: contentType = "application/octet-stream";
            break;
      }
      return contentType;
    }
    /**
     *
     * @MethodName: getBucketName
     * @Description: 根据url获取bucketName
     * @param fileUrl 文件url
     * @return String bucketName
     */
    private static String getBucketName(String fileUrl){
      String http = "http://";
      String https = "https://";
      int httpIndex = fileUrl.indexOf(http);
      int httpsIndex = fileUrl.indexOf(https);
      int startIndex  = 0;
      if(httpIndex==-1){
          if(httpsIndex==-1){
            return null;
          }else{
            startIndex = httpsIndex+https.length();
          }
      }else{
          startIndex = httpIndex+http.length();
      }
      int endIndex = fileUrl.indexOf(".oss-");
      return fileUrl.substring(startIndex, endIndex);
    }
    /**
     *
     * @MethodName: getFileName
     * @Description: 根据url获取fileName
     * @param fileUrl 文件url
     * @return String fileName
     */
    private static String getFileName(String fileUrl){
      String str = "yby6.com/";
      int beginIndex = fileUrl.indexOf(str);
      if(beginIndex==-1) return null;
      return fileUrl.substring(beginIndex+str.length());
    }
    /**
     *
     * @MethodName: getFileName
     * @Description: 根据url获取fileNames集合
     * @param fileUrl 文件url
     * @return List<String>  fileName集合
     */
    private static List<String> getFileName(List<String> fileUrls){
      List<String> names = new ArrayList<>();
      for (String url : fileUrls) {
          names.add(getFileName(url));
      }
      return names;
    }
}

创建Config.properties配置文件到resources下

#阿里云OSS配置
endpoint = oss-img.yby6.com # 访问节点  这里表示 uri访问的图片域名相当于一个域名
bucketName = yangbuyi-img # 你创建的Bucket
picLocation = 文件夹路径 随便填  如: yangbuyi/
accessKeyId = 第一张图片要你开通的 ID
accessKeySecret = 第一张图片要你开通的 密码

创建SystemConfig.java 处理配置文件

package top.yangbuyi.utils;
import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;
/**
 * @description: 杨不易网站:www.yby6.com
 * @program: yangbuyispringcloudparent
 * @ClassName: SystemConfig
 * @create: 2020-08-12 00:04
 * @author: yangbuyi
 * @since: JDK1.8
 * @SystemConfig:
 **/
public class SystemConfig {
     private static final String CONFIG_PROPERTIES="config.properties";
     public static String getConfigResource(String key) throws IOException {
         ClassLoader loader = Thread.currentThread().getContextClassLoader();
         Properties properties = new Properties();
         InputStream in = loader.getResourceAsStream(CONFIG_PROPERTIES);
         properties.load(in);
         String value = properties.getProperty(key);
         // 编码转换,从ISO-8859-1转向指定编码
         value = new String(value.getBytes("ISO-8859-1"), "UTF-8");
         in.close();
         return value;
     }
}

创建config文件夹下的OSSConfig.java

package top.yangbuyi.utils.config;
import top.yangbuyi.utils.SystemConfig;
import java.io.IOException;
/**
 * @description: 杨不易网站:www.yby6.com
 * @program: yangbuyispringcloudparent
 * @ClassName: OSSConfig
 * @create: 2020-08-12 00:04
 * @author: yangbuyi
 * @since: JDK1.8
 * @OSSConfig:
 **/
public class OSSConfig{
     private  String endpoint;       //连接区域地址
     private  String accessKeyId;    //连接keyId
     private  String accessKeySecret;    //连接秘钥
     private  String bucketName;     //需要存储的bucketName
     private  String picLocation;    //图片保存路径
     /*
     * 加载配置文件 初始化 参数
     * 也可 yml加载 看你自己  
     * */
     public OSSConfig() {
         try {
              this.endpoint = SystemConfig.getConfigResource("endpoint");
              this.bucketName = SystemConfig.getConfigResource("bucketName");
              this.picLocation = SystemConfig.getConfigResource("picLocation");
              this.accessKeyId = SystemConfig.getConfigResource("accessKeyId");
              this.accessKeySecret = SystemConfig.getConfigResource("accessKeySecret");
         } catch (IOException e) {
              e.printStackTrace();
         }
     }
     public String getEndpoint() {
         return endpoint;
     }
     public void setEndpoint(String endpoint) {
         this.endpoint = endpoint;
     }
     public String getAccessKeyId() {
         return accessKeyId;
     }
     public void setAccessKeyId(String accessKeyId) {
         this.accessKeyId = accessKeyId;
     }
     public String getAccessKeySecret() {
         return accessKeySecret;
     }
     public void setAccessKeySecret(String accessKeySecret) {
         this.accessKeySecret = accessKeySecret;
     }
     public String getBucketName() {
         return bucketName;
     }
     public void setBucketName(String bucketName) {
         this.bucketName = bucketName;
     }
     public String getPicLocation() {
         return picLocation;
     }
     public void setPicLocation(String picLocation) {
         this.picLocation = picLocation;
     }
     @Override
     public String toString() {
         return "OSSConfig{" +
               "endpoint='" + endpoint + '\'' +
               ", accessKeyId='" + accessKeyId + '\'' +
               ", accessKeySecret='" + accessKeySecret + '\'' +
               ", bucketName='" + bucketName + '\'' +
               ", picLocation='" + picLocation + '\'' +
               '}';
     }
}

在测试当中创建测试类

import org.junit.Test;
import top.yangbuyi.utils.OSSUploadUtil;
import top.yangbuyi.utils.OSSUtils;
import java.io.File;
/**
 * @description: 杨不易网站:www.yby6.com
 * @program: yangbuyispringcloudparent
 * @ClassName: two
 * @create: 2020-08-12 00:06
 * @author: yangbuyi
 * @since: JDK1.8
 * @two: OSSUploadUtil.uploadFile(File file, String fileType) //单文件上传,type:文件后缀名
 * OSSUploadUtil.updateFile(File file, String fileType, String oldUrl)//更新文件:只更新内容,不更新文件名和文件地址。
 * OSSUploadUtil.replaceFile(File file, String fileType, String oldUrl)//替换文件,删除源文件并上传新文件,文件名和地址也改变
 * OSSUploadUtil.deleteFile(List<String> fileUrls)  //删除多文件,根据问价url来自定获取其中的bucket和文件名,用于bucket和文件名可能存在不同的,循环调用deleteFile方法
 * OSSUploadUtil.deleteFile(String fileUrl) //删除单文件
 * OSSUploadUtil.deleteFiles(List<String> fileUrls)  //删除多文件,根据配置直接取删除多个文件,bucket和文件地址从配置中获取,用于多文件bucket和文件名都相同的
 **/
public class two {
     @Test
     public void t() {
         // 文件上传
         File file = new File("F:\\美女图片\\dac18dd66fbbf53ddd55563b5edecac6.jpg");
         String jpg = OSSUploadUtil.uploadFile(file, "jpg");
         System.out.println(jpg);
         // 更新 只更新 图片  不更新名称
         System.out.println("更新图片开始:" + "http://oss-img.yby6.com/github.png");
         File file2 = new File("F:\\美女图片\\httpsimg2020.cnblogs.comblog17352552020081735255-20200805220326890-2058657956.jpg");
         String jpg1 = OSSUploadUtil.updateFile(file2, "jpg", "http://oss-img.yby6.com/github.png");
         System.out.println("更新后的:" + jpg1);
         // 删除  根据url 删除图片
//       boolean b = OSSUploadUtil.deleteFile("https://yangbuyi.oss-cn-beijing.aliyuncs.com/imgBAA8AD5484D847E09BDB535765A9EEB9.jpg");
//       System.out.println(b);
     }
}

列举常用的上传

方法名

描述

OSSUploadUtil.uploadFile(File file, String fileType)

单文件上传,type:文件后缀名

OSSUploadUtil.updateFile(File file, String fileType, String oldUrl)

 更新文件:只更新内容,不更新文件名和文件地址。

OSSUploadUtil.deleteFiles(List fileUrls)

删除多文件,根据配置直接取删除多个文件,bucket和文件地址从配置中获取,用于多文件bucket和文件名都相同的

OSSUploadUtil.deleteFile(String fileUrl)

根据url删除单文件

OSSUploadUtil.replaceFile(File file, String fileType, String oldUrl)

替换文件,删除源文件并上传新文件,文件名和地址也改变

OSSUploadUtil.deleteFile(List fileUrls)

 删除多文件,根据问价url来自定获取其中的bucket和文件名,用于bucket和文件名可能存在不同的,循环调用deleteFile方法

看到这 是不是觉得 超级简单 就CV大法。。

看到这 是不是觉得 超级简单 就CV大法。。

给到的项目地址 有不同oss实现 本文章只讲了 OSSuploadUtil 对应的测试类为 two.java

测试完毕复制url访问

https://oss-yby.yby6.com/uni-app/1602927243%281%29.jpg

项目地址: https://gitee.com/yangbuyi/ossAlibaba

oss云存储完毕

相关实践学习
借助OSS搭建在线教育视频课程分享网站
本教程介绍如何基于云服务器ECS和对象存储OSS,搭建一个在线教育视频课程分享网站。
相关文章
|
11天前
|
安全 Java 编译器
深入理解Java中synchronized三种使用方式:助您写出线程安全的代码
`synchronized` 是 Java 中的关键字,用于实现线程同步,确保多个线程互斥访问共享资源。它通过内置的监视器锁机制,防止多个线程同时执行被 `synchronized` 修饰的方法或代码块。`synchronized` 可以修饰非静态方法、静态方法和代码块,分别锁定实例对象、类对象或指定的对象。其底层原理基于 JVM 的指令和对象的监视器,JDK 1.6 后引入了偏向锁、轻量级锁等优化措施,提高了性能。
35 3
|
18天前
|
前端开发 Java 测试技术
java日常开发中如何写出优雅的好维护的代码
代码可读性太差,实际是给团队后续开发中埋坑,优化在平时,没有那个团队会说我专门给你一个月来优化之前的代码,所以在日常开发中就要多注意可读性问题,不要写出几天之后自己都看不懂的代码。
55 2
|
1月前
|
Java 编译器 数据库
Java 中的注解(Annotations):代码中的 “元数据” 魔法
Java注解是代码中的“元数据”标签,不直接参与业务逻辑,但在编译或运行时提供重要信息。本文介绍了注解的基础语法、内置注解的应用场景,以及如何自定义注解和结合AOP技术实现方法执行日志记录,展示了注解在提升代码质量、简化开发流程和增强程序功能方面的强大作用。
79 5
|
1月前
|
存储 算法 Java
Java 内存管理与优化:掌控堆与栈,雕琢高效代码
Java内存管理与优化是提升程序性能的关键。掌握堆与栈的运作机制,学习如何有效管理内存资源,雕琢出更加高效的代码,是每个Java开发者必备的技能。
55 5
|
1月前
|
安全 Java API
Java中的Lambda表达式:简化代码的现代魔法
在Java 8的发布中,Lambda表达式的引入无疑是一场编程范式的革命。它不仅让代码变得更加简洁,还使得函数式编程在Java中成为可能。本文将深入探讨Lambda表达式如何改变我们编写和维护Java代码的方式,以及它是如何提升我们编码效率的。
|
6月前
|
机器学习/深度学习 人工智能 专有云
人工智能平台PAI使用问题之怎么将DLC的数据写入到另一个阿里云主账号的OSS中
阿里云人工智能平台PAI是一个功能强大、易于使用的AI开发平台,旨在降低AI开发门槛,加速创新,助力企业和开发者高效构建、部署和管理人工智能应用。其中包含了一系列相互协同的产品与服务,共同构成一个完整的人工智能开发与应用生态系统。以下是对PAI产品使用合集的概述,涵盖数据处理、模型开发、训练加速、模型部署及管理等多个环节。
|
2月前
|
分布式计算 Java 开发工具
阿里云MaxCompute-XGBoost on Spark 极限梯度提升算法的分布式训练与模型持久化oss的实现与代码浅析
本文介绍了XGBoost在MaxCompute+OSS架构下模型持久化遇到的问题及其解决方案。首先简要介绍了XGBoost的特点和应用场景,随后详细描述了客户在将XGBoost on Spark任务从HDFS迁移到OSS时遇到的异常情况。通过分析异常堆栈和源代码,发现使用的`nativeBooster.saveModel`方法不支持OSS路径,而使用`write.overwrite().save`方法则能成功保存模型。最后提供了完整的Scala代码示例、Maven配置和提交命令,帮助用户顺利迁移模型存储路径。
|
5月前
|
存储 机器学习/深度学习 弹性计算
阿里云EMR数据湖文件系统问题之OSS-HDFS全托管服务的问题如何解决
阿里云EMR数据湖文件系统问题之OSS-HDFS全托管服务的问题如何解决
|
6月前
|
消息中间件 分布式计算 DataWorks
DataWorks产品使用合集之如何使用Python和阿里云SDK读取OSS中的文件
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
|
6月前
|
存储 运维 安全
阿里云OSS的优势
【7月更文挑战第19天】阿里云OSS的优势
248 2