亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Spring Boot項目中實現(xiàn)文件上傳功能的示例

 更新時間:2020年12月08日 11:41:54   作者:風起青萍末  
這篇文章主要介紹了Spring Boot項目中實現(xiàn)文件上傳功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

在實際項目中,文件上傳是很多項目必不可少的一個功能。那么在 Spring Boot 項目中又是如何來實現(xiàn)文件上傳功能的呢?一般來說,上傳的文件可以保存到項目根目錄下的某一文件夾中,但這樣做顯然是不太合適的。因此我們選擇將文件上傳到專門的文件服務器中。很多云計算廠商都提供文件存儲服務。這里我選擇的是阿里云的對象存儲(OSS)。

一、配置OSS

1. 導入SDK

首先,你需要注冊阿里云的賬號并開通對象存儲服務。在準備工作完成之后,需要導入 JAVA 版本的 SDK,這里使用 maven 進行導入

<!-- 阿里云OSS對象存儲 -->
<dependency>
	<groupId>com.aliyun.oss</groupId>
	<artifactId>aliyun-sdk-oss</artifactId>
	<version>3.8.0</version>
</dependency>

2. 修改配置文件

導入完成后在 application.properties 配置文件中添加以下內容

# 節(jié)點域名
aliyun.oss.endpoint=oss-cn-xxxxxxx.aliyuncs.com
# 賬戶id
aliyun.oss.accessKeyId=xxxxxxxxxxxxx
# 賬戶密碼
aliyun.oss.accessKeySecret=xxxxxxxxxxxxx
# bucket名稱
aliyun.oss.bucketName=xxxxxxxxxxx
# 簽名過期時間
aliyun.oss.policy.expire=300
# 上傳文件的最大尺寸
aliyun.oss.maxSize=10
# 上傳地址的前綴
aliyun.oss.dir.prefix=xxx
# 回調參數(shù)的請求地址
aliyun.oss.callback=http://www.xxxxxx.com/api/aliyun/oss/callback

以上內容在開通服務后均可獲取到,請根據(jù)實際情況進行修改

3. 初始化

OSSClient是OSS的Java客戶端,用于管理存儲空間和文件等OSS資源。使用Java SDK發(fā)起OSS請求,您需要初始化一個OSSClient實例,并根據(jù)需要修改ClientConfiguration的默認配置項。

根據(jù)官方文檔的描述,需要初始化一個ossClient實例并將其注入到Spring容器中,因此可以編寫一個配置類OssConfig

@Configuration
@PropertySource(value = {"classpath:application.properties"}, encoding = "utf-8")
public class OssConfig {

 @Value("${aliyun.oss.endpoint}")
 private String endpoint;

 @Value("${aliyun.oss.accessKeyId}")
 private String accessKeyId;

 @Value("${aliyun.oss.accessKeySecret}")
 private String secretAccessKey;

 @Bean
 public OSS ossClient(){
 return new OSSClientBuilder().build(endpoint, accessKeyId, secretAccessKey);
 }
}

更多詳細的配置,請參考官方文檔:初始化

二、文件上傳

1. 流程分析

我們以典型的表單上傳為例,在使用對象存儲OSS后,表單上傳分為以下幾個流程:

注:Policy表單域用于驗證請求的合法性。例如可以指定上傳的大小,可以指定上傳的Object名稱等,上傳成功后客戶端跳轉到的URL,上傳成功后客戶端收到的狀態(tài)碼。

PolicyConditions policyConds = new PolicyConditions();
policyConds.addConditionItem(PolicyConditions.COND_CONTENT_LENGTH_RANGE, 0, maxSize);
policyConds.addConditionItem(MatchMode.StartWith, PolicyConditions.COND_KEY, DIR_PREFIX);
String postPolicy = ossClient.generatePostPolicy(expiration, policyConds);
byte[] binaryData = postPolicy.getBytes(StandardCharsets.UTF_8);
// 將Policy字符串進行base64編碼
String policy = BinaryUtil.toBase64String(binaryData);
// 用OSS的AccessKeySecret對base64編碼后的Policy進行簽名
String signature = ossClient.calculatePostSignature(postPolicy);

前端向OSS服務器上傳文件時要上傳Policy表單域,OSS服務器將對Policy表單域的內容進行驗證。關于 Post Policy 的詳細內容,請參考官方文檔:Post Policy

當文件上傳成功后,OSS服務器會向應用服務器發(fā)起回調請求,具體流程如下:

用戶只需要在發(fā)送給 OSS 的請求中攜帶相應的 Callback 參數(shù),即能實現(xiàn)回調。

Callback 參數(shù)是由一段經過 base64 編碼的 JSON 字符串(字段)。構建 callback 參數(shù)的關鍵是指定請求回調的服務器 URL(callbackUrl)以及回調的內容(callbackBody)。

// 上傳回調參數(shù)
Callback callback = new Callback();
// 指定請求回調的服務器URL
callback.setCallbackUrl(CALLBACK);
//(可選)設置回調請求消息頭中Host的值,即您的服務器配置Host的值。
// callback.setCallbackHost("yourCallbackHost");
// 設置發(fā)起回調時請求body的值。
callback.setCallbackBody("{\\\"filename\\\":${object},\\\"mineType\\\":${mimeType}}");
// 設置發(fā)起回調請求的Content-Type。
callback.setCalbackBodyType(Callback.CalbackBodyType.JSON);
// 設置發(fā)起回調請求的自定義參數(shù),由Key和Value組成,Key必須以x:開始。
// callback.addCallbackVar("x:dir", "value");

更詳細的內容請閱讀官方文檔:Callback

2. 功能實現(xiàn)

首先編寫 Post Policy 封裝對象OssPolicyResult

@Data
public class OssPolicyResult {

	@ApiModelProperty("用戶id")
	private String accessKeyId;
	
	@ApiModelProperty("Post Policy經過base64編碼過的字符串")
 private String policy;
	
	@ApiModelProperty("對policy簽名后的字符串")
 private String signature;

	// @ApiModelProperty("對象的鍵值")
	// private String key;
	
	@ApiModelProperty("上傳文件夾路徑前綴")
 private String dir;
	
	@ApiModelProperty("oss對外服務的訪問域名")
 private String host;

	@ApiModelProperty("上傳成功后的回調設置")
	private String callback;
}

然后需自定義一個回調結果對象OssCallBackResult

@Data
public class OssCallBackResult {

 @ApiModelProperty("文件的鏈接")
 private String url;
 @ApiModelProperty("文件名稱")
 private String filename;
 @ApiModelProperty("文件大小")
 private String size;
 @ApiModelProperty("文件的mimeType")
 private String mimeType;
 @ApiModelProperty("圖片文件的寬")
 private String width;
 @ApiModelProperty("圖片文件的高")
 private String height;
}

注:以上內容可根據(jù)實際需要進行修改

之后編寫 Service 接口及實現(xiàn)類

Service 接口:

public interface OssService {
	
 // 生成Post Policy
	OssPolicyResult policy();
	
 // 上傳成功后的回調
	OssCallBackResult callback(Map<String, Object> requestBody);
}

Service 實現(xiàn)類:

@Slf4j
@Service
@PropertySource(value = {"classpath:application.properties"}, encoding = "utf-8")
public class OssServiceImpl implements OssService {

	@Value("${aliyun.oss.endpoint}")
	private String ENDPOINT;

	@Value("${aliyun.oss.accessKeyId}")
	private String ACCESS_KEY_ID;

	@Value("${aliyun.oss.accessKeySecret}")
	private String SECRET_ACCESS_KEY;

	@Value("${aliyun.oss.bucketName}")
	private String BUCKET_NAME;

	@Value("${aliyun.oss.policy.expire}")
	private int EXPIRE;

	@Value("${aliyun.oss.maxSize}")
	private int MAX_SIZE;

	@Value("${aliyun.oss.dir.prefix}")
	private String DIR_PREFIX;

	@Value("${aliyun.oss.callback}")
	private String CALLBACK;

	@Autowired
	private OSS ossClient;

	@Override
	public OssPolicyResult policy() {
		OssPolicyResult result = new OssPolicyResult();
		// 簽名有效期
		long expireEndTime = System.currentTimeMillis() + EXPIRE * 1000;
		Date expiration = new Date(expireEndTime);
		// 文件名稱
		// String filename = UUID.randomUUID().toString();
		// 文件大小
		long maxSize = MAX_SIZE * 1024 * 1024;
		// 提交節(jié)點
		String action = "http://" + BUCKET_NAME + "." + ENDPOINT;
		// 上傳回調參數(shù)
		Callback callback = new Callback();
		// 指定請求回調的服務器URL
		callback.setCallbackUrl(CALLBACK);
		//(可選)設置回調請求消息頭中Host的值,即您的服務器配置Host的值。
		// callback.setCallbackHost("yourCallbackHost");
		// 設置發(fā)起回調時請求body的值。
		callback.setCallbackBody("{\\\"filename\\\":${object}}");
		// 設置發(fā)起回調請求的Content-Type。
		callback.setCalbackBodyType(Callback.CalbackBodyType.JSON);
		// 設置發(fā)起回調請求的自定義參數(shù),由Key和Value組成,Key必須以x:開始。
		// callback.addCallbackVar("x:dir", "value");
		try {
			PolicyConditions policyConds = new PolicyConditions();
			policyConds.addConditionItem(PolicyConditions.COND_CONTENT_LENGTH_RANGE, 0, maxSize);
			policyConds.addConditionItem(MatchMode.StartWith, PolicyConditions.COND_KEY, DIR_PREFIX);
			String postPolicy = ossClient.generatePostPolicy(expiration, policyConds);
			byte[] binaryData = postPolicy.getBytes(StandardCharsets.UTF_8);
 // 將Policy字符串進行base64編碼
			String policy = BinaryUtil.toBase64String(binaryData);
 // 用OSS的AccessKeySecret對base64編碼后的Policy進行簽名
			String signature = ossClient.calculatePostSignature(postPolicy);
 // 將callback配置進行base64編碼
			String callbackData = BinaryUtil.toBase64String(OSSUtils.jsonizeCallback(callback).getBytes());
			// 返回結果
			result.setAccessKeyId(ACCESS_KEY_ID);
			result.setPolicy(policy);
			result.setSignature(signature);
			// result.setKey(filename);
			result.setDir(dir);
			result.setHost(action);
			result.setCallback(callbackData);
		} catch (Exception e) {
			log.error("簽名生成失敗", e);
		}
		return result;
	}

	@Override
	public OssCallBackResult callback(Map<String, Object> requestBody) {
		OssCallBackResult ossCallbackResult = new OssCallBackResult();
		// 文件名
		String filename = requestBody.get("filename").toString();
		// 文件鏈接
		String url = "https://" + BUCKET_NAME + "." + ENDPOINT + "/" + DIR_PREFIX + "/" + filename;
		ossCallbackResult.setUrl(url);
		return ossCallbackResult;
	}
}

添加 Controller 層:

@Api(tags = "阿里云對象存儲接口")
@RequestMapping("/api")
@RestController
public class OssController {
	
	@Autowired
	private OssService ossService;
	
	@ApiOperation(value = "OSS上傳簽名生成")
	@GetMapping("/aliyun/oss/policy")
	public Object policy() {
		return ossService.policy();
	}

	@ApiOperation(value = "OSS上傳成功回調")
	@PostMapping("/aliyun/oss/callback")
	public Object callback(@RequestBody Map<String, Object> requestBody) {
		return ossService.callback(requestBody);
	}
}

到此這篇關于Spring Boot項目中實現(xiàn)文件上傳功能的示例的文章就介紹到這了,更多相關Spring Boot實現(xiàn)文件上傳內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Java二分查找算法實現(xiàn)代碼實例

    Java二分查找算法實現(xiàn)代碼實例

    這篇文章主要介紹了Java二分查找算法實現(xiàn)代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-11-11
  • JAVA如何獲取30天或某段范圍日期

    JAVA如何獲取30天或某段范圍日期

    JAVA獲取30天或某段范圍日期的方法,在項目使用中比較頻繁,通過示例代碼介紹了Java獲取當前時間的上一年、下一年、上個月、下個月、前一天,當天,本周,上周,本季度,上季度等(時間格式化),感興趣的朋友一起看看吧
    2023-10-10
  • Spring中自定義數(shù)據(jù)類型轉換的方法詳解

    Spring中自定義數(shù)據(jù)類型轉換的方法詳解

    Spring3引入了一個core.onvert包,提供一個通用類型轉換系統(tǒng)。在Spring容器中,可以使用這個系統(tǒng)作為PropertyEditor實現(xiàn)的替代,將外部化的bean屬性值字符串轉換為所需的屬性類型。本文將詳解這一系統(tǒng)的使用方法,需要的可以參考一下
    2022-06-06
  • 使用Spring?Boot?2.x構建Web服務的詳細代碼

    使用Spring?Boot?2.x構建Web服務的詳細代碼

    這篇文章主要介紹了使用Spring?Boot?2.x構建Web服務的詳細代碼,主要基于JWT的身份認證,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-03-03
  • springboot整合shardingjdbc實現(xiàn)分庫分表最簡單demo

    springboot整合shardingjdbc實現(xiàn)分庫分表最簡單demo

    我們知道分庫分表是針對某些數(shù)據(jù)量持續(xù)大幅增長的表,比如用戶表、訂單表等,而不是一刀切將全部表都做分片,這篇文章主要介紹了springboot整合shardingjdbc實現(xiàn)分庫分表最簡單demo,需要的朋友可以參考下
    2021-06-06
  • IntellJ idea使用FileWatch實時編譯less文件的方法

    IntellJ idea使用FileWatch實時編譯less文件的方法

    這篇文章主要介紹了IntellJ idea使用FileWatch實時編譯less文件的相關資料,需要的朋友可以參考下
    2018-02-02
  • Spring實戰(zhàn)之調用實例工廠方法創(chuàng)建Bean操作示例

    Spring實戰(zhàn)之調用實例工廠方法創(chuàng)建Bean操作示例

    這篇文章主要介紹了Spring實戰(zhàn)之調用實例工廠方法創(chuàng)建Bean操作,結合實例形式分析了實例工廠方法創(chuàng)建Bean相關配置、實現(xiàn)方法及操作注意事項,需要的朋友可以參考下
    2019-11-11
  • Java實現(xiàn)指定線程執(zhí)行順序的三種方式示例

    Java實現(xiàn)指定線程執(zhí)行順序的三種方式示例

    這篇文章主要介紹了Java實現(xiàn)指定線程執(zhí)行順序的三種方式,包括通過共享對象鎖加上可見變量,通過主線程Join()以及通過線程執(zhí)行時Join()等三種實現(xiàn)方法,需要的朋友可以參考下
    2019-01-01
  • Java中的JPA實體關系:JPA一對一,一對多(多對一),多對多

    Java中的JPA實體關系:JPA一對一,一對多(多對一),多對多

    Java Persistence API(JPA)是Java平臺上的一個對象關系映射(ORM)規(guī)范,用于簡化數(shù)據(jù)庫操作,其中實體關系的映射是核心內容之一,本文將深入淺出地探討JPA中的三種基本實體關系類型:一對一、一對多、多對多,揭示常見問題、易錯點及其避免策略,希望能幫助大家
    2024-06-06
  • Spring?Boot中的@EnableAutoConfiguration注解詳解

    Spring?Boot中的@EnableAutoConfiguration注解詳解

    這篇文章主要介紹了Spring?Boot中的@EnableAutoConfiguration注解詳解,Spring?Boot是一個非常流行的Java框架,它可以快速創(chuàng)建基于Spring的應用程序。Spring?Boot提供了許多自動配置功能,使得開發(fā)者可以非常容易地創(chuàng)建一個可運行的應用程序,需要的朋友可以參考下
    2023-08-08

最新評論