首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何将BufferedImage对象转换为InputStream或BLOB?

将BufferedImage对象转换为InputStream或BLOB的方法如下:

  1. 将BufferedImage对象转换为InputStream:
代码语言:java
复制
import java.awt.image.BufferedImage;
import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream;
import javax.imageio.ImageIO;

public class BufferedImageToInputStream {
    public static InputStream convert(BufferedImage bufferedImage, String format) throws IOException {
        ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
        ImageIO.write(bufferedImage, format, byteArrayOutputStream);
        InputStream inputStream = new ByteArrayInputStream(byteArrayOutputStream.toByteArray());
        return inputStream;
    }
}
  1. 将BufferedImage对象转换为BLOB:
代码语言:java
复制
import java.awt.image.BufferedImage;
import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.sql.Blob;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import javax.imageio.ImageIO;

public class BufferedImageToBLOB {
    public static void convert(BufferedImage bufferedImage, String format, String jdbcUrl, String user, String password) throws IOException, SQLException {
        ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
        ImageIO.write(bufferedImage, format, byteArrayOutputStream);
        InputStream inputStream = new ByteArrayInputStream(byteArrayOutputStream.toByteArray());
        Connection connection = DriverManager.getConnection(jdbcUrl, user, password);
        String sql = "INSERT INTO your_table_name (your_blob_column) VALUES (?)";
        PreparedStatement preparedStatement = connection.prepareStatement(sql);
        preparedStatement.setBlob(1, inputStream);
        preparedStatement.executeUpdate();
        preparedStatement.close();
        connection.close();
    }
}

其中,your_table_nameyour_blob_column分别表示你要插入数据的表名和BLOB列名。

注意:在使用这些代码时,请确保已经正确配置了数据库连接信息和表结构。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

word转出图片(使用免费插件)02

/**      * 将word文档, 转换成pdf, 中间替换掉变量      * @param source 源为word文档, 必须为docx文档      * @param target 目标输出      * @param params 需要替换的变量      * @throws Exception      */     public static void wordConverterToPdf(InputStream source,                                           OutputStream target, Map<String, String> params) throws Exception {         wordConverterToPdf(source, target, null, params);     }     /**      * 将word文档, 转换成pdf, 中间替换掉变量      * @param source 源为word文档, 必须为docx文档      * @param target 目标输出      * @param params 需要替换的变量      * @param options PdfOptions.create().fontEncoding( "windows-1250" ) 或者其他      * @throws Exception      */     public static void wordConverterToPdf(InputStream source, OutputStream target,                                           PdfOptions options,                                           Map<String, String> params) throws Exception {         //HWPFDocument doc=new HWPFDocument(source);         XWPFDocument doc = new XWPFDocument(source);         paragraphReplace(doc.getParagraphs(), params);         for (XWPFTable table : doc.getTables()) {             for (XWPFTableRow row : table.getRows()) {                 for (XWPFTableCell cell : row.getTableCells()) {                     paragraphReplace(cell.getParagraphs(), params);                 }             }         }         PdfConverter.getInstance().convert(doc, target, options);     }     /** 替换段落中内容 */     private static void paragraphReplace(List<XWPFParagraph> paragraphs, Map<String, String> params) {         if (MapUtils.isNotEmpty(params)) {             for (XWPFParagraph p : paragraphs){                 for (XWPFRun r : p.getRuns()){                     String content = r.getText(r.getTextPosition());                     if(StringUtils.isNotEmpty(content) && params.containsKey(content)) {                         r.setText(params.get(content), 0);                     }                 }             }         }     }

01

Get几个非常实用技能——常用文件操作工具类、图片视频操作

工具类中的方法 1. toFile:MultipartFile转File 参数:MultipartFile multipartFile 2. getExtensionName:获取文件扩展名,不带 . 参数:String filename 3. getFileNameNoEx:Java文件操作 获取不带扩展名的文件名 参数:String filename 4. getSize:文件大小转换 参数:long size 5. inputStreamToFile:inputStream 转 File 参数:InputStream ins, String name 6. upload:将文件名解析成文件的上传路径 MultipartFile file, String filePath 7. downloadExcel:导出excel 参数:List<Map<String, Object>> list, HttpServletResponse response 8. getFileType:获取文件类型 参数:String type 9. getTransferFileType:获取文件类型英文名 参数:String type 10. checkSize:检测文件是否超出允许范围 参数:long maxSize, long size 11. check:判断两个文件是否相同 参数:File file1, File file2 12. getByte:获取文件字节长度 参数:File file 13. getMd5:将字节数组转换为16进制字符 参数:byte[] bytes 14. downloadFile:下载文件 参数:HttpServletRequest request, HttpServletResponse response, File file, boolean deleteOnExit

01

java实现在线预览–poi实现word、excel、ppt转html

###简介 java实现在线预览功能是一个大家在工作中也许会遇到的需求,如果公司有钱,直接使用付费的第三方软件或者云在线预览服务就可以了,例如永中office、office web 365(http://www.officeweb365.com/)他们都有云在线预览服务,就是要钱0.0 如果想要免费的,可以用openoffice,还需要借助其他的工具(例如swfTools、FlexPaper等)才行,可参考这篇文章http://blog.csdn.net/z69183787/article/details/17468039,写的挺细的,实现原理就是: 1.通过第三方工具openoffice,将word、excel、ppt、txt等文件转换为pdf文件; 2.通过swfTools将pdf文件转换成swf格式的文件; 3.通过FlexPaper文档组件在页面上进行展示。 当然如果装了Adobe Reader XI,那把pdf直接拖到浏览器页面就可以直接打开预览,这样就不需要步骤2、3了,前提就是客户装了Adobe Reader XI这个pdf阅读器。 我这里介绍通过poi实现word、excel、ppt转html,这样就可以放在页面上了。

02
领券