Browse Source

:tada: 集成腾讯云存储

smallchill 6 years ago
parent
commit
4a10db691d

+ 4 - 0
pom.xml

@@ -92,6 +92,10 @@
             <groupId>org.springblade</groupId>
             <groupId>org.springblade</groupId>
             <artifactId>blade-starter-alioss</artifactId>
             <artifactId>blade-starter-alioss</artifactId>
         </dependency>
         </dependency>
+        <dependency>
+            <groupId>org.springblade</groupId>
+            <artifactId>blade-starter-tencentcos</artifactId>
+        </dependency>
         <dependency>
         <dependency>
             <groupId>org.springblade</groupId>
             <groupId>org.springblade</groupId>
             <artifactId>blade-starter-swagger</artifactId>
             <artifactId>blade-starter-swagger</artifactId>

+ 7 - 5
src/main/java/org/springblade/modules/resource/builder/AliBuilder.java

@@ -36,6 +36,12 @@ public class AliBuilder {
 
 
 	@SneakyThrows
 	@SneakyThrows
 	public static OssTemplate template(Oss oss, OssRule ossRule) {
 	public static OssTemplate template(Oss oss, OssRule ossRule) {
+		// 创建配置类
+		OssProperties ossProperties = new OssProperties();
+		ossProperties.setEndpoint(oss.getEndpoint());
+		ossProperties.setAccessKey(oss.getAccessKey());
+		ossProperties.setSecretKey(oss.getSecretKey());
+		ossProperties.setBucketName(oss.getBucketName());
 		// 创建ClientConfiguration。ClientConfiguration是OSSClient的配置类,可配置代理、连接超时、最大连接数等参数。
 		// 创建ClientConfiguration。ClientConfiguration是OSSClient的配置类,可配置代理、连接超时、最大连接数等参数。
 		ClientConfiguration conf = new ClientConfiguration();
 		ClientConfiguration conf = new ClientConfiguration();
 		// 设置OSSClient允许打开的最大HTTP连接数,默认为1024个。
 		// 设置OSSClient允许打开的最大HTTP连接数,默认为1024个。
@@ -50,12 +56,8 @@ public class AliBuilder {
 		conf.setIdleConnectionTime(60000);
 		conf.setIdleConnectionTime(60000);
 		// 设置失败请求重试次数,默认为3次。
 		// 设置失败请求重试次数,默认为3次。
 		conf.setMaxErrorRetry(5);
 		conf.setMaxErrorRetry(5);
-		OssProperties ossProperties = new OssProperties();
-		ossProperties.setEndpoint(oss.getEndpoint());
-		ossProperties.setAccessKey(oss.getAccessKey());
-		ossProperties.setSecretKey(oss.getSecretKey());
-		ossProperties.setBucketName(oss.getBucketName());
 		CredentialsProvider credentialsProvider = new DefaultCredentialProvider(ossProperties.getAccessKey(), ossProperties.getSecretKey());
 		CredentialsProvider credentialsProvider = new DefaultCredentialProvider(ossProperties.getAccessKey(), ossProperties.getSecretKey());
+		// 创建客户端
 		OSSClient ossClient = new OSSClient(ossProperties.getEndpoint(), credentialsProvider, conf);
 		OSSClient ossClient = new OSSClient(ossProperties.getEndpoint(), credentialsProvider, conf);
 		return new AliossTemplate(ossClient, ossProperties, ossRule);
 		return new AliossTemplate(ossClient, ossProperties, ossRule);
 	}
 	}

+ 3 - 1
src/main/java/org/springblade/modules/resource/builder/MinioBuilder.java

@@ -33,12 +33,14 @@ public class MinioBuilder {
 
 
 	@SneakyThrows
 	@SneakyThrows
 	public static OssTemplate template(Oss oss, OssRule ossRule) {
 	public static OssTemplate template(Oss oss, OssRule ossRule) {
-		MinioClient minioClient = new MinioClient(oss.getEndpoint(), oss.getAccessKey(), oss.getSecretKey());
+		// 创建配置类
 		OssProperties ossProperties = new OssProperties();
 		OssProperties ossProperties = new OssProperties();
 		ossProperties.setEndpoint(oss.getEndpoint());
 		ossProperties.setEndpoint(oss.getEndpoint());
 		ossProperties.setAccessKey(oss.getAccessKey());
 		ossProperties.setAccessKey(oss.getAccessKey());
 		ossProperties.setSecretKey(oss.getSecretKey());
 		ossProperties.setSecretKey(oss.getSecretKey());
 		ossProperties.setBucketName(oss.getBucketName());
 		ossProperties.setBucketName(oss.getBucketName());
+		// 创建客户端
+		MinioClient minioClient = new MinioClient(oss.getEndpoint(), oss.getAccessKey(), oss.getSecretKey());
 		return new MinioTemplate(minioClient, ossRule, ossProperties);
 		return new MinioTemplate(minioClient, ossRule, ossProperties);
 	}
 	}
 
 

+ 2 - 0
src/main/java/org/springblade/modules/resource/builder/OssBuilder.java

@@ -89,6 +89,8 @@ public class OssBuilder {
 						template = QiniuBuilder.template(oss, ossRule);
 						template = QiniuBuilder.template(oss, ossRule);
 					} else if (oss.getCategory() == OssEnum.ALI.getCategory()) {
 					} else if (oss.getCategory() == OssEnum.ALI.getCategory()) {
 						template = AliBuilder.template(oss, ossRule);
 						template = AliBuilder.template(oss, ossRule);
+					} else if (oss.getCategory() == OssEnum.TENCENT.getCategory()) {
+						template = TencentBuilder.template(oss, ossRule);
 					}
 					}
 					templatePool.put(tenantId, template);
 					templatePool.put(tenantId, template);
 					ossPool.put(tenantId, oss);
 					ossPool.put(tenantId, oss);

+ 4 - 4
src/main/java/org/springblade/modules/resource/builder/QiniuBuilder.java

@@ -37,15 +37,15 @@ public class QiniuBuilder {
 
 
 	@SneakyThrows
 	@SneakyThrows
 	public static OssTemplate template(Oss oss, OssRule ossRule) {
 	public static OssTemplate template(Oss oss, OssRule ossRule) {
-		Configuration cfg = new Configuration(Zone.autoZone());
-		Auth auth = Auth.create(oss.getAccessKey(), oss.getSecretKey());
-		UploadManager uploadManager = new UploadManager(cfg);
-		BucketManager bucketManager = new BucketManager(auth, cfg);
 		OssProperties ossProperties = new OssProperties();
 		OssProperties ossProperties = new OssProperties();
 		ossProperties.setEndpoint(oss.getEndpoint());
 		ossProperties.setEndpoint(oss.getEndpoint());
 		ossProperties.setAccessKey(oss.getAccessKey());
 		ossProperties.setAccessKey(oss.getAccessKey());
 		ossProperties.setSecretKey(oss.getSecretKey());
 		ossProperties.setSecretKey(oss.getSecretKey());
 		ossProperties.setBucketName(oss.getBucketName());
 		ossProperties.setBucketName(oss.getBucketName());
+		Configuration cfg = new Configuration(Zone.autoZone());
+		Auth auth = Auth.create(oss.getAccessKey(), oss.getSecretKey());
+		UploadManager uploadManager = new UploadManager(cfg);
+		BucketManager bucketManager = new BucketManager(auth, cfg);
 		return new QiniuTemplate(auth, uploadManager, bucketManager, ossProperties, ossRule);
 		return new QiniuTemplate(auth, uploadManager, bucketManager, ossProperties, ossRule);
 	}
 	}
 
 

+ 64 - 0
src/main/java/org/springblade/modules/resource/builder/TencentBuilder.java

@@ -0,0 +1,64 @@
+/*
+ *      Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
+ *
+ *  Redistribution and use in source and binary forms, with or without
+ *  modification, are permitted provided that the following conditions are met:
+ *
+ *  Redistributions of source code must retain the above copyright notice,
+ *  this list of conditions and the following disclaimer.
+ *  Redistributions in binary form must reproduce the above copyright
+ *  notice, this list of conditions and the following disclaimer in the
+ *  documentation and/or other materials provided with the distribution.
+ *  Neither the name of the dreamlu.net developer nor the names of its
+ *  contributors may be used to endorse or promote products derived from
+ *  this software without specific prior written permission.
+ *  Author: Chill 庄骞 (smallchill@163.com)
+ */
+package org.springblade.modules.resource.builder;
+
+import com.qcloud.cos.COSClient;
+import com.qcloud.cos.ClientConfig;
+import com.qcloud.cos.auth.BasicCOSCredentials;
+import com.qcloud.cos.auth.COSCredentials;
+import com.qcloud.cos.region.Region;
+import lombok.SneakyThrows;
+import org.springblade.core.oss.OssTemplate;
+import org.springblade.core.oss.props.OssProperties;
+import org.springblade.core.oss.rule.OssRule;
+import org.springblade.core.tencentcos.TencentCosTemplate;
+import org.springblade.modules.resource.entity.Oss;
+
+/**
+ * 腾讯云存储构建类
+ *
+ * @author Chill
+ */
+public class TencentBuilder {
+
+	@SneakyThrows
+	public static OssTemplate template(Oss oss, OssRule ossRule) {
+		// 创建配置类
+		OssProperties ossProperties = new OssProperties();
+		ossProperties.setEndpoint(oss.getEndpoint());
+		ossProperties.setAccessKey(oss.getAccessKey());
+		ossProperties.setSecretKey(oss.getSecretKey());
+		ossProperties.setBucketName(oss.getBucketName());
+		// 初始化用户身份信息(secretId, secretKey)
+		COSCredentials credentials = new BasicCOSCredentials(ossProperties.getAccessKey(), ossProperties.getSecretKey());
+		// 设置 bucket 的区域, COS 地域的简称请参照 https://cloud.tencent.com/document/product/436/6224
+		Region region = new Region(ossProperties.getRegion());
+		// clientConfig 中包含了设置 region, https(默认 http), 超时, 代理等 set 方法, 使用可参见源码或者常见问题 Java SDK 部分。
+		ClientConfig clientConfig = new ClientConfig(region);
+		// 设置OSSClient允许打开的最大HTTP连接数,默认为1024个。
+		clientConfig.setMaxConnectionsCount(1024);
+		// 设置Socket层传输数据的超时时间,默认为50000毫秒。
+		clientConfig.setSocketTimeout(50000);
+		// 设置建立连接的超时时间,默认为50000毫秒。
+		clientConfig.setConnectionTimeout(50000);
+		// 设置从连接池中获取连接的超时时间(单位:毫秒),默认不超时。
+		clientConfig.setConnectionRequestTimeout(1000);
+		COSClient cosClient = new COSClient(credentials, clientConfig);
+		return new TencentCosTemplate(cosClient, ossProperties, ossRule);
+	}
+
+}