news 2026/4/5 5:05:23

阿里云OSS文件上传案例

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
阿里云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 密钥信息,避免泄露
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/31 21:10:42

Windows系统透明美化大师:DWMBlurGlass全方位使用教程

Windows系统透明美化大师&#xff1a;DWMBlurGlass全方位使用教程 【免费下载链接】DWMBlurGlass Add custom effect to global system title bar, support win10 and win11. 项目地址: https://gitcode.com/gh_mirrors/dw/DWMBlurGlass 还在为Windows系统单调的界面设计…

作者头像 李华
网站建设 2026/4/3 6:08:27

钉钉防撤回工具完整使用指南:彻底解决消息消失烦恼

想要完全掌握钉钉防撤回工具的使用技巧吗&#xff1f;本指南将带你从零开始&#xff0c;快速掌握这款实用工具的完整使用方法&#xff0c;彻底告别消息被撤回的烦恼&#xff01; 【免费下载链接】DingTalkRevokeMsgPatcher 钉钉消息防撤回补丁PC版&#xff08;原名&#xff1a;…

作者头像 李华
网站建设 2026/4/3 9:21:08

电子签名终极解决方案:OpenSign免费开源平台完全指南

电子签名终极解决方案&#xff1a;OpenSign免费开源平台完全指南 【免费下载链接】OpenSign &#x1f525; &#x1f525; &#x1f525; The free & Open Source DocuSign alternative 项目地址: https://gitcode.com/gh_mirrors/op/OpenSign 在数字化转型浪潮中&a…

作者头像 李华
网站建设 2026/4/1 10:37:24

Qwen3-4B-FP8模型本地部署实战:5分钟轻松搭建AI助手

Qwen3-4B-FP8模型本地部署实战&#xff1a;5分钟轻松搭建AI助手 【免费下载链接】Qwen3-4B-Instruct-2507-FP8 项目地址: https://ai.gitcode.com/hf_mirrors/Qwen/Qwen3-4B-Instruct-2507-FP8 还在为AI模型部署的复杂流程而头疼吗&#xff1f;Qwen3-4B-FP8作为新一代轻…

作者头像 李华
网站建设 2026/3/27 1:35:10

量子计算+AI开发新范式(VSCode加载QML模型全解析)

第一章&#xff1a;量子机器学习的 VSCode 模型加载在现代量子机器学习开发中&#xff0c;VSCode 已成为主流集成开发环境之一。借助其丰富的插件生态和对 Python、Q# 等语言的良好支持&#xff0c;开发者可以高效地加载与调试量子模型。环境准备 在开始前&#xff0c;确保已安…

作者头像 李华