SpringBoot整合OSS实现文件上传

以前,文件上传到本地(服务器,磁盘),文件多,大,会影响服务器性能

如何解决? 使用文件服务器单独存储这些文件,例如七牛云存储,阿里云OSS,腾讯云cos等等

也可以自己搭建文件服务器(FastDFS,minio)

1 开通OSS

2 创建bucket

其他不用管,直接完成即可

3 获取AccessKeyId、AccessKeySecret

墙裂建议,保存好此文件,因为后续无法再查看,只能删除重建

4 获取外网访问域名

Endpoint(地域节点): oss-cn-hangzhou.aliyuncs.com

Bucket 域名 : qiushiju-tuchuang.oss-cn-hangzhou.aliyuncs.com

5 创建文件夹

oss中存储在app/upload下

6 添加依赖

7 封装常量类

根据自己实际情况改变

public class AliyunOSSConstants {

    // OSS唯一key
    public static final String ASSCESS_KEY_ID = "LTAI5tSHaTi33oPh6SAU69Ax";
    // OSS唯一key秘钥
    public static final String ASSCESS_KEY_SECRET = "rJVo4Ksr4hFdyMOxxWl2Dx7Shr5wKz";
    // 地域节点
    public static final String END_POINT = "oss-cn-hangzhou.aliyuncs.com";
    // Bucket名称
    public static final String BUCKET_NAME = "qiushiju-tuchuang";
    // 文件一级路径
    public static final String FILE_DIR = "app/upload";
    // 文件访问域名
    public static final String COMMON_URL = "https://qiushiju-tuchuang.oss-cn-hangzhou.aliyuncs.com/";

}

8 封装工具类

    /**
     * 上传文件
     */
    public static String upLoad(MultipartFile file) {
        System.out.println("------OSS文件上传开始--------" );

        String endPoint = AliyunOSSConstants.END_POINT;
        String accessKeyId = AliyunOSSConstants.ASSCESS_KEY_ID;
        String accessKeySecret = AliyunOSSConstants.ASSCESS_KEY_SECRET;
        String bucketName = AliyunOSSConstants.BUCKET_NAME;
        String fileDir = AliyunOSSConstants.FILE_DIR;
        SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
        String dateStr = format.format(new Date( ));
        String fileUrl = null;
        OSS client = new OSSClientBuilder( ).build(endPoint, accessKeyId, accessKeySecret);
        try {
            // 判断容器是否存在,不存在就创建
            if (!client.doesBucketExist(bucketName)) {
                client.createBucket(bucketName);
                CreateBucketRequest createBucketRequest = new CreateBucketRequest(bucketName);
                createBucketRequest.setCannedACL(CannedAccessControlList.PublicRead);
                client.createBucket(createBucketRequest);
            }
            String originalFilename = file.getOriginalFilename( );
            String suffix = originalFilename.substring(originalFilename.indexOf("."));
            // 设置文件路径和名称
            fileUrl = fileDir + "/" + (dateStr + "/" + UUID.randomUUID( ).toString( ).replace("-", "") + suffix);
            System.out.println("fileUrl:" + fileUrl);
            // 上传文件
            PutObjectResult result = client.putObject(new PutObjectRequest(bucketName, fileUrl, file.getInputStream( )));
            // 设置权限(公开读)
            client.setBucketAcl(bucketName, CannedAccessControlList.PublicRead);
            if (result != null) {
                System.out.println("resp:" + result);
                System.out.println("------OSS文件上传成功------" + AliyunOSSConstants.COMMON_URL + fileUrl);
            }
        } catch (OSSException oe) {
            oe.printStackTrace();
        } catch (ClientException ce) {
            ce.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace( );
        } finally {
            if (client != null) {
                client.shutdown( );
            }
        }
        return AliyunOSSConstants.COMMON_URL + fileUrl;
    }

    /**
     * 删除文件
     */
    public static String delete(String fileUrl) {
        System.out.println("------OSS文件删除开始--------" + fileUrl);

        String endPoint = AliyunOSSConstants.END_POINT;
        String accessKeyId = AliyunOSSConstants.ASSCESS_KEY_ID;
        String accessKeySecret = AliyunOSSConstants.ASSCESS_KEY_SECRET;
        String bucketName = AliyunOSSConstants.BUCKET_NAME;
        OSS client = new OSSClientBuilder( ).build(endPoint, accessKeyId, accessKeySecret);
        try {
            client.deleteObject(bucketName, fileUrl);
            System.out.println("------OSS文件删除成功------" + AliyunOSSConstants.COMMON_URL + fileUrl);
        } catch (OSSException oe) {
           oe.printStackTrace();
        } catch (ClientException ce) {
           ce.printStackTrace();
        } finally {
            if (client != null) {
                client.shutdown( );
            }
        }
        return AliyunOSSConstants.COMMON_URL + fileUrl;
    }
}

 9 接口测试


@RestController
public class UploadController {

    /**
     * 演示上传文件到OSS
     */
    @PostMapping("/upload")
    public R upload(MultipartFile file){
        String filePath = AliyunOSSUtil.upLoad(file);
        return R.ok(filePath);
    }

}
10 前端

<template>
  <div>
    <h2>文件上传</h2>
    <el-upload
      class="upload-demo"
      drag
      action=""
      :http-request="uploadFile"  
      :on-change="handleChange"
      multiple>
      <i class="el-icon-upload"></i>
      <div class="el-upload__text">将文件拖到此处,或<em>点击上传</em></div>
      <div class="el-upload__tip" slot="tip">只能上传jpg/png文件,且不超过500kb</div>
    </el-upload>
    <div>
      <img :src="fileSrc" width="100px">
    </div>
  </div>

</template>

<script>
import {uploadPicture} from '@/api/upload'
export default {
  data(){
    return{
      file:null,
      fileSrc:null
    }
  },
  methods:{
    handleChange(file){
      this.file = file.raw;
    },
    uploadFile(){
      const file = this.file;
      const formData = new FormData();
      formData.append("file", file); // 由后端接口决定,后端参数叫file
      uploadPicture(formData).then((res) => {
        this.$message({
          message: "上传成功",
          type: "success",
        });
        this.fileSrc = res.data
        console.log("fileSrc",this.fileSrc)
      });
    }
  }
}
</script>

<style scoped lang="scss">

</style>

使用:http-request指定文件上传的函数,原有的action、:before-upload、:on-success等不起作用。但删去action可能有报错,所以还是写了action=""。

uploadPicture()是封装的函数,在upload.js中

import axios from '@/utils/request'

export function uploadPicture(data) {
  return axios({
    url: '/upload',
    method: 'post',
    data
  })
}

11 测试即可

Spring Boot 是一种快速开发应用程序的框架,而OSS(Object Storage Service)是阿里云提供的对象存储服务。将它们结合起来,可以实现文件的上传、下载、查看等功能。 下面是实现上传、查看、下载的具体步骤: 1. 引入依赖 在 `pom.xml` 文件中添加以下依赖: ```xml <dependency> <groupId>com.aliyun.oss</groupId> <artifactId>aliyun-sdk-oss</artifactId> <version>3.10.2</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> ``` 2. 配置 OSS 客户端 在配置文件中添加 OSS 的配置: ```properties aliyun.oss.endpoint=oss-cn-hangzhou.aliyuncs.com aliyun.oss.accessKeyId=yourAccessKeyId aliyun.oss.accessKeySecret=yourAccessKeySecret aliyun.oss.bucketName=yourBucketName ``` 然后创建 OSS 客户端: ```java @Configuration public class OSSConfig { @Autowired private OSSProperties ossProperties; @Bean public OSS ossClient() { return new OSSClientBuilder().build(ossProperties.getEndpoint(), ossProperties.getAccessKeyId(), ossProperties.getAccessKeySecret()); } } ``` 3. 实现上传功能 在控制器中实现上传功能: ```java @RestController public class OSSController { @Autowired private OSS ossClient; @Autowired private OSSProperties ossProperties; @PostMapping("/upload") public String upload(@RequestParam("file") MultipartFile file) throws IOException { // 上传文件到 OSS String filename = file.getOriginalFilename(); ossClient.putObject(ossProperties.getBucketName(), filename, file.getInputStream()); // 返回文件 URL return ossClient.generatePresignedUrl(ossProperties.getBucketName(), filename, new Date(System.currentTimeMillis() + 3600 * 1000)).toString(); } } ``` 4. 实现查看功能 在控制器中实现查看功能: ```java @RestController public class OSSController { @Autowired private OSS ossClient; @Autowired private OSSProperties ossProperties; @GetMapping("/view/{filename:.+}") public ResponseEntity<Resource> view(@PathVariable String filename) throws IOException { // 从 OSS 中获取文件流 OSSObject ossObject = ossClient.getObject(ossProperties.getBucketName(), filename); InputStream inputStream = ossObject.getObjectContent(); // 将文件流转换为 Resource 对象 ByteArrayResource resource = new ByteArrayResource(IOUtils.toByteArray(inputStream)); // 返回 Resource 对象 return ResponseEntity.ok() .header(HttpHeaders.CONTENT_DISPOSITION, "attachment; filename=\"" + filename + "\"") .contentLength(resource.contentLength()) .contentType(MediaType.parseMediaType("application/octet-stream")) .body(resource); } } ``` 5. 实现下载功能 在控制器中实现下载功能: ```java @RestController public class OSSController { @Autowired private OSS ossClient; @Autowired private OSSProperties ossProperties; @GetMapping("/download/{filename:.+}") public ResponseEntity<Resource> download(@PathVariable String filename) throws IOException { // 从 OSS 中获取文件流 OSSObject ossObject = ossClient.getObject(ossProperties.getBucketName(), filename); InputStream inputStream = ossObject.getObjectContent(); // 将文件流转换为 Resource 对象 ByteArrayResource resource = new ByteArrayResource(IOUtils.toByteArray(inputStream)); // 返回 Resource 对象 return ResponseEntity.ok() .header(HttpHeaders.CONTENT_DISPOSITION, "attachment; filename=\"" + filename + "\"") .contentLength(resource.contentLength()) .contentType(MediaType.parseMediaType("application/octet-stream")) .body(resource); } } ``` 这样就可以通过访问 `/upload` 接口上传文件,访问 `/view/{filename}` 接口查看文件,访问 `/download/{filename}` 接口下载文件了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值