云存储解决方案-阿里云OSS

1. 阿里云 OSS 简介
阿里云对象存储服务( Object Storage Service ,简称 OSS )为您提供基于网络的数据
存取服务。使用 OSS ,您可以通过网络随时存储和调用包括文本、图片、音频和视频
等在内的各种非结构化数据文件。
阿里云 OSS 将数据文件以对象( object )的形式上传到存储空间( bucket )中。
您可以进行以下操作:
创建一个或者多个存储空间,向每个存储空间中添加一个或多个文件。
通过获取已上传文件的地址进行文件的分享和下载。
通过修改存储空间或文件的属性或元信息来设置相应的访问权限。
在阿里云管理控制台执行基本和高级 OSS 任务。
使用阿里云开发工具包或直接在应用程序中进行 RESTful API 调用执行基本和高级
OSS 任务
2. OSS 开通
1 )打开 https://www.aliyun.com/ ,申请阿里云账号并完成实名认证。  
(2)充值 (可以不用做)
(3)开通OSS
登录阿里云官网。 点击右上角的控制台。

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

 

 

开通服务后,在OSS产品详情页面单击管理控制台直接进入OSS管理控制台界面。您也
可以单击位于官网首页右上方菜单栏的控制台,进入阿里云管理控制台首页,然后单
击左侧的对象存储OSS菜单进入OSS管理控制台界面。
(4)创建存储空间
新建 

 

(4)创建存储空间
新建Bucket,命名为 ****** ,读写权限为 公共读 

3. OSS快速入门
参考文档官方
(1)创建测试工程,引入依赖

<dependency>
<groupId>com.aliyun.oss</groupId>
<artifactId>aliyun-sdk-oss</artifactId>
<version>3.15.1</version>
</dependency>

(2)新建类和main方法

import org.junit.jupiter.api.Test;
import com.aliyun.oss.ClientException;
import com.aliyun.oss.OSS;
import com.aliyun.oss.OSSClientBuilder;
import com.aliyun.oss.OSSException;
import java.io.FileInputStream;
import java.io.InputStream;
public class AliOssTest {
@Test
public void testOss(){
// Endpoint以华东1(杭州)为例,其它Region请按实际情况填写。
String endpoint = "https://oss-cn-hangzhou.aliyuncs.com";
// 阿里云账号AccessKey拥有所有API的访问权限,风险很高。强烈建
议您创建并使用RAM用户进行API访问或日常运维,请登录RAM控制台创建RAM用
户。
String accessKeyId = "---------------------";
String accessKeySecret = "-----------------------";
// 填写Bucket名称,例如examplebucket。
String bucketName = "-----------";
// 填写Object完整路径,完整路径中不能包含Bucket名称,例如
exampledir/exampleobject.txt。
String objectName = "0001.jpg";
// 填写本地文件的完整路径,例如
D:\\localpath\\examplefile.txt。

// 如果未指定本地路径,则默认从示例程序所属项目对应本地路径中
上传文件流。
String filePath=
"C:\\Users\\Administrator\\Pictures\\Saved Pictures\\10.jpg";
// 创建OSSClient实例。
OSS ossClient = new OSSClientBuilder().build(endpoint,
accessKeyId, accessKeySecret);
try {
InputStream inputStream = new
FileInputStream(filePath);
// 创建PutObject请求。
ossClient.putObject(bucketName, objectName,
inputStream);
} 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 (Exception 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();
}
}
}

 4. 获取AccessKeyId

请告诉我,exceptionCaught(...) 在Netty中的作用是什么?如何处理出站异常? 在Netty中,exceptionCaught(...) 方法主要用于处理入站异常。当接收到入站事件(如 channelRead()、channelActive() 等)时,如果出现异常,Netty会调用 exceptionCaught(...) 方法来处理异常。这个方法可以用于记录日志、关闭连接或者其他异常处理操作。 而对于出站异常,Netty不会自动调用 exceptionCaught(...) 方法,而是需要在监听器中处理。可以在 ChannelOutboundHandler 的 write() 方法中,通过添加监听器来处理 write 操作抛出的异常。通过监听器可以获取到操作的结果,并进行相应的异常处理操作。 另外,还有一种实现方式是在 pipeline 的最后添加一个自定义的异常处理器(ExceptionHandler),在该处理器的 write() 方法中添加监听器来处理出站异常。该处理器会在所有的出站操作之后被调用,可以通过监听器获取到操作结果,并处理异常操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Netty exceptionCaught 异常机制](https://blog.csdn.net/abc3224302/article/details/81502640)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值