9.1 Oss学习、Oss文件直传前端、耗时任务异步处理方式
- Oss搭建
- Oss文件传输直接与前端交互
- taskService线程轮询机制
- 重任务的异步处理
一、Oss
阿里云存储Oss,将文件图片等资源存储在云端。
应用场景:存储项目中文件、图片、音频等不易在数据库和服务器中存储的资源
解决问题:文件不经过Api服务器,减轻APi服务器压力。重数据不存在数据库中,减少数据库压力,提高读写性能
1.1 创建Bucket
- 注册阿里云账号
- 开通Oss
- 创键一个Bucket
1.2 权限设置
- 跨域设置
- RAM设置
首先,添加用户分配权限
,创建AccessKey密钥,拿到key和secret
接着,创建角色分配权限(跟用户一样),拿到
1.3 项目引用
写配置:
oss.endpoint=对应红框第一个
oss.key=获取的key
oss.secret=获取的secret
oss.bucket=自定义bucket名
oss.internalEndpoint=https://+你的oss.endpoint
oss.canonicalDomain=红框第二个
oss.cdnDomain=红框第二个
oss.region=cn-主机的地址(比如shanghai、beijing)
oss.putArn=创建角色获取的那个
oss.namespace=java07(可以自定义,也就是bucket的一级目录)
1.4 搭建与使用Oss业务框架
引入文件:
- common > file
二、OSS文件上传
fileService.upload():该方法提供了上传到OSS的接口。
参数:
- file:文件名
- options:上传的配置
public String upload(final File file, final UploadOptions options) throws Exception
{
// 通过配置项来配置上传的元数据。
final ObjectMetadata metadata = new ObjectMetadata();
String contentType = options.getContentType();
if (contentType == null)
{
contentType = Files.probeContentType(file.toPath());
}
if (contentType != null)
{
metadata.setContentType(contentType);
}
if (options.getPermission() != null)
{
switch (options.getPermission())
{
case PRIVATE:
metadata.setObjectAcl(CannedAccessControlList.Private);
break;
case PUBLIC_READ:
metadata.setObjectAcl(CannedAccessControlList.PublicReadWrite);
break;
default:
break;
}
}
// 如果配置中有文件名,则采取配置中的文件名,否则使用文件本身的名子
final String fileName = options.getFileName() != null ? options.getFileName() : file.getName();
// 生成不重复的key作为上传的文件路径+文件名(这样可以防止重名出错)。路径为:
// namespace/year/month/day/(一位小写随机英文)/一个加密随机数+文件后缀
final String objectKey = generateObjectKey(options.getNamespace(), fileName, options.getRandomLength());
// 上传OSS
ossClient.putObject(ossConfig.getBucket(), objectKey, file, metadata)