java处理富文本图片保存数据库

在接收富文本时,数据库接收含有图片内容,图片会自动转换为Base64编码保存到数据库,导数据库性能降低。

解决:在接收富文本内容时,将接收到的图片转换为文件上传到Minio(Minio具体使用可参考文档),然后将base64编码替换为图片地址保存

用到的工具类

使用正则表达式提取接收内容的Base64编码工具类

import java.util.ArrayList;
import java.util.List;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class ImgBaseUtil {
    public static List<String> getImgStr(String htmlStr) {
        List<String> list = new ArrayList<>();
        String img = "";
        Pattern p_image;
        Matcher m_image;
        // String regEx_img = "<img.*src=(.*?)[^>]*?>"; //图片链接地址
        String regEx_img = "<img.*src\\s*=\\s*(.*?)[^>]*?>";
        p_image = Pattern.compile(regEx_img, Pattern.CASE_INSENSITIVE);
        m_image = p_image.matcher(htmlStr);
        while (m_image.find()) {
            // 得到<img />数据
            img = m_image.group();
            // 匹配<img>中的src数据
            Matcher m = Pattern.compile("src\\s*=\\s*\"?(.*?)(\"|>|\\s+)").matcher(img);
            while (m.find()) {
                list.add(m.group(1));
            }
        }
        return list;
    }
}

将Base64编码转换为文件流的工具类

import org.springframework.web.multipart.MultipartFile;
import sun.misc.BASE64Decoder;

import java.io.*;

public class BASE64DecodedMultipartFile implements MultipartFile {
 
    private final byte[] imgContent;
    private final String header;
 
    public BASE64DecodedMultipartFile(byte[] imgContent, String header) {
        this.imgContent = imgContent;
        this.header = header.split(";")[0];
    }
 
    @Override
    public String getName() {
        return System.currentTimeMillis() + Math.random() + "." + header.split("/")[1];
    }
 
    @Override
    public String getOriginalFilename() {
        return System.currentTimeMillis() + (int) Math.random() * 10000 + "." + header.split("/")[1];
    }
 
    @Override
    public String getContentType() {
        return header.split(":")[1];
    }
 
    @Override
    public boolean isEmpty() {
        return imgContent == null || imgContent.length == 0;
    }
 
    @Override
    public long getSize() {
        return imgContent.length;
    }
 
    @Override
    public byte[] getBytes() throws IOException {
        return imgContent;
    }
 
    @Override
    public InputStream getInputStream() throws IOException {
        return new ByteArrayInputStream(imgContent);
    }
 
    @Override
    public void transferTo(File dest) throws IOException, IllegalStateException {
        new FileOutputStream(dest).write(imgContent);
    }
 
    public static MultipartFile base64ToMultipart(String base64) {
        try {
            String[] baseStrs = base64.split(",");
 
            BASE64Decoder decoder = new BASE64Decoder();
            byte[] b = new byte[0];
            b = decoder.decodeBuffer(baseStrs[1]);
 
            for (int i = 0; i < b.length; ++i) {
                if (b[i] < 0) {
                    b[i] += 256;
                }
            }
            return new BASE64DecodedMultipartFile(b, baseStrs[0]);
        } catch (IOException e) {
            e.printStackTrace();
            return null;
        }
    }
 
}

内容接收并完成处理工具类

public class RichTextUtil {
    /**
     *
     * @param text 富文本内容
     * @return  返回处理图片后的数据
     */
    public  String richText(String text,MinioUtils minioUtils,MinioConfig minioConfig){
        String s=new String(text);
        String result=null;//返回结果
        List<String> imgStr = ImgBaseUtil.getImgStr(s); //每组base64编码图片
        if (imgStr.isEmpty()){
            return text;
        }
        for (String s1:imgStr){ //每个base64转换并上传
            String s2= UUID.randomUUID().toString().replaceAll("-","")+".jpg"; //新的文件链接
            //上传
            MultipartFile multipartFile = BASE64DecodedMultipartFile.base64ToMultipart(s1);
            assert multipartFile != null;
            minioUtils.putObject1(multipartFile,minioConfig.getBucketName(),s2);
            String foreverUrl=minioConfig.getEndpoint()+":"+minioConfig.getPort()+"/"+minioConfig.getBucketName()+"/"+s2;//永久链接

            if (Objects.isNull(result)){
                result=s.replace(s1,foreverUrl); //第一次替换
            }
            result=result.replace(s1,foreverUrl); //前边替换过,继续替换

        }
        return result;
    }
}
配合Minio工具类使用
    @GetMapping("/tss")
    public String dmo(@RequestBody Entity entity) throws IOException {
        String s=entity.getContent();//接收到的内容
        RichTextUtil richTextUtil = new RichTextUtil();
        String s1 = richTextUtil.richText(s,minioUtils,minioConfig);
        entity.setContent(s1);//最后将转换过的内容替换就行
        //数据库保存一下实体类内容
        return entity;
    }

Minio使用可查询相关资料或了解本博客SpringBoot对Minio的简单使用链接: http://t.csdn.cn/IJA0G

Java中,上传图片保存数据库可以通过以下步骤实现: 1. 创建一个包含图片信息的Java类,例如ImageInfo,其中包含图片的名称、类型、大小等属性。 2. 创建一个用于处理文件上传的Servlet,例如UploadServlet。在该Servlet中,可以使用Apache Commons FileUpload库来处理文件上传操作。 3. 在UploadServlet中,获取上传的文件流,并将其保存到服务器的指定位置。可以使用File类来创建目标文件夹和文件,并使用FileOutputStream将文件流写入目标文件。 4. 将图片信息保存数据库中。可以使用JDBC或者ORM框架(如Hibernate、MyBatis)来操作数据库。根据ImageInfo类的定义,创建对应的数据库表,并将图片信息插入到表中。 下面是一个简单的示例代码: ```java // ImageInfo.java public class ImageInfo { private String name; private String type; private long size; // 其他属性和方法 // getter和setter方法 } // UploadServlet.java @WebServlet("/upload") public class UploadServlet extends HttpServlet { protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // 获取上传的文件流 Part filePart = request.getPart("file"); // "file"为前端表单中文件上传字段的名称 InputStream fileInputStream = filePart.getInputStream(); // 保存文件到服务器指定位置 String fileName = filePart.getSubmittedFileName(); String filePath = "/path/to/save/" + fileName; // 指定保存路径 File targetFile = new File(filePath); FileOutputStream fileOutputStream = new FileOutputStream(targetFile); byte[] buffer = new byte[1024]; int length; while ((length = fileInputStream.read(buffer)) != -1) { fileOutputStream.write(buffer, 0, length); } fileOutputStream.close(); fileInputStream.close(); // 将图片信息保存数据库 ImageInfo imageInfo = new ImageInfo(); imageInfo.setName(fileName); imageInfo.setType(filePart.getContentType()); imageInfo.setSize(filePart.getSize()); // 将imageInfo插入到数据库中 // 返回上传成功的提示信息 response.getWriter().println("文件上传成功"); } } ``` 请注意,上述代码仅为示例,实际应用中可能需要进行错误处理、文件大小限制、文件类型验证等操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值