java 文件上传数据库

存储文件的数据库类型:

     1.oracle :Blob,bfile类型

     2.mysql:longblob类型

     3.sqlserver :varbinary(Max)类型

 

文件都是以二进制流存入数据库的,因此,在文件上传后,我们要将文件转换为byte[],然后通过import java.io.File;处理成byte存放到数据库。

以下为数据操作类(java):

复制代码
package com.yunztec.eprj.util;
import java.io.BufferedOutputStream;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;

public class FileOperateUtil {
 
 
 private static FileOperateUtil fpu=new FileOperateUtil();
 
 
 public static FileOperateUtil getInstance(){
  return fpu;
 }
 
 
 
 public byte[] getBytes(File file){  
       byte[] buffer = null;  
          try {     
              FileInputStream fis = new FileInputStream(file);  
              ByteArrayOutputStream bos = new ByteArrayOutputStream(1000);  
              byte[] b = new byte[1000];  
              int n;  
              while ((n = fis.read(b)) != -1) {  
                  bos.write(b, 0, n);  
              }  
              fis.close();  
              bos.close();  
              buffer = bos.toByteArray();  
          } catch (FileNotFoundException e) {  
              e.printStackTrace();  
          } catch (IOException e) {  
              e.printStackTrace();  
          }  
        return buffer;  
 }
 
 
 public String writeFileToService(byte[] bt, String filePath,String fileName) {  
        BufferedOutputStream bos = null;  
        FileOutputStream fos = null;  
        File file = null;  
        try {  
            File dir = new File(filePath);
            System.out.println(dir.exists());
            if(!dir.exists()){//判断文件目录是否存在  
                dir.mkdirs();  
            }  
            file = new File(filePath+"\\"+fileName);  
            fos = new FileOutputStream(file);  
            bos = new BufferedOutputStream(fos);  
           bos.write(bt);  
       } catch (Exception e) {  
           e.printStackTrace();  
       } finally {  
           if (bos != null) {  
                try {  
                    bos.close();  
                } catch (IOException e1) {  
                    e1.printStackTrace();  
                }  
            }  
            if (fos != null) {  
                try {  
                    fos.close();  
                } catch (IOException e1) {  
                    e1.printStackTrace();  
                }  
            }  
        }  
        return filePath+"\\"+fileName;
   }
}
复制代码

 

总结:

1.上传:  file----->byte[]   

2.下载: byte[]------->File---->存到服务器--->提供路径---->下载完成后删除服务器文件。

posted @   岁月淡忘了谁  阅读(1532)  评论(0编辑  收藏  举报
(评论功能已被禁用)
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
点击右上角即可分享
微信分享提示