当前位置:   article > 正文

(亲测有效)SpringBoot项目集成腾讯云COS对象存储(1)_springboot配置腾讯云对象存储

springboot配置腾讯云对象存储

目录

一、腾讯云对象存储使用

1、创建Bucket

2、使用web控制台上传和浏览文件

3、创建API秘钥

二、代码对接腾讯云COS(以Java为例)

1、初始化客户端

2、填写配置文件

3、通用能力类

文件上传

测试


一、腾讯云对象存储使用

1、创建Bucket

(1)进入腾讯云官网,注册登录用户,进行实名认证,开通“对象存储COS”服务,进入管理控制台,

(2)进入管理控制台,找到存储桶列表, 创建存储桶。

可以把存储桶理解为一个存储空间,和文件系统类似,都是根据路径找到文件或目录(比如/test/aaajpg )。可以多个项目共用一个存储桶,也可以每个项目一个。

点击创建存储桶,注意地域选择国内(离用户较近的位置)。此处访问权限先选择"公有读私有写”,因为我们的存储桶要存储允许用户公开访问的代码生成器图片。而如果整个存储桶要存储的文件都不允许用户访问,建议选择私有读写,更安全。

默认告警一定要勾选!因为对象存储服务的存储和访问流量都是计费的,超限后我们要第一时间得到通知并进行相应的处理。

不过也不用太担心,自己做项目的话一般是没人攻击你的,而且对象存储很便宜,正常情况下消耗的费用寥寥无几。

然后一直点击“下一步"即可。

2、使用web控制台上传和浏览文件

开通成功后,我们可以试着使用web控制台上传和浏览文件。

先上传一个文件,点击上传。

上传文件后,可以使用对象存储服务为我们生成的默认域名,在线访问图片。

当然,一般情况下我们会使用程序来操作存储桶。

3、创建API秘钥

进入访问管理中的访问密钥里的API秘钥管理,地址为登录 - 腾讯云

点击新建秘钥,

 

二、代码对接腾讯云COS(以Java为例)

1、初始化客户端

参考官方文档,我们要先初始化一个 COS 客户端对象,和对象存储服务进行交互。

对于我们的项目,只需要复用一个COS 客户端对象即可,所以我们可以通过编写配置类初始化客户端对象。

1)使用idea打开后端项目,在 config 目录下新建 CosClientConfig 类,负责读取配置文件。并创建一个COS 客户端的 Bean。

代码如下:

  1. import com.qcloud.cos.COSClient;
  2. import com.qcloud.cos.ClientConfig;
  3. import com.qcloud.cos.auth.BasicCOSCredentials;
  4. import com.qcloud.cos.auth.COSCredentials;
  5. import com.qcloud.cos.region.Region;
  6. import lombok.Data;
  7. import org.springframework.boot.context.properties.ConfigurationProperties;
  8. import org.springframework.context.annotation.Bean;
  9. import org.springframework.context.annotation.Configuration;
  10. /**
  11. * 腾讯云对象存储客户端
  12. */
  13. @Configuration
  14. @ConfigurationProperties(prefix = "cos.client")
  15. @Data
  16. public class CosClientConfig {
  17. private String accessKey;
  18. private String secretKey;
  19. /**
  20. * 区域
  21. */
  22. private String region;
  23. /**
  24. * 桶名
  25. */
  26. private String bucket;
  27. @Bean
  28. public COSClient cosClient() {
  29. // 初始化用户身份信息(secretId, secretKey)
  30. COSCredentials cred = new BasicCOSCredentials(accessKey, secretKey);
  31. // 设置bucket的区域, COS地域的简称请参照 https://www.qcloud.com/document/product/436/6224
  32. ClientConfig clientConfig = new ClientConfig(new Region(region));
  33. // 生成cos客户端
  34. return new COSClient(cred, clientConfig);
  35. }
  36. }

2、填写配置文件

一定要注意防止密码泄露!所以我们新建application-local.yml文件,并且在.gitignore中忽略该文件的提交,这样就不会将代码等敏感配置提交到代码仓库了。

配置代码如下:

  1. # 对象存储
  2. # todo 需替换配置
  3. cos:
  4. client:
  5. accessKey: xxx
  6. secretKey: xxx
  7. region: xxx
  8. bucket: xxx

可以通过如下方式分别获取需要的配置。

(1)accessKey/secretId、secretKey 密钥对:在腾讯云网站中,访问管理中的密钥管理中获取。

获取地址为:登录 - 腾讯云

(2)region 表示地域名,默认域名指 COS 的默认存储桶域名,腾讯云中,用户在 创建存储桶 时,由系统根据存储桶名称和地域自动生成。不同地域的存储桶有不同的默认域名。

获取地址为:对象存储 地域和访问域名-产品简介-文档中心-腾讯云

此处我的regin域名应该是ap-beijing。 

 (3)bucket是存储桶名,可以从腾讯云网站的对象存储里,点击存储桶列表里获取。

 写完配置文件之后,如下图所示,

 

3、通用能力类

我们新建 CosManager 类,提供通用的对象存储操作,比如文件上传、文件下载等,供其他代码(比如 Service)调用。

文件上传

参考官方文档的"上传对象"部分,可以编写出文件上传的代码。地址 : https://cloud.tencent.com/document/product/436/65935

CosManager 新增两个上传对象的方法,代码如下:

  1. import com.qcloud.cos.COSClient;
  2. import com.qcloud.cos.model.PutObjectRequest;
  3. import com.qcloud.cos.model.PutObjectResult;
  4. import com.waterai.water.config.CosClientConfig;
  5. import java.io.File;
  6. import javax.annotation.Resource;
  7. import org.springframework.stereotype.Component;
  8. /**
  9. * Cos 对象存储操作
  10. */
  11. @Component
  12. public class CosManager {
  13. @Resource
  14. private CosClientConfig cosClientConfig;
  15. @Resource
  16. private COSClient cosClient;
  17. /**
  18. * 上传对象
  19. * @param key 唯一键
  20. * @param localFilePath 本地文件路径
  21. * @return
  22. */
  23. public PutObjectResult putObject(String key, String localFilePath) {
  24. PutObjectRequest putObjectRequest = new PutObjectRequest(cosClientConfig.getBucket(), key, new File(localFilePath));
  25. return cosClient.putObject(putObjectRequest);
  26. }
  27. /**
  28. * 上传对象
  29. * @param key 唯一键
  30. * @param file 文件
  31. * @return
  32. */
  33. public PutObjectResult putObject(String key, File file) {
  34. PutObjectRequest putObjectRequest = new PutObjectRequest(cosClientConfig.getBucket(), key, file);
  35. return cosClient.putObject(putObjectRequest);
  36. }
  37. }

(2)新建FileConstant类,设置常量中的 COS 访问域名,便于接下来测试访问已上传的文件。

代码如下:

  1. /**
  2. * 文件常量
  3. */
  4. public interface FileConstant {
  5. /**
  6. * COS 访问地址
  7. * todo 需替换配置
  8. */
  9. String COS_HOST = "https://xxxx.cos.ap-xxxx.myqcloud.com";
  10. }

该域名可以在COS控制台的域名信息部分找到,

测试

(1为了方便测试,在 FileController 中编写测试文件上传接口。

核心流程是先接受用户上传的文件,指定上传的路径,然后调用 cosManager.putObject 方法上传文件到 COS 对象存储。上传成功后,会返回一个文件的key(其实就是文件路径),便于我们访问和下载文件。

需要注意,测试接口一定要加上管理员权限!防止任何用户随意上传文件。

测试文件上传接口这个方法的代码如下:

  1. import cn.hutool.core.io.FileUtil;
  2. import com.waterai.water.annotation.AuthCheck;
  3. import com.waterai.water.common.BaseResponse;
  4. import com.waterai.water.common.ErrorCode;
  5. import com.waterai.water.common.ResultUtils;
  6. import com.waterai.water.constant.FileConstant;
  7. import com.waterai.water.constant.UserConstant;
  8. import com.waterai.water.exception.BusinessException;
  9. import com.waterai.water.manager.CosManager;
  10. import com.waterai.water.model.dto.file.UploadFileRequest;
  11. import com.waterai.water.model.entity.User;
  12. import com.waterai.water.model.enums.FileUploadBizEnum;
  13. import com.waterai.water.service.UserService;
  14. import java.io.File;
  15. import java.util.Arrays;
  16. import javax.annotation.Resource;
  17. import javax.servlet.http.HttpServletRequest;
  18. import lombok.extern.slf4j.Slf4j;
  19. import org.apache.commons.lang3.RandomStringUtils;
  20. import org.springframework.web.bind.annotation.PostMapping;
  21. import org.springframework.web.bind.annotation.RequestMapping;
  22. import org.springframework.web.bind.annotation.RequestPart;
  23. import org.springframework.web.bind.annotation.RestController;
  24. import org.springframework.web.multipart.MultipartFile;
  25. /**
  26. * 文件接口
  27. */
  28. @RestController
  29. @RequestMapping("/file")
  30. @Slf4j
  31. public class FileController {
  32. @Resource
  33. private UserService userService;
  34. @Resource
  35. private CosManager cosManager;
  36. /*
  37. * 其他方法。。。。。
  38. * */
  39. /*
  40. * 测试文件上传
  41. * */
  42. @AuthCheck(mustRole = UserConstant.ADMIN_ROLE)
  43. @PostMapping("/test/upload")
  44. public BaseResponse<String> testUploadFile(@RequestPart("file") MultipartFile multipartFile) {
  45. // 文件目录
  46. String filename = multipartFile.getOriginalFilename();
  47. String filepath = String.format("/test/%s", filename);
  48. File file = null;
  49. try {
  50. //上传文件
  51. file = File.createTempFile(filepath, null);
  52. multipartFile.transferTo(file);
  53. cosManager.putObject(filepath, file);
  54. //返回可访问地址
  55. return ResultUtils.success(filepath);
  56. } catch (Exception e) {
  57. System.out.println("file upload error, filepath = " + filepath + ", error = " +e);
  58. throw new BusinessException(ErrorCode.SYSTEM_ERROR, "上传失败");
  59. } finally {
  60. if (file != null) {
  61. //删除临时文件
  62. boolean delete = file.delete();
  63. if (!delete) System.out.println("file delete error, filepath = [l" + filepath);
  64. }
  65. }
  66. }
  67. }

 (2)修改启动配置李的active profiles,使用local配置启动项。

然后点击启动按钮启动项目。

(2)打开 Swagger接口文档,此处我的项目端口是8101,因此就是http://localhost:8101/api/doc.html,然后在file-controller中找到测试文件上传的这个接口,开始进行测试。

首先,点击选择文件,从本地选择一个文件,然后点击发送请求。

请求返回成功。

(3)在腾讯云官网上的控制台中,可以看到已经有了test这个文件夹,双击进入,

就可以看到5.jpg这个文件已经上传成功了。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/爱喝兽奶帝天荒/article/detail/1020671
推荐阅读
相关标签
  

闽ICP备14008679号