当前位置: 首页 > news >正文

阿里云OSS文件上传案例

OSS 文件上传流程详解

以下是基于提供代码实现的 OSS 文件上传完整流程,包含配置、核心代码及步骤说明:

一、前期准备
  1. 阿里云 OSS 配置
    • 需在阿里云控制台创建 Bucket,获取endpointaccessKeyIdaccessKeySecretbucketName
    • 配置文件位置:src/main/resources/oss.properties

properties

# oss.properties配置示例 aliyun.oss.endpoint=oss-cn-beijing.aliyuncs.com aliyun.oss.accessKeyId=LTAI5tGRHc12i6A4ZEnrUaRR aliyun.oss.accessKeySecret=EEeB0vBuvmDlXK1fkX2cBMWcsztlx0 aliyun.oss.bucketName=zjc-java-spring
二、核心组件配置
  1. OSS 客户端配置(OssConfig.java)

java

运行

@Configuration public class OssConfig { // 从配置文件注入OSS连接参数 @Value("${aliyun.oss.endpoint}") private String endpoint; @Value("${aliyun.oss.accessKeyId}") private String accessKeyId; @Value("${aliyun.oss.accessKeySecret}") private String accessKeySecret; // 创建OSS客户端实例并交给Spring管理 @Bean(destroyMethod = "shutdown") public OSS ossClient() { return new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret); } }
  1. 文件上传工具类(OssUtils.java)

java

运行

@Component public class OssUtils { @Autowired private OSS ossClient; @Value("${aliyun.oss.bucketName}") private String bucketName; @Value("${aliyun.oss.endpoint}") private String endpoint; /** * 文件上传到OSS * @param file 要上传的文件 * @param folder OSS存储文件夹 * @return 外网访问URL */ public String upload(MultipartFile file, String folder) throws Exception { // 1. 校验文件是否为空 if (file.isEmpty()) { throw new Exception("上传文件不能为空"); } // 2. 处理文件名和后缀 String originalFilename = file.getOriginalFilename(); String suffix = ""; if (originalFilename != null && originalFilename.contains(".")) { suffix = originalFilename.substring(originalFilename.lastIndexOf(".")); } String fileName = originalFilename; // 使用原始文件名 // 3. 处理文件夹路径 if (!folder.endsWith("/")) { folder += "/"; } String objectName = folder + fileName; // 最终OSS存储路径 // 4. 上传文件到OSS InputStream inputStream = file.getInputStream(); try { ossClient.putObject(bucketName, objectName, inputStream); } finally { inputStream.close(); // 确保流关闭 } // 5. 构建文件访问URL String endpointWithoutProtocol = endpoint.replaceFirst("^https?://", ""); return "https://" + bucketName + "." + endpointWithoutProtocol + "/" + objectName; } }
三、业务层实现
  1. 服务接口(FileService.java)

java

运行

public interface FileService { // 上传文件并返回文件信息 File uploadFile(MultipartFile file, String fileName); }
  1. 服务实现类(FileServiceImpl.java)

java

运行

@Service public class FileServiceImpl implements FileService { @Autowired private FileMapper fileMapper; @Autowired private OssUtils ossUtils; @Override public File uploadFile(MultipartFile file, String fileName) { try { // 1. 上传文件到OSS,指定存储文件夹 String folder = "file/"; String fileUrl = ossUtils.upload(file, folder); // 2. 构建文件实体对象 File fileEntity = new File(); fileEntity.setName(fileName); fileEntity.setUrl(fileUrl); // 提取文件标识(用于后续删除) String keyPoints = fileUrl.substring(fileUrl.lastIndexOf("/") + 1); fileEntity.setKeyPoints(keyPoints); // 3. 保存文件信息到数据库 fileMapper.insert(fileEntity); return fileEntity; } catch (Exception e) { throw new RuntimeException("文件上传失败:" + e.getMessage()); } } }
四、控制器层(接收前端请求)

java

运行

@Controller @RequestMapping("/file") public class FileController { @Autowired private FileService fileService; @PostMapping("/upload") @ResponseBody public Map<String, Object> upload( @RequestParam("file") MultipartFile file, @RequestParam("fileName") String fileName) { Map<String, Object> result = new HashMap<>(); try { // 1. 校验参数 if (file == null || file.isEmpty()) { result.put("success", false); result.put("message", "请选择文件"); return result; } // 2. 调用服务层上传 File fileEntity = fileService.uploadFile(file, fileName); // 3. 返回结果 result.put("success", true); result.put("data", fileEntity); result.put("message", "上传成功"); } catch (Exception e) { result.put("success", false); result.put("message", "上传失败:" + e.getMessage()); } return result; } }
五、SpringMVC 文件上传配置

springmvc.xml中配置文件上传解析器:

xml

<!-- 文件上传解析器 --> <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <property name="maxUploadSize" value="10485760"/> <!-- 最大10MB --> <property name="defaultEncoding" value="UTF-8"/> </bean>
六、完整上传流程总结
  1. 前端请求:通过表单或 AJAX 提交MultipartFile文件和文件名
  2. 参数校验:控制器检查文件是否为空、文件名是否存在
  3. OSS 上传
    • 工具类处理文件路径和名称
    • 通过 OSS 客户端将文件流上传到指定 Bucket
    • 生成外网可访问的文件 URL
  4. 数据持久化
    • 将文件 URL、名称、标识等信息存入数据库
    • 返回包含文件信息的成功响应
  5. 异常处理:任何环节出错时返回错误信息
七、关键注意点
  1. 确保 OSS Bucket 的访问权限设置正确(通常为公共读)
  2. 生产环境中应使用 UUID 生成唯一文件名,避免重名覆盖
  3. 大文件上传建议分块上传(需额外实现)
  4. 记得在项目关闭时关闭 OSS 客户端连接(已通过@PreDestroy实现)
  5. 实际部署时需替换为自己的 OSS 密钥信息,避免泄露
http://www.jsqmd.com/news/105208/

相关文章:

  • 8、量子计算与技术发展:从理论根源到实际应用
  • 10、日志记录与事件处理:Linux 系统的高效解决方案
  • Moonlight for Tizen:智能电视游戏串流终极指南
  • 【Azure CLI量子作业资源统计全攻略】:掌握高效资源监控的5大核心命令
  • 从信号到数据的“魔法转换”:图像采集卡如何让机器“看懂”世界?
  • KuGouMusicApi:打造专业的酷狗音乐开发接口服务
  • 大模型Agent核心架构拆解:从原理到可落地的智能任务规划器开发
  • 11、量子计算加速发展:从理论到现实的飞跃
  • 自动识别U盘并格式化bat脚本
  • Docker 安全配置终极指南:打造不可穿透的智能 Agent 运行环境
  • 车载网关前装与后装差的区别及选型
  • 29、实现 SNMP MIB 及 RTA 参考指南
  • 2025年石墨板制造商及定制服务商排行榜,专业石墨制品公司测 - myqiye
  • 毕设分享 基于单片机的姿态检测与可视化系统(源码+硬件+论文)
  • Jellyfin Bangumi插件3分钟配置攻略:告别混乱的动画收藏管理
  • 棕榈酰二肽-5 / SYN-Tacks轮廓重塑,紧致上扬794590-34-4
  • EmotiVoice移动端SDK预览:即将支持iOS和Android平台
  • 窗口置顶功能:打造高效多任务工作环境
  • 省钱不打折!爱创猫靠谱 AI 服务,功能全还便宜
  • 3步打造高颜值Obsidian:从新手到美化达人终极指南
  • 暗影精灵笔记本性能管理神器:OmenSuperHub离线控制完全指南
  • 高效实战:5种SHAP可视化方法深度解析机器学习模型
  • DeepSeek-V3 KV缓存技术:如何实现多轮对话推理效率的突破性提升
  • Docker权限校验全攻略,守护AI模型最后一道防线
  • DeeplxFile终极指南:免费文件翻译的完整解决方案
  • DeeplxFile终极指南:免费文件翻译的完整解决方案
  • Windows隐藏功能管理:5个实用技巧告别命令行恐惧
  • 【Electron教程】第1节 Electron 简介与环境搭建 - 教程
  • IDM无限试用重置工具:数字时代下载管理终极解决方案
  • rclone云存储配置全攻略:从零基础到高效数据同步专家