亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

Spring Boot項目中實現文件上傳功能的示例

瀏覽:58日期:2023-07-29 08:37:11

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

一、配置OSS1. 導入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 配置文件中添加以下內容

# 節點域名aliyun.oss.endpoint=oss-cn-xxxxxxx.aliyuncs.com# 賬戶idaliyun.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# 回調參數的請求地址aliyun.oss.callback=http://www.xxxxxx.com/api/aliyun/oss/callback

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

3. 初始化

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

根據官方文檔的描述,需要初始化一個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后,表單上傳分為以下幾個流程:

Spring Boot項目中實現文件上傳功能的示例

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

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服務器會向應用服務器發起回調請求,具體流程如下:

Spring Boot項目中實現文件上傳功能的示例

用戶只需要在發送給 OSS 的請求中攜帶相應的 Callback 參數,即能實現回調。

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

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

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

2. 功能實現

首先編寫 Post Policy 封裝對象OssPolicyResult

@Datapublic 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

@Datapublic 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;}

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

之后編寫 Service 接口及實現類

Service 接口:

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

Service 實現類:

@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;@Autowiredprivate OSS ossClient;@Overridepublic 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;// 提交節點String action = 'http://' + BUCKET_NAME + '.' + ENDPOINT;// 上傳回調參數Callback callback = new Callback();// 指定請求回調的服務器URLcallback.setCallbackUrl(CALLBACK);//(可選)設置回調請求消息頭中Host的值,即您的服務器配置Host的值。// callback.setCallbackHost('yourCallbackHost');// 設置發起回調時請求body的值。callback.setCallbackBody('{'filename':${object}}');// 設置發起回調請求的Content-Type。callback.setCalbackBodyType(Callback.CalbackBodyType.JSON);// 設置發起回調請求的自定義參數,由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;}@Overridepublic 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')@RestControllerpublic class OssController {@Autowiredprivate 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項目中實現文件上傳功能的示例的文章就介紹到這了,更多相關Spring Boot實現文件上傳內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Spring
相關文章:
主站蜘蛛池模板: 成人精品一区二区三区校园激情 | 精品欧美一区二区精品久久 | 亚州精品一区中文字幕乱码 | 国产三级在线免费观看 | 欧洲美女高清一级毛片 | 青青自拍 | 久久精品区 | 中文字幕日韩在线 | 日韩一级a毛片欧美一级 | 劲爆欧美色欧美 | 免费观看亚洲 | 日本精品久久久久中文字幕2 | 国产国语一级毛片 | 久久成 | 九九热视频这里只有精品 | 九九九好热在线 | 国模沟沟一区二区三区 | 国产一二区 | 亚洲图片欧洲图片aⅴ | 亚洲视频污 | 正在播放一区二区 | 看一级毛片免费观看视频 | 一区二区三区欧美视频 | 免费一区二区三区在线视频 | 992tv快乐视频在线啪啪免费 | 狂野猛交xxxx吃奶 | 看亚洲a级一级毛片 | 香蕉免费一区二区三区在线观看 | 高h猛烈做哭bl壮汉受小说 | 国产成人精品亚洲午夜麻豆 | 2021年国产精品久久 | 国产美女视频一区二区二三区 | 欧美日韩免费一区二区三区 | 午夜激情免费 | 久草免费色站 | 亚洲精品亚洲人成在线观看麻豆 | 欧美三级在线观看黄 | 一级片在线播放 | 亚洲欧美日韩闷骚影院 | 一级做a爱久久久久久久 | 国产一级特黄全黄毛片 |