java将base64格式图片读取并存到MInio

package com.zrf.testchatgpt.util;

import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import com.zrf.testchatgpt.service.IConfigService;
import io.minio.BucketExistsArgs;
import io.minio.MakeBucketArgs;
import io.minio.MinioClient;
import io.minio.PutObjectArgs;
import io.minio.errors.MinioException;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import sun.misc.BASE64Decoder;

import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
import java.util.UUID;

@Component
@Slf4j
public class MinioUtil {
    @Autowired
    IConfigService iSysConfigService;

    public String MinioUploadBase64(JSONObject path){
            System.out.println("图片路径为:"+path.toString());
            //你的endpoint,本机可以不变(直接写就行了)
            String endpoint = iSysConfigService.selectConfigByKey("minio_url");
            //你的accessKey
            String accessKey = iSysConfigService.selectConfigByKey("minio_accessKey");
            //你的sercetKey
            String secretKey = iSysConfigService.selectConfigByKey("minio_secretKey");
            //你的bucket
            String bucketName = iSysConfigService.selectConfigByKey("minio_bucket");

            // 使用MinIO服务的URL,端口,Access key和Secret key创建一个MinioClient对象
          String nameSuffix = UUID.randomUUID().toString() + ".png";
          nameSuffix=nameSuffix.replaceAll("-","");
        try {
//            log.info("endpoint:"+endpoint);
//            log.info("accessKey:"+accessKey);
//            log.info("secretKey:"+secretKey);
            MinioClient minioClient =MinioClient.builder()
                    .endpoint(endpoint)
                    .credentials(accessKey, secretKey)
                    .build();
            // 检查存储桶是否已经存在
            boolean isExist = false;
            isExist = minioClient.bucketExists(BucketExistsArgs.builder().bucket(bucketName).build());
            if (isExist) {
                System.out.println("Bucket already exists.");
            } else {
                // 创建一个名为asiatrip的存储桶,用于存储照片的zip文件。
                minioClient.makeBucket(MakeBucketArgs.builder().bucket(bucketName).build());
            }
            JSONArray base64=JSONArray.parseArray(path.getString("images"));
            InputStream byteArrayInputStream = base64ConvertPNG(base64.toString());


            minioClient.putObject( PutObjectArgs.builder().bucket(bucketName).object(nameSuffix).stream(
                    byteArrayInputStream, byteArrayInputStream.available(), -1)
                    .build());
        }catch (Exception e){
            e.printStackTrace();
                //log.info("minio上传出错了");
        }
        return endpoint+"/"+bucketName+"/"+nameSuffix;

    }
    public static InputStream base64ConvertPNG(String base64){
        BASE64Decoder decoder = new BASE64Decoder();
        //解码
        base64 = base64.replaceAll("\\[","");
        base64 = base64.replaceAll("]","");
        base64=base64.substring(1);
        try {

            byte[] buffer = decoder.decodeBuffer(base64);
            for(int i = 0;i<buffer.length;i++){
                if(buffer[i] < 0){
                    buffer[i] += 256;
                }
            }
            //生成流
            ByteArrayInputStream stream = new ByteArrayInputStream(buffer);
            return stream;
        } catch (IOException e) {
            throw new RuntimeException(e);
        }
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
可以使用 Apache POI 库来读取 Excel 文件并将其转换为 base64 字符串,然后使用 MinIO Java 客户端将其上传到 MinIO。 以下是一个示例代码,假设你已经添加了 Apache POI 和 MinIO 客户端的依赖: ```java import java.io.ByteArrayOutputStream; import java.io.FileInputStream; import java.io.IOException; import java.io.InputStream; import java.nio.charset.StandardCharsets; import org.apache.poi.ss.usermodel.Workbook; import org.apache.poi.xssf.usermodel.XSSFWorkbook; import io.minio.MinioClient; import io.minio.errors.MinioException; public class ExcelToMinio { private static final String MINIO_ENDPOINT = "http://localhost:9000"; private static final String MINIO_ACCESS_KEY = "minio_access_key"; private static final String MINIO_SECRET_KEY = "minio_secret_key"; private static final String BUCKET_NAME = "my-bucket"; private static final String OBJECT_NAME = "my-file.xlsx"; public static void main(String[] args) { try { // Read Excel file InputStream excelInputStream = new FileInputStream("path/to/my/file.xlsx"); Workbook workbook = new XSSFWorkbook(excelInputStream); // Convert Excel to base64 string ByteArrayOutputStream outputStream = new ByteArrayOutputStream(); workbook.write(outputStream); String base64String = java.util.Base64.getEncoder().encodeToString(outputStream.toByteArray()); // Initialize MinIO client MinioClient minioClient = new MinioClient(MINIO_ENDPOINT, MINIO_ACCESS_KEY, MINIO_SECRET_KEY); // Upload to MinIO InputStream base64InputStream = new java.io.ByteArrayInputStream(base64String.getBytes(StandardCharsets.UTF_8)); minioClient.putObject(BUCKET_NAME, OBJECT_NAME, base64InputStream, base64String.length(), null, null, null); System.out.println("File uploaded successfully"); } catch (IOException | MinioException e) { System.out.println("Error occurred: " + e.getMessage()); } } } ``` 解释一下代码: 1. 在 `main` 方法中,我们首先读取 Excel 文件并将其转换为 `Workbook` 对象。 2. 然后,我们将 `Workbook` 对象写入 `ByteArrayOutputStream` 中,并将其转换为 base64 字符串。 3. 接下来,我们初始化 MinIO 客户端,并使用 `putObject` 方法将 base64 字符串作为输入流上传到 MinIO 中。 4. 如果上传成功,我们将在控制台输出一条消息。 需要注意的是,这个示例代码中仅限于处理 `.xlsx` 格式的 Excel 文件。如果你需要处理 `.xls` 格式的文件,你需要使用 `HSSFWorkbook` 类代替 `XSSFWorkbook` 类。另外,如果你需要上传其他类型的文件,你需要将 `putObject` 方法中的 `contentType` 参数设置为正确的 MIME 类型。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值