news 2026/4/30 15:22:20

阿里云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/4/29 22:49:34

JSZip实战指南:5个常见错误场景与解决方案

JSZip实战指南&#xff1a;5个常见错误场景与解决方案 【免费下载链接】jszip Create, read and edit .zip files with Javascript 项目地址: https://gitcode.com/gh_mirrors/js/jszip 你是否曾在处理ZIP文件时遇到过这样的困扰&#xff1a;用户上传的文件无法正常打开…

作者头像 李华
网站建设 2026/4/27 10:59:49

终极指南:5款开源macOS窗口管理神器推荐

终极指南&#xff1a;5款开源macOS窗口管理神器推荐 【免费下载链接】open-source-mac-os-apps serhii-londar/open-source-mac-os-apps: 是一个收集了众多开源 macOS 应用程序的仓库&#xff0c;这些应用程序涉及到各种领域&#xff0c;例如编程、生产力工具、游戏等。对于开发…

作者头像 李华
网站建设 2026/4/30 0:57:57

入门篇--Python篇-3-为什么做AI开发首选Python,而不是Java或C++?

作者&#xff1a;Weisian AI探索者 软件工程师 写给每一个想入行AI的你 哈喽&#xff0c;各位技术小伙伴&#xff5e; 最近后台好多刚入门AI的同学问我&#xff1a;“想做AI开发&#xff0c;先学Python、Java还是C呢&#xff1f;” 其实答案很明确——90%的AI开发场景&#x…

作者头像 李华