山东大学软件学院项目实训-基于大模型的模拟面试系统-个人主页头像上传

采用图床的方案,存储用户头像。

实现步骤

引入OSS依赖

在我们的SpringBoot项目中引入OSS依赖

cpp 复制代码
<dependency>
    <groupId>com.aliyun.oss</groupId>
    <artifactId>aliyun-sdk-oss</artifactId>
    <version>3.10.2</version>
</dependency>

配置 OSSClient

java 复制代码
package com.sdumagicode.backend.config;

import com.aliyun.oss.OSSClient;
import com.aliyun.oss.OSSClientBuilder;
import io.github.cdimascio.dotenv.Dotenv;
import lombok.Data;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Data
@Configuration
public class OSSUploadConfig {
    private String endpoint;
    private String accessKeyId;
    private String accessKeySecret;
    private String bucketName;
    private String maxSize;
    private String prefix;

    public OSSUploadConfig() {
        Dotenv dotenv = Dotenv.configure().load();
        this.endpoint = dotenv.get("ALIYUN_OSS_ENDPOINT");
        this.accessKeyId = dotenv.get("ALIYUN_OSS_ACCESS_KEY_ID");
        this.accessKeySecret = dotenv.get("ALIYUN_OSS_ACCESS_KEY_SECRET");
        this.bucketName = dotenv.get("ALIYUN_OSS_BUCKET_NAME");
        this.maxSize = dotenv.get("ALIYUN_OSS_MAX_SIZE");
        this.prefix = dotenv.get("ALIYUN_OSS_DIR_PREFIX");
    }

    @Bean
    public OSSClient createOssClient() {
        return (OSSClient) new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);
    }
}

配置信息在.env文件里:

java 复制代码
# .env 文件(注意:不要加引号)
ALIYUN_OSS_ENDPOINT=oss-cn-hangzhou.aliyuncs.com
ALIYUN_OSS_ACCESS_KEY_ID=your-access-key-id
ALIYUN_OSS_ACCESS_KEY_SECRET=your-access-key-secret
ALIYUN_OSS_BUCKET_NAME=your-bucket-name
ALIYUN_OSS_MAX_SIZE=10MB
ALIYUN_OSS_DIR_PREFIX=uploads/

因为Spring Boot 默认不直接支持 .env 文件,所以需要使用 dotenv 库来加载它。

cpp 复制代码
<dependency>
    <groupId>io.github.cdimascio</groupId>
    <artifactId>dotenv-java</artifactId>
    <version>3.0.0</version>
</dependency>

完成上述代码后,我们就可以在其他类中上传图片到阿里云图床了。

调用实例

首先,根据前端传来的是一个base64编码的图片,于是定义了一个工具类专门处理该图片并将其上传到阿里云图床。

java 复制代码
package com.sdumagicode.backend.util;

import com.aliyun.oss.OSSClient;
import com.aliyun.oss.model.PutObjectRequest;
import com.sdumagicode.backend.config.OSSUploadConfig;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.io.ByteArrayInputStream;
import java.util.Base64;
import java.util.UUID;

@Service
public class OSSUpload {
    private final OSSClient ossClient;
    private final OSSUploadConfig ossConfig;

    @Autowired
    public OSSUpload(OSSClient ossClient, OSSUploadConfig ossConfig) {
        this.ossClient = ossClient;
        this.ossConfig = ossConfig;
    }

    public String uploadBase64ToOSS(String base64Data, String folder) {
        try {
            // 1. 检查 Base64 数据
            if (base64Data == null || !base64Data.startsWith("data:image/")) {
                throw new IllegalArgumentException("Base64 数据格式不正确");
            }

            // 2. 解析 Base64
            String[] parts = base64Data.split(",");
            String header = parts[0]; // data:image/png;base64
            String data = parts[1];   // 实际数据

            // 3. 获取文件扩展名
            String extension = header.split(";")[0].split("/")[1];

            // 4. 生成唯一文件名
            String fileName = folder + UUID.randomUUID() + "." + extension;

            // 5. 解码并上传
            byte[] bytes = Base64.getDecoder().decode(data);
            ossClient.putObject(
                    ossConfig.getBucketName(),
                    fileName,
                    new ByteArrayInputStream(bytes)
            );

            // 6. 返回访问 URL
            return "https://" + ossConfig.getBucketName() + "." + ossConfig.getEndpoint() + "/" + fileName;
        } catch (Exception e) {
            throw new RuntimeException("上传图片到 OSS 失败: " + e.getMessage(), e);
        }
    }
}

之后,修改UserServiceImpl.java文件里保存图片URL的部分:

java 复制代码
@Autowired
private OSSUpload ossUpload;

...

if (FileDataType.BASE64.equals(user.getAvatarType())) {
    // 1. 上传Base64图片到OSS
    String ossUrl = ossUpload.uploadBase64ToOSS(user.getAvatarUrl(), "avatars/");
    // 2. 更新用户信息
    user.setAvatarUrl(ossUrl);
    user.setAvatarType("0"); // 假设"0"表示URL类型
}

图片成功上传到阿里云,并且可以在用户端正常显示。

遇到的问题

dotenv版本不匹配

java 复制代码
java: cannot access io.github.cdimascio.dotenv.Dotenv
  bad class file: /Users/leeson/.m2/repository/io/github/cdimascio/dotenv-java/3.0.0/dotenv-java-3.0.0.jar!/io/github/cdimascio/dotenv/Dotenv.class
    class file has wrong version 55.0, should be 52.0
    Please remove or make sure it appears in the correct subdirectory of the classpath.

这个错误是因为 Java 版本不兼容.class 文件的版本 55.0 对应 Java 11 ,而项目使用的是 Java 8 (版本 52.0),导致无法加载该类。

解决方案

降级 dotenv-java(兼容 Java 8)

xml 复制代码
<dependency>
    <groupId>io.github.cdimascio</groupId>
    <artifactId>dotenv-java</artifactId>
    <version>2.3.2</version> <!-- 支持 Java 8 的版本 -->
</dependency>

修改之后,项目成功地跑了起来。

相关推荐
heartbeat..7 分钟前
零基础学 SQL:DQL/DML/DDL/DCL 核心知识点汇总(附带连接云服务器数据库教程)
java·服务器·数据库·sql
萌萌哒草头将军19 分钟前
Node.js 存在多个严重安全漏洞!官方建议尽快升级🚀🚀🚀
vue.js·react.js·node.js
专注于大数据技术栈29 分钟前
java学习--LinkedHashSet
java·开发语言·学习
这个图像胖嘟嘟31 分钟前
前端开发的基本运行环境配置
开发语言·javascript·vue.js·react.js·typescript·npm·node.js
北辰alk35 分钟前
Vue 自定义指令生命周期钩子完全指南
前端·vue.js
是小崔啊35 分钟前
03-vue2
前端·javascript·vue.js
阿湯哥1 小时前
Spring AI Alibaba 实现 Workflow 全指南
java·人工智能·spring
旺仔小拳头..1 小时前
Java ---变量、常量、类型转换、默认值、重载、标识符、输入输出、访问修饰符、泛型、迭代器
java·开发语言·python
12344521 小时前
【面试复盘】有了equals为什么还要hashcode
java·后端
毕设源码-邱学长2 小时前
【开题答辩全过程】以 台球俱乐部管理系统为例,包含答辩的问题和答案
java·eclipse