java导入导出pdf文档实践

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) {

        }

    }

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值