zoukankan      html  css  js  c++  java
  • 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---->存到服务器--->提供路径---->下载完成后删除服务器文件。

  • 相关阅读:
    Eclipse部署项目到Tomcat中,class文件夹为空的解决方案
    微软(北京).NET俱乐部活动 (2010年6月26日) – Visual Studio 2010 /*LIFE RUNS ON CODE*/
    失望的Vista SP1
    急聘BI DW OLAP开发工程师 (北京)
    急聘.NET开发工程师 (北京)
    开篇
    Windows Vista User Account Control (UAC) 全新安全模块“用户帐户控制”
    Tidy your desktop
    [导入]Vista的屏幕截图小工具:Snipping Tool
    微软发布官方TFS 2010 Scrum 模板
  • 原文地址:https://www.cnblogs.com/henuyuxiang/p/6674699.html
Copyright © 2011-2022 走看看