J2EE分散式架構整合阿里雲OSS儲存
摘要: 1. 服務介面定義 / 檔案上傳 1:頭像 2:顯示圖片 3:個人封面 :4:基礎圖片 @param request @param response @param uid 使用者id @param userType 檔案上傳 1:頭像 2:顯示圖片 3:個人封面 :4:基礎圖片 0:影片 @param files 上傳的檔案物件 * @return
服務介面定義
@RequestMapping(value = "/upload/base64Code", method = RequestMethod.POST)
public ResponseVO fileuploadBase64(@RequestBody JSONObject json, HttpServletRequest request, HttpServletResponse response) throws Exception {
String uid = json.optString("uid");
String userType = json.optString("userType");
String base64Code = json.optString("base64Code");
String oldName = json.optString("oldName");
String suffix = json.optString("suffix");
//獲取當前登陸使用者
if(StringUtils.isEmpty(uid)){
return CloudResponseCode.buildEnumResponseVO(CloudResponseCode.USER_ID_NOT_NULL, null);
}
//上傳檔案新名字
String newName = String.valueOf(new Date().getTime());
String fileKey = CloudConstant.VITAL_USER_INFO_PATH + uid + "/" + newName + "." + suffix;
AliyunUtils.getInstance().uploadByte(base64Code.getBytes(), fileKey);
......
.......
return CloudResponseCode.buildEnumResponseVO(CloudResponseCode.FILEUPLOAD_SUCCESS, obj);
}
oss utils封裝
public void uploadByte(byte[] fileByte, String fileKey){
// 建立OSSClient例項
OSSClient ossClient = new OSSClient(CloudConstant.ENDPOINT, CloudConstant.ACCESSKEYID, CloudConstant.ACCESSKEYSECRET);
// 上傳byte陣列
ossClient.putObject(CloudConstant.BUCKET, fileKey, new ByteArrayInputStream(fileByte));
// 關閉client
ossClient.shutdown();
}
public void uploadInputStream(InputStream inputStream, String fileKey){
// 建立OSSClient例項
OSSClient ossClient = new OSSClient(CloudConstant.ENDPOINT, CloudConstant.ACCESSKEYID, CloudConstant.ACCESSKEYSECRET);
// 上傳檔案流
ossClient.putObject(CloudConstant.BUCKET, fileKey, inputStream);
// 關閉client
ossClient.shutdown();
}
public void deleteFile(String fileKey){
// 建立OSSClient例項
OSSClient ossClient = new OSSClient(CloudConstant.ENDPOINT, CloudConstant.ACCESSKEYID, CloudConstant.ACCESSKEYSECRET);
// 刪除檔案
ossClient.deleteObject(CloudConstant.BUCKET, fileKey);
// 關閉client
ossClient.shutdown();
}
3.介面效果
歡迎大家一起學習研究相關技術
願意瞭解框架技術或者原始碼的朋友直接求求交流分享技術2042849237
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/3137/viewspace-2813944/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Spring Boot 整合阿里雲 OSS 進行檔案儲存Spring Boot阿里
- Laravel 使用阿里雲 oss 儲存物件Laravel阿里物件
- SpringBoot整合阿里雲OSS物件儲存實現檔案上傳Spring Boot阿里物件
- 阿里雲OSS雲端儲存管理實踐阿里
- 阿里雲物件儲存OSS支援版本管理特性阿里物件
- 阿里雲物件儲存OSS及CDN加速配置阿里物件
- 基於MFS高可用的分散式儲存架構分散式架構
- 杉巖PACS影像系統分散式儲存架構分散式架構
- 分散式日誌儲存架構程式碼實踐分散式架構
- DAOS 分散式非同步物件儲存|架構設計分散式非同步物件架構
- SpringBoot使用阿里OSS實現檔案雲端儲存Spring Boot阿里
- 前端(react)上傳到阿里雲OSS儲存 例項前端React阿里
- 分散式系統架構與雲原生—阿里雲《雲原生架構白皮書》導讀分散式架構阿里
- 分散式儲存架構知識,一篇講清楚!分散式架構
- Unirech:阿里雲國際站的物件儲存oss與自建儲存的區別阿里物件
- Longhorn 雲原生分散式塊儲存解決方案設計架構和概念分散式架構
- SpringBoot 整合 阿里雲OSS 儲存服務,快來免費搭建一個自己的圖床Spring Boot阿里圖床
- 分散式塊儲存 ZBS 的自主研發之旅 | 架構篇分散式架構
- 整合spring cloud雲架構 -高可用的分散式配置中心SpringCloud架構分散式
- 整合spring cloud雲架構 --spring cloud分散式系統中實現分散式鎖SpringCloud架構分散式
- 王懷遠:阿里雲一站式物聯網儲存架構設計阿里架構
- 阿里雲解決方案架構師,講述分散式架構雲平臺解決方案阿里架構分散式
- Spring Cloud微服務分散式雲架構 - 整合企業架構的技術點SpringCloud微服務分散式架構
- Spring Cloud微服務分散式雲架構—整合專案簡介SpringCloud微服務分散式架構
- Laravel5.6 + 阿里雲 OSS 完成圖文分離架構Laravel阿里架構
- (二)spring cloud微服務分散式雲架構 - 整合企業架構的技術點SpringCloud微服務分散式架構
- (二)spring cloud微服務分散式雲架構-整合企業架構的技術點SpringCloud微服務分散式架構
- J2EE企業分散式微服務雲快速開發架構分散式微服務架構
- HDFS分散式儲存分散式
- Redis 分散式儲存Redis分散式
- (三)springcloud微服務分散式雲架構-SpringCloud整合專案簡介SpringGCCloud微服務分散式架構
- (十六)spring cloud微服務分散式雲架構-整合專案簡介SpringCloud微服務分散式架構
- Longhorn,Kubernetes 雲原生分散式塊儲存分散式
- Longhorn 雲原生容器分散式儲存 - Python Client分散式Pythonclient
- 整合spring cloud雲服務架構 - 企業分散式微服務雲架構構建SpringCloud架構分散式微服務
- 大規模分散式儲存系統:原理解析與架構實戰分散式架構
- 分散式儲存單主、多主和無中心架構的特徵與趨勢分散式架構特徵
- spring cloud微服務分散式雲架構 - Spring Cloud整合專案簡介SpringCloud微服務分散式架構