SpringBoot整合騰訊雲COS對象存儲實現文件上傳的示例代碼

企業級項目開發中都會有文件、圖片、視頻等文件上傳並能夠訪問的場景,對於初學者Demo可能會直接存儲在應用服務器上;對於傳統項目可能會單獨搭建FastDFS、MinIO等文件服務來實現存儲,這種方案可能對於企業成本較小,但缺點也是很多,例如:1、增加技術人員的運維和維護成本,2、規模越來越大時需要硬件的支持,且存在文件丟失風險,3、服務器沒有CDN,用戶訪問網站圖片加載慢用戶體驗不好。

所以,一般上規模的項目、或者追求用戶體驗的項目可能會考慮使用第三方的雲服務來存儲,市場主流廠商有:七牛雲、阿裡雲OSS、騰訊雲COS等,具體采用哪種存儲方案需結合項目、規模、成本等因素,綜合考量確定。

因為用的騰訊雲服務器,為瞭方便統一管理,所以直接用瞭騰訊雲的COS對象存儲服務,下面是基於SpringBoot和騰訊雲COS提供的Java SDK快速對接實現文件上傳功能。

1、開通騰訊雲對象存儲服務

https://console.cloud.tencent.com/cos5

2、創建存儲桶

3、密鑰管理,新建密鑰

4、yml配置密鑰、COS信息

cos:
  baseUrl: fxxxxxa-1xxxxx1.cos.ap-shanghai.myqcloud.com
  accessKey: AKxxxxxxxxxxxxxxxxxxxxxxxxxCF
  secretKey: oKxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxni
  regionName: ap-shanghai
  bucketName: fxxxxxa-1xxxxx1
  folderPrefix: /files

5、COSConfig配置類

@Data
@Component
@ConfigurationProperties(prefix = "cos")
public class COSConfig {
    private String baseUrl;
    private String accessKey;
    private String secretKey;
    private String regionName;
    private String bucketName;
    private String folderPrefix;
}

6、COS文件上傳工具類

/**
 * 騰訊雲COS文件上傳工具類
 */
@Slf4j
public class COSClientUtil {
 
    /**
     * 獲取配置信息
     */
    private static COSConfig cosConfig = SpringBeanUtils.getBean(COSConfig.class);
 
    /**
     * 初始化用戶身份信息
     */
    private static COSCredentials cred = new BasicCOSCredentials(cosConfig.getAccessKey(), cosConfig.getSecretKey());
 
    /**
     * 設置bucket的區域
     */
    private static ClientConfig clientConfig = new ClientConfig(new Region(cosConfig.getRegionName()));
 
    /**
     * 生成COS客戶端
     */
    private static COSClient cosClient = new COSClient(cred, clientConfig);
 
    /**
     * 上傳文件
     *
     * @param file
     * @return
     * @throws Exception
     */
    public static String upload(MultipartFile file) throws Exception {
        String date = DateUtils.formateDate(new Date(), "yyyy-MM-dd");
        String originalFilename = file.getOriginalFilename();
        long nextId = IdGenerator.getFlowIdWorkerInstance().nextId();
        String name = nextId + originalFilename.substring(originalFilename.lastIndexOf("."));
        String folderName = cosConfig.getFolderPrefix() + "/" + date + "/";
        String key = folderName + name;
        File localFile = null;
        try {
            localFile = transferToFile(file);
            String filePath = uploadFileToCOS(localFile, key);
            log.info("upload COS successful: {}", filePath);
            return filePath;
        } catch (Exception e) {
            throw new Exception("文件上傳失敗");
        } finally {
            localFile.delete();
        }
    }
 
    /**
     * 上傳文件到COS
     *
     * @param localFile
     * @param key
     * @return
     */
    private static String uploadFileToCOS(File localFile, String key) throws InterruptedException {
        PutObjectRequest putObjectRequest = new PutObjectRequest(cosConfig.getBucketName(), key, localFile);
        ExecutorService threadPool = Executors.newFixedThreadPool(8);
        // 傳入一個threadPool, 若不傳入線程池, 默認TransferManager中會生成一個單線程的線程池
        TransferManager transferManager = new TransferManager(cosClient, threadPool);
        // 返回一個異步結果Upload, 可同步的調用waitForUploadResult等待upload結束, 成功返回UploadResult, 失敗拋出異常
        Upload upload = transferManager.upload(putObjectRequest);
        UploadResult uploadResult = upload.waitForUploadResult();
        transferManager.shutdownNow();
        cosClient.shutdown();
        String filePath = cosConfig.getBaseUrl() + uploadResult.getKey();
        return filePath;
    }
 
    /**
     * 用緩沖區來實現這個轉換, 即創建臨時文件
     * 使用 MultipartFile.transferTo()
     *
     * @param multipartFile
     * @return
     */
    private static File transferToFile(MultipartFile multipartFile) throws IOException {
        String originalFilename = multipartFile.getOriginalFilename();
        String prefix = originalFilename.split("\\.")[0];
        String suffix = originalFilename.substring(originalFilename.lastIndexOf("."));
        File file = File.createTempFile(prefix, suffix);
        multipartFile.transferTo(file);
        return file;
    }
 
}

7、Controller測試上傳接口:

    /**
     * 騰訊雲COS上傳
     *
     * @param file
     * @return
     * @throws Exception
     */
    @PostMapping(value = "/cosUpload")
    public ResponseEntity cosUpload(MultipartFile file) throws Exception {
        String filePath = COSClientUtil.upload(file);
        UploadDTO dto = UploadDTO.builder().filePath(filePath).build();
        return ResultVOUtil.success(dto);
    }

8、PostMan接口調用

9、瀏覽器預覽效果

到此這篇關於SpringBoot整合騰訊雲COS對象存儲實現文件上傳的示例代碼的文章就介紹到這瞭,更多相關SpringBoot騰訊雲COS文件上傳內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: