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---->存到服务器--->提供路径---->下载完成后删除服务器文件。

Java中,可以使用MultipartFile类来处理文件上传,然后将文件内容存入数据库,并实现文件的下载功能。 文件上传的步骤如下: 1. 在HTML表单中添加一个文件选择的按钮,并设置enctype为multipart/form-data,以支持文件上传。 2. 后端接收文件的控制器方法使用@RequestParam注解来接收上传的文件,将其转换为MultipartFile对象。 3. 使用MultipartFile的方法可以获取文件的相关信息,比如文件名、文件大小等。 4. 通过MultipartFile的getInputStream()方法,可以获取文件内容的输入流。 5. 将文件内容的输入流存入数据库中,可以将文件内容存储为BLOB类型或者将文件保存到磁盘上,并将文件路径存入数据库中。 文件下载的步骤如下: 1. 在HTML页面中,添加一个下载链接或者按钮,点击该链接或按钮时触发下载操作。 2. 后端接收下载请求的控制器方法根据请求的参数,从数据库中获取文件信息。 3. 如果文件存储为BLOB类型,可以通过Blob对象的getBinaryStream()方法获取文件内容的输入流;如果文件是保存在磁盘上,可以通过读取文件的方式获取文件内容的输入流。 4. 使用HttpServletResponse对象设置响应头,包括Content-Disposition设置为attachment,以指定浏览器将文件作为附件下载。 5. 将文件内容的输入流通过HttpServletResponse的输出流输出到前端,完成文件下载操作。 以上就是使用Java上传文件存入数据库并下载的简要步骤。具体的实现逻辑需要根据具体情况进行调整和完善。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值