java导入导出pdf文档实践

原创 2007年10月11日 17:59:00

1:mysql数据库存储pdf流字段为:filed name: filestream   type: MEDIUMBLOB

2:导入pdf文件到mysql 数据库 

private void doWrite() ...{
        
try ...{
            
            
if (new File("D:/Sun.pdf").exists()) ...{
                FileInputStream fis 
= new FileInputStream(new File(
                        
"D:/Sun.pdf"));
                PreparedStatement pstmt 
= cnn
                        .prepareStatement(
"insert into tb(filestream) values(?) ");
                pstmt.setBinaryStream(
1, fis, 1024);
                pstmt.execute();
            }

        }
 catch (Exception e) ...{
            e.printStackTrace();
        }

    }

 

3:从mysql数据库读取pdf流到网页客户端显示

private void doRead(HttpServletRequest request, HttpServletResponse response) ...{
        
try ...{
            ByteArrayOutputStream ba 
= new ByteArrayOutputStream();
            Statement stmt 
= cnn.createStatement();
            ResultSet rs 
= stmt.executeQuery("select filestream from tb where id=1");
            rs.next();
            InputStream is 
= rs.getBinaryStream(1);
            
int c;
            
while ((c = is.read()) != -1)
                ba.write(c);
            Document document 
= new Document(PageSize.A4, 36363636);
            PdfWriter writer 
= PdfWriter.getInstance(document, ba);
            
// document.close();
            response.setContentType("application/pdf");
            response.setContentLength(ba.size());
            ServletOutputStream out 
= response.getOutputStream();
            ba.writeTo(out);
            out.flush();
        }
 catch (Exception e) ...{
            e.printStackTrace();
        }

    }

4:下载jar包:itext-2.0.6.jar   iTextAsian.jar(此包是解决中文乱码用)

5:完整源码

import java.io.BufferedInputStream;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.Statement;

import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.lowagie.text.Document;
import com.lowagie.text.DocumentException;
import com.lowagie.text.PageSize;
import com.lowagie.text.Paragraph;
import com.lowagie.text.pdf.PdfWriter;

public class PDFGenerateServlet extends HttpServlet ...{
    
private Connection cnn = null;

    
public void doGet(HttpServletRequest request, HttpServletResponse response)
            
throws IOException, ServletException ...{

        
try ...{
            InitConnection();
            String s 
= request.getParameter("method");
            
if (s.equals("w")) ...{
                doWrite();
            }

            
if (s.equals("r")) ...{
                doRead(request, response);
            }

            
/**//*
             * Statement stmt = cnn.createStatement(); ResultSet rs =
             * stmt.executeQuery(""); InputStream is = rs.getBinaryStream("");
             * int c; while ((c = is.read()) != 1) ba.write(c); // ba=new
             * ByteArrayOutputStream(rs.getBlob("")); PdfWriter writer =
             * PdfWriter.getInstance(document, ba); document.open();
             * document.add(new Paragraph("Hello World"));
             
*/


        }
 catch (Exception e) ...{

        }


    }


    
public void doPost(HttpServletRequest request, HttpServletResponse response)
            
throws IOException, ServletException ...{
        doGet(request, response);
    }


    
private void doWrite() ...{
        
try ...{
            
            
if (new File("D:/Sun.pdf").exists()) ...{
                FileInputStream fis 
= new FileInputStream(new File(
                        
"D:/Sun.pdf"));
                PreparedStatement pstmt 
= cnn
                        .prepareStatement(
"insert into tb(filestream) values(?) ");
                pstmt.setBinaryStream(
1, fis, 1024);
                pstmt.execute();
            }

        }
 catch (Exception e) ...{
            e.printStackTrace();
        }

    }


    
private void doRead(HttpServletRequest request, HttpServletResponse response) ...{
        
try ...{
            ByteArrayOutputStream ba 
= new ByteArrayOutputStream();
            Statement stmt 
= cnn.createStatement();
            ResultSet rs 
= stmt.executeQuery("select filestream from tb where id=1");
            rs.next();
            InputStream is 
= rs.getBinaryStream(1);
            
int c;
            
while ((c = is.read()) != -1)
                ba.write(c);
            Document document 
= new Document(PageSize.A4, 36363636);
            PdfWriter writer 
= PdfWriter.getInstance(document, ba);
            
// document.close();
            response.setContentType("application/pdf");
            response.setContentLength(ba.size());
            ServletOutputStream out 
= response.getOutputStream();
            ba.writeTo(out);
            out.flush();
        }
 catch (Exception e) ...{
            e.printStackTrace();
        }

    }


    
private void InitConnection() ...{
        
try ...{
            Class.forName(
"com.mysql.jdbc.Driver");
            cnn 
= DriverManager.getConnection(
                    
"jdbc:mysql://localhost:3306/jms""root""aastocks");

        }
 catch (Exception e) ...{

        }

    }

}

 

 

java导入导出pdf文档实践

1:MySQL数据库存储pdf流字段为:filed name: filestream   type: MEDIUMBLOB 2:导入pdf文件到mysql 数据库  private v...
  • opshres169
  • opshres169
  • 2016年07月11日 18:44
  • 1163

Java导出PDF文件的实现

Java利用itext实现导出PDF文件 所需要的jar包:com.lowagie.text_2.1.7.v201004222200.jar jar包下载地址:http://cn.jarfire.or...
  • yi2419808933
  • yi2419808933
  • 2016年09月08日 11:11
  • 5216

保存pdf文件至数据库,在线预览并下载到本地

这几天在做将pdf文件转为字节流并保存至数据库,然后再从数据库中中下载下来的工作。所用的东西比较简单,但是也比较琐碎,因为以前没有用过,耽误了点时间,现在整理下来,希望帮助到大家。     上传 ...
  • chengzixiaohai
  • chengzixiaohai
  • 2015年01月15日 16:42
  • 3403

java导入导出pdf文档实践

1:MySQL数据库存储pdf流字段为:filed name: filestream   type: MEDIUMBLOB 2:导入pdf文件到mysql 数据库  private v...
  • opshres169
  • opshres169
  • 2016年07月11日 18:44
  • 1163

java 导入导出pdf

java导入导出pdf文档实践 收藏 1:mysql数据库存储pdf流字段为:filed name: filestream   type: MEDIUMBLOB 2:导入pdf文件到mysql...
  • opshres169
  • opshres169
  • 2016年07月11日 18:41
  • 343

使用Aspose插件对Excel操作 使用使用Aspose插件对Excel文档进行导入导出操作

  • 2017年12月25日 11:43
  • 2.73MB
  • 下载

oracle 导入导出文档

  • 2013年05月30日 16:05
  • 985KB
  • 下载

C#实现客户端数据导入导出源代码及说明文档

  • 2012年09月25日 23:01
  • 369KB
  • 下载

文件文档管理器1.0(支持批量导入导出)

  • 2008年12月07日 22:42
  • 708KB
  • 下载

NPOI导入导出excel文档

  • 2014年03月27日 14:08
  • 5.72MB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:java导入导出pdf文档实践
举报原因:
原因补充:

(最多只允许输入30个字)