动力商城-04 阿里云对象存储OSS

1.申请阿里云秘钥

2.创建Bucket

3.对应模块添加依赖

4.文件上传控制类

复制代码
@Api(tags = "文件上传接口管理")
@RequestMapping("admin/file")
@RestController
public class FileUploadController {

    @Resource
    private AliyunOSSConfig aliyunOSSConfig;


    /**
     * 上传文件:
     * 1.接口要求请求方式必须是post请求
     * 2.接收文件的对象的类型是:MultipartFile  该对象是SpringMVC提供的
     * @return   此处返回的是url地址
     */
    @ApiOperation("上传单个文件")
    @PostMapping("upload/element")
    public String uploadFile(MultipartFile file) {

        // 填写Bucket名称
        String bucketName = aliyunOSSConfig.getBucketName();
        // 以天为单位的名称,作为文件夹名称
        String newFolderName = DateUtil.format(new Date(), "yyyy-MM-dd");
        // 以时间戳作为文件的新名称
        String newFileName = DateUtil.format(new Date(), "HHmmssSSS");
        // 获取原文件的后缀名称
        String originalFilename = file.getOriginalFilename();
        String fileSuffix = originalFilename.substring(originalFilename.lastIndexOf("."));
        // 填写Object完整路径,完整路径中不能包含Bucket名称,例如exampledir/exampleobject.txt。
        String objectName = newFolderName+"/"+newFileName+fileSuffix;

        // 创建OSSClient实例。
        OSS ossClient = new OSSClientBuilder().build(aliyunOSSConfig.getEndpoint(), aliyunOSSConfig.getAccessKeyId(), aliyunOSSConfig.getAccessKeySecret());
        URL url = null;
        try {
            // 创建PutObjectRequest对象。
            PutObjectRequest putObjectRequest = new PutObjectRequest(bucketName, objectName, file.getInputStream());
            // 上传
            ossClient.putObject(putObjectRequest);
            // 创建上传文件访问的url地址
            url = ossClient.generatePresignedUrl(bucketName, objectName, DateUtil.offsetDay(new Date(), 365 * 10));
        } catch (Exception ce) {
            System.out.println("Error Message:" + ce.getMessage());
        } finally {
            if (ossClient != null) {
                ossClient.shutdown();
            }
        }
        return url.toString();
    }
}

5.阿里云平台-对象存储OSS服务配置类

复制代码
public class AliyunOSSConfig {

    /**
     * 访问地址
     */
    private String endpoint;
    /**
     * bucket名称
     */
    private String bucketName;
    /**
     * 访问ID
     */
    private String accessKeyId;
    /**
     * 访问密钥
     */
    private String accessKeySecret;
}

6.bootstrap.yml配置 放到nacos远程配置中

复制代码
  aliyun:
    oss:
      endpoint: oss-cn-beijing.aliyuncs.com
      bucketName: ynu-mall
      accessKeyId: 
      accessKeySecret: 
相关推荐
捂一捂啊啊10 小时前
腾讯云系统盘占满
云计算·腾讯云
腾讯云大数据10 小时前
腾讯云ES一站式RAG方案获信通院“开源大模型+软件创新应用”精选案例奖
大数据·elasticsearch·开源·云计算·腾讯云
国际云,接待13 小时前
[特殊字符]服务器性能优化:从硬件到AI的全栈调优指南
运维·服务器·人工智能·阿里云·性能优化·架构·云计算
信服云14 小时前
拥有600+门店的宠物连锁医院,实现核心业务系统上云
云计算
容器魔方15 小时前
Bilibili、中电信人工智能科技、商汤科技、联通云等正式加入Volcano社区用户组
云原生·容器·云计算
24k小善16 小时前
FlinkSql入门与实践
java·大数据·flink·云计算
Linux运维老纪16 小时前
Python文件操作及数据库交互(Python File Manipulation and Database Interaction)
linux·服务器·数据库·python·云计算·运维开发
南客先生21 小时前
Java在云计算、大数据、云原生下的应用和优势 - 面试实战
java·大数据·微服务·云原生·云计算·容器化·分布式计算
Linux运维老纪21 小时前
交换机之配置系统基本信息(Basic Information of the Configuration System for Switches)
linux·网络·mysql·华为·云计算·运维开发
weixin_307779131 天前
Azure Data Factory ETL设计与调度最佳实践
数据仓库·性能优化·云计算·azure·etl