以下JSP文件用common-fileupload组件实现文件上传,并将文件以二进制文件的形式存入数据库

<%
if("POST".equalsIgnoreCase(request.getMethod)){//如果是POST表单
      DiskFileUpload diskFileUpload = newDiskFileUpload();
      diskFileUpload.setHeaderEncoding("UTF-8");//设置编码
      //解析上传的数据
      List <FileItem> list =diskFileUpload.parseRequest(request);

      for(FileItem fileItem : list){
             if(!fileItem.isFormField()){  //如果是文件域
                    //文件路径,替换掉特殊字符
                    String filename =fileItem.getName().replace("\\","/");
                    //获取文件名
                    filename =filename.substring(filename.lastIndexOf("/")+1);
                    //获取文件类型
                    String filetype =fileItem.getContentType();
                    //获取文件大小
                    Int filesize =fileItem.getSize();

      Connection conn = null;
      PrepareStatement preStmt = null;

      try{
             conn = DbManager.getConnection();
             preStmt = conn.prepareStatement(
"insert into table_name (filename,filetype,size,content,date) values(?,?,?,?,?)");

             preStmt.setString(1,filename);
             preStmt.setString(2,filetype);
             preStmt.setInt(3,filesize);
             preStmt.setBinaryStream(4,fileItem.getInputStream(),filesize);
             preStmt.setTimestamp(5,newTimestamp(System.currentTimeMills()));
             preStmt.executeUpdate();

      }finally{
             if(preStmt != null)  preStmt.close();
             if(conn != null)  conn.close();

      }

             }
      }

}
%>

读取二进制文件

<%
out.clear();  //清空一切输出
int id=Integer.parseInt(request.getParameter("id")); //获取附件ID

Connection conn= null;
PrepareStatementpreStmt = null;
ResultSet rs =null;

try{
conn =DbManager.getConnection();
preStmt =conn.prepareStatement("select from table_name where id = ?");
preStmt.setInt(1,id);
rs =preStmt.executeQuery();

      if(rs.next()){
      response.reset();  //重置response
      response.setContentType(rs.getString("fileType"));//设置输出的文件类型
      response.setContentLength(ra.getInt("filesize"));//设置输出的文件长度

      InputStream ins = null;
      OutputStream ous = null;
             try{
             ins = rs.getBinaryStream("content");
             ous = response.getOutputStream();
             byte [] b = new byte[1024];
             int len = 0;
                    while((len = ins.read(b)) !=-1){
                           ous.write(b,0,len);
                    }
             }finally{
                    if(ous != null) ous.close();
                    if(ins != null) ins.close();
             }
      }else{
             out.println("没有找到附件:"+id);
      }

}finally{
      if(rs! = null)  rs.close();
      if(preStmt != null)  preStmt.close();
      if(conn != null)  conn.close();
}

%>

JDBC存储和读取二进制数据的更多相关文章

  1. SQLite数据库如何存储和读取二进制数据

    SQLite数据库如何存储和读取二进制数据 1. 存储二进制数据 SQLite提供的绑定二进制参数接口函数为: int sqlite3_bind_blob(sqlite3_stmt*, int, co ...

  2. [19/05/07-星期二] JDBC(Java DataBase Connectivity)_CLOB(存储大量的文本数据)与BLOB(存储大量的二进制数据)

    一. CLOB(Character Large Object ) – 用于存储大量的文本数据 – 大字段有些特殊,不同数据库处理的方式不一样,大字段的操作常常是以流的方式来处理的.而非一般的字段,一次 ...

  3. (第二章第三部分)TensorFlow框架之读取二进制数据

    系列博客链接: (第二章第一部分)TensorFlow框架之文件读取流程:https://www.cnblogs.com/kongweisi/p/11050302.html (第二章第二部分)Tens ...

  4. python 读取二进制数据到可变缓冲区中

    想直接读取二进制数据到一个可变缓冲区中,而不需要做任何的中间复制操作.或者你想原地修改数据并将它写回到一个文件中去. 为了读取数据到一个可变数组中,使用文件对象的readinto() 方法.比如 im ...

  5. BLOB存储图片文件二进制数据是非对错

    子在一天一天虚度,生活也在一天一天中茫然 做人做事哪能尽如人意,付出多少收获多少虽然存在偏颇,但是不劳而获的心态是万万不对的,更不能去怨天尤人,低调为人.做好自己就可以了 改进你的系统的最好的方法是先 ...

  6. Cocos Creator存储和读取用户数据--官方文档

    存储数据 cc.sys.localStorage.setItem(key, value) 上面的方法需要两个参数,用来索引的字符串键值 key,和要保存的字符串数据 value. 假如我们要保存玩家最 ...

  7. JDBC流ASCII和二进制数据

    PreparedStatement对象可以使用输入和输出流来提供参数数据.能够将整个文件放入可以容纳大值的数据库列,例如CLOB和BLOB数据类型. 有以下方法可用于流式传输数据 - setAscii ...

  8. 使用jQuery AJAX读取二进制数据

    READING BINARY DATA USING JQUERY AJAX http://www.henryalgus.com/reading-binary-files-using-jquery-aj ...

  9. mysql 存储二进制数据

    晚上小研究了下MySQL存储于读取二进制数据的功能.关键步骤为以下三点: 最重要的一点:存储二进制数据的表的类型需要是blob类型(按长度不同分为tiny, media, long) 插入二进制数据时 ...

随机推荐

  1. FZU 2158

    在密室逃脱游戏中,大家被困在一个密室中,为了逃出密室,需要找到正确的数字密码,于是大家分头行动,分别找到了密码的子序列,而后大家将得到的线索集中整理分析,大家想知道密码最少是多少位.  Input 第 ...

  2. [bzoj4821][Sdoi2017]相关分析

    来自FallDream的博客,未经允许,请勿转载,谢谢. Frank对天文学非常感兴趣,他经常用望远镜看星星,同时记录下它们的信息,比如亮度.颜色等等,进而估算出星星的距离,半径等等.Frank不仅喜 ...

  3. Java Servlet 笔记2

    1. Servlet的生命周期 Servlet 通过调用 init () 方法进行初始化. Servlet 调用 service() 方法来处理客户端的请求. Servlet 通过调用 destroy ...

  4. CentOS 安装Docker

    CentOS 系列安装 Docker Docker 支持 CentOS6 及以后的版本. CentOS6 对于 CentOS6,可以使用 EPEL 库安装 Docker,命令如下 $ sudo yum ...

  5. Android Support库——support annotations

    Android Support库是官方出的支持扩展库,包含了丰富的组件.工具类等,通过在Android SDK Manager中勾选以下两项来获取到. 其中,Android Support Libra ...

  6. SQL Server 虚拟化(1)——虚拟化简介

    本文属于SQL Server虚拟化系列 前言: 现代系统中,虚拟化越来越普遍,如果缺乏对虚拟化工作原理的理解,那么DBA在解决性能问题比如降低资源争用.提高备份还原速度等操作时就会出现盲点.所以基于本 ...

  7. 个人在AS的一些安卓适配经验

    具体的安卓适配http://blog.csdn.net/qfanmingyiq/article/details/53219812 AS在屏幕适配方面做的比eclipse做得好得多. 以下AS中的一些具 ...

  8. 让你的代码减少三倍!使用kotlin开发Android(五) 监听器

    本文同步自 博主的私人博客wing的地方酒馆 在前面的博客中,有一个栗子,是点击按钮转跳的监听器. button.setOnClickListener { val user = User(" ...

  9. Antlr v4入门教程和实例

    1 重逢ANTLR 最早知道ANTLR是当年学习Apache Derby数据库源码时,在看到SQL解析那一层时,第一次看到编译原理在实际项目中的应用,惊叹之余也只能望而却步.之前也根据网上一些资料尝试 ...

  10. 初识Spark2.0之Spark SQL

    内存计算平台spark在今年6月份的时候正式发布了spark2.0,相比上一版本的spark1.6版本,在内存优化,数据组织,流计算等方面都做出了较大的改变,同时更加注重基于DataFrame数据组织 ...