全面了解阿里云OSS使用方法

本文涉及的产品
对象存储 OSS,20GB 3个月
对象存储 OSS,内容安全 1000次 1年
对象存储 OSS,恶意文件检测 1000次 1年
简介: 本文介绍了阿里云对象存储(OSS)的准备工作、服务开通、优势、使用步骤以及代码实现。首先,用户需要注册阿里云账号并进行实名认证,然后开通OSS服务,创建存储空间。阿里云OSS提供高可靠、安全、低成本的云存储,适合各种数据存储和分发场景。接着,通过官方SDK学习如何上传文件,并提供了Java代码示例。最后,展示了如何在Spring Boot项目中集成阿里云OSS,实现文件上传功能。

一,准备工作

点击:注册阿里云账号,输入用户名,手机号,验证码

然后点击:个人中心,做一下实名,建议选择企业实名,因为阿里云个人实名无法索取企业发票


二,什么是阿里云OSS

阿里云对象存储(Alibaba Cloud Object Storage Service,简称OSS)是阿里云提供的海量、安全、低成本、高可靠的云存储服务。用户可以通过简单的API接口在任何时间、任何地点上传和下载数据,适用于图像、音视频、文档、网站等各种类型的数据存储和分发场景。

2.1,阿里云OSS的优点

高可靠性:OSS采用了多副本存储和容灾备份机制,确保数据的高可靠性和持久性。

安全性:支持多种安全策略,如访问控制、加密传输等,保障数据的安全性。

弹性扩展:支持按需存储和弹性扩展,用户可以根据实际需求灵活调整存储容量。

低成本:OSS的存储费用低廉,且支持按量付费模式,使用户能够根据实际使用量付费

2.2,为什么要使用云服务OSS

解决本地存储无法直接访问,本地磁盘空间有限,本地磁盘损坏这3个问题

三,使用步骤

3.1,OSS开通

(1)开通OSS

点击:OSS购买页面,点击购买

image.png

选择:预留空间

image.png

登录阿里云官网。 点击右上角的控制台

将鼠标移至产品,找到并单击对象存储OSS,打开OSS产品详情页面。在OSS产品详情

页中的单击立即开通。

开通服务后,在OSS产品详情页面单击管理控制台直接进入OSS管理控制台界面。您也

可以单击位于官网首页右上方菜单栏的控制台,进入阿里云管理控制台首页,然后单

击左侧的对象存储OSS菜单进入OSS管理控制台界面。

创建存储空间

新建Bucket,命名为 hmleadnews ,读写权限为 公共读

3.2,参考官方SDK

四,编写代码

我把脚手架上传到网盘里面了,有需要的同学自取

我用夸克网盘分享了「tlias-web-management」,点击链接即可保存。

链接:https://pan.quark.cn/s/6171608c92b2

我们打开网盘里面的代码

在pom文件中添加下面的代码

<!--阿里云OSS-->

       <dependency>

           <groupId>com.aliyun.oss</groupId>

           <artifactId>aliyun-sdk-oss</artifactId>

           <version>3.15.1</version>

       </dependency>


如果使用的是Java 9及以上的版本,则需要添加jaxb相关依赖。添加jaxb相关依赖示例代码如下:

<dependency>

   <groupId>javax.xml.bind</groupId>

   <artifactId>jaxb-api</artifactId>

   <version>2.3.1</version>

</dependency>

<dependency>

   <groupId>javax.activation</groupId>

   <artifactId>activation</artifactId>

   <version>1.1.1</version>

</dependency>

<!-- no more than 2.3.3-->

<dependency>

   <groupId>org.glassfish.jaxb</groupId>

   <artifactId>jaxb-runtime</artifactId>

   <version>2.3.3</version>

</dependency>

4.1,上传文件

我们返回官方文档,找到上传文件

上传字符串

以下代码用于将字符串上传到目标存储空间examplebucket中exampledir目录下的exampleobject.txt文件。

import com.aliyun.oss.ClientException;

import com.aliyun.oss.OSS;

import com.aliyun.oss.common.auth.*;

import com.aliyun.oss.OSSClientBuilder;

import com.aliyun.oss.OSSException;

import com.aliyun.oss.model.PutObjectRequest;

import com.aliyun.oss.model.PutObjectResult;

import java.io.ByteArrayInputStream;

public class Demo {

   public static void main(String[] args) throws Exception {

       // Endpoint以华东1(杭州)为例,其它Region请按实际情况填写。

       String endpoint = "填写自己的";

       // 从环境变量中获取访问凭证。运行本代码示例之前,请确保已设置环境变量OSS_ACCESS_KEY_ID和OSS_ACCESS_KEY_SECRET。

       EnvironmentVariableCredentialsProvider credentialsProvider = CredentialsProviderFactory.newEnvironmentVariableCredentialsProvider();

       // 填写Bucket名称,例如examplebucket。

       String bucketName = "examplebucket";

       // 填写Object完整路径,完整路径中不能包含Bucket名称,例如exampledir/exampleobject.txt。

       String objectName = "exampledir/exampleobject.txt";

       // 创建OSSClient实例。

       OSS ossClient = new OSSClientBuilder().build(endpoint, credentialsProvider);

       try {

           // 填写字符串。

           String content = "Hello OSS,你好世界";

           // 创建PutObjectRequest对象。

           PutObjectRequest putObjectRequest = new PutObjectRequest(bucketName, objectName, new ByteArrayInputStream(content.getBytes()));

           // 如果需要上传时设置存储类型和访问权限,请参考以下示例代码。

           // ObjectMetadata metadata = new ObjectMetadata();

           // metadata.setHeader(OSSHeaders.OSS_STORAGE_CLASS, StorageClass.Standard.toString());

           // metadata.setObjectAcl(CannedAccessControlList.Private);

           // putObjectRequest.setMetadata(metadata);

         

           // 上传字符串。

           PutObjectResult result = ossClient.putObject(putObjectRequest);            

       } catch (OSSException oe) {

           System.out.println("Caught an OSSException, which means your request made it to OSS, "

                   + "but was rejected with an error response for some reason.");

           System.out.println("Error Message:" + oe.getErrorMessage());

           System.out.println("Error Code:" + oe.getErrorCode());

           System.out.println("Request ID:" + oe.getRequestId());

           System.out.println("Host ID:" + oe.getHostId());

       } catch (ClientException ce) {

           System.out.println("Caught an ClientException, which means the client encountered "

                   + "a serious internal problem while trying to communicate with OSS, "

                   + "such as not being able to access the network.");

           System.out.println("Error Message:" + ce.getMessage());

       } finally {

           if (ossClient != null) {

               ossClient.shutdown();

           }

       }

   }

}    

把代码的相关内容修改为自己的

五,综合案例

我们创建工具类包,导入阿里云工具类相关代码

package com.itheima.utils;

import com.aliyun.oss.OSS;

import com.aliyun.oss.OSSClientBuilder;

import org.springframework.web.multipart.MultipartFile;

import java.io.*;

import java.util.UUID;

/**

* 阿里云 OSS 工具类

*/

public class AliOSSUtils {

   private String endpoint = "填写自己的";

   private String accessKeyId = "填写自己的";

   private String accessKeySecret = "填写自己的";

   private String bucketName = "填写自己的";

   /**

    * 实现上传图片到OSS

    */

   public String upload(MultipartFile file) throws IOException {

       // 获取上传的文件的输入流

       InputStream inputStream = file.getInputStream();

       // 避免文件覆盖

       String originalFilename = file.getOriginalFilename();

       String fileName = UUID.randomUUID().toString() + originalFilename.substring(originalFilename.lastIndexOf("."));

       //上传文件到 OSS

       OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);

       ossClient.putObject(bucketName, fileName, inputStream);

       //文件访问路径

       String url = endpoint.split("//")[0] + "//" + bucketName + "." + endpoint.split("//")[1] + "/" + fileName;

       // 关闭ossClient

       ossClient.shutdown();

       return url;// 把上传到oss的路径返回

   }

}

把代码的相关内容修改为自己的

在AliOSSUtils中加上@Component注解,交给ioc容器进行管理

编写UploadController类

写入下面的代码

package com.itheima.controller;

import com.itheima.pojo.Result;

import com.itheima.utils.AliOSSUtils;

import lombok.extern.slf4j.Slf4j;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.web.bind.annotation.PostMapping;

import org.springframework.web.bind.annotation.RestController;

import org.springframework.web.multipart.MultipartFile;

import java.io.IOException;

@Slf4j

@RestController

public class UploadController {

 

   @Autowired

   private AliOSSUtils aliOSSUtils;

 

   @PostMapping("/upload")

   public Result upload(MultipartFile image) throws IOException {

       log.info("文件上传,文件名{}",image.getOriginalFilename());

     

       //调用阿里云OSS工具类进行文件上传

       String url=aliOSSUtils.upload(image);

       log.info("文件上传完成,url:{}", url);

     

       return Result.success(url);

   }

}

完结,散花!

相关实践学习
借助OSS搭建在线教育视频课程分享网站
本教程介绍如何基于云服务器ECS和对象存储OSS,搭建一个在线教育视频课程分享网站。
相关文章
|
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的优势
247 2
|
6月前
|
存储 API 开发工具
阿里云OSS
【7月更文挑战第19天】阿里云OSS
211 1
|
6月前
|
存储 弹性计算 对象存储
预留空间是什么?阿里云OSS对象存储预留空间说明
阿里云OSS预留空间是预付费存储产品,提供折扣价以锁定特定容量,适用于抵扣有地域属性的Bucket标准存储费用及ECS快照费。通过购买预留空间,如500GB通用预留+100GB标准-本地冗余存储包,用户可优化成本。
242 4
|
7月前
|
SQL 分布式计算 DataWorks
DataWorks产品使用合集之如何将CSV文件从阿里云OSS同步到ODPS表,并且使用列作为表分区
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
DataWorks产品使用合集之如何将CSV文件从阿里云OSS同步到ODPS表,并且使用列作为表分区
|
6月前
|
人工智能 对象存储
【阿里云AI助理】自家产品提供错误答案。阿里云OSS 资源包类型: 下行流量 地域: 中国内地通用 下行流量包规格: 300 GB 套餐: 下行流量包(中国内地) ,包1年。那么这个是每月300GB,1年是3600GB的流量;还是1年只有300GB的流量?
自家产品提供错误答案。阿里云OSS 资源包类型: 下行流量 地域: 中国内地通用 下行流量包规格: 300 GB 套餐: 下行流量包(中国内地) ,包1年。那么这个是每月300GB,1年是3600GB的流量;还是1年只有300GB的流量?
146 1
|
8月前
|
SQL 分布式计算 监控
基于阿里云 EMR Serverless Spark 版快速搭建OSS日志分析应用
本文演示了使用 EMR Serverless Spark 产品搭建一个日志分析应用的全流程,包括数据开发和生产调度以及交互式查询等场景。
56614 7
基于阿里云 EMR Serverless Spark 版快速搭建OSS日志分析应用