JEESZ分布式架构集成阿里云OSS存储
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JEESZ分布式架构集成阿里云OSS存储相关的知识,希望对你有一定的参考价值。
1. 服务接口定义
/**
* 文件上传 1:头像 2:显示图片 3:个人封面 :4:基础图片
* @param request
* @param response
* @param uid 用户id
* @param userType 文件上传 1:头像 2:显示图片 3:个人封面 :4:基础图片 0:视频
* @param files 上传的文件对象
* @return
* @throws Exception
*/
@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);
}
2. oss utils封装
/**
* 上传byte数组
* @param fileByte
* @param fileKey
*/
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();
}
/**
* 上传文件流
* @param inputStream
* @param fileKey
*/
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();
}
/**
* 删除文件
* @param fileKey
*/
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
更多详细源码参考来源:http://minglisoft.cn/technology
以上是关于JEESZ分布式架构集成阿里云OSS存储的主要内容,如果未能解决你的问题,请参考以下文章