将PDF格式文件转成二进制并生成Base64编码,将Base64编码转成PDF文件

时间:2022-11-13 00:24:40
// 为工程添加 sun.misc.BASE64Encoder和sun.misc.BASE64Decoder包:  
//右键项目》属性》Java Build Path》jre System Library 》access rules》resolution选择accessible,下面填上**点击确定即可!  
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.ByteArrayInputStream;    
import java.io.ByteArrayOutputStream;    
import java.io.File;    
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;    

import org.apache.commons.codec.binary.Base64;

import sun.misc.BASE64Decoder;    
import sun.misc.BASE64Encoder;    
    
public class TestPDFBinary {    
	/*BASE64Encoder和BASE64Decoder这两个方法是sun公司的内部方法,并没有在java api中公开过,所以使用这些方法是不安全的,
	 * 将来随时可能会从中去除,所以相应的应该使用替代的对象及方法,建议使用apache公司的API*/
    static BASE64Encoder encoder = new sun.misc.BASE64Encoder();    
    static BASE64Decoder decoder = new sun.misc.BASE64Decoder();    
        
    public static void main(String[] args) {    
         //将PDF格式文件转成base64编码 
    	 String base64String = getPDFBinary(new File("/home/amarsoft/AFm.pdf"));
    	 System.out.println(base64String);
    	//将base64的编码转成PDF格式文件
    	base64StringToPDF(base64String);
    }    
        
    /**
     *  将PDF转换成base64编码
     *  1.使用BufferedInputStream和FileInputStream从File指定的文件中读取内容;
     *  2.然后建立写入到ByteArrayOutputStream底层输出流对象的缓冲输出流BufferedOutputStream
     *  3.底层输出流转换成字节数组,然后由BASE64Encoder的对象对流进行编码
     * */
    static String getPDFBinary(File file) {
    	FileInputStream fin =null;
    	BufferedInputStream bin =null;
    	ByteArrayOutputStream baos = null;
    	BufferedOutputStream bout =null;
    	try {
    		//建立读取文件的文件输出流
    		fin = new FileInputStream(file);
    		//在文件输出流上安装节点流(更大效率读取)
    		bin = new BufferedInputStream(fin);
    		// 创建一个新的 byte 数组输出流,它具有指定大小的缓冲区容量
    		baos = new ByteArrayOutputStream();
    		//创建一个新的缓冲输出流,以将数据写入指定的底层输出流
    		bout = new BufferedOutputStream(baos);
    		byte[] buffer = new byte[1024];
    		int len = bin.read(buffer);
    		while(len != -1){
    			bout.write(buffer, 0, len);
    			len = bin.read(buffer);
    		}
    		//刷新此输出流并强制写出所有缓冲的输出字节,必须这行代码,否则有可能有问题
    		bout.flush();
    		 byte[] bytes = baos.toByteArray();
    		 //sun公司的API
    		 return encoder.encodeBuffer(bytes).trim();  
    		 //apache公司的API
    		 //return Base64.encodeBase64String(bytes);
    		
		} catch (FileNotFoundException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		}finally{
			try {
				fin.close();
				bin.close();
				//关闭 ByteArrayOutputStream 无效。此类中的方法在关闭此流后仍可被调用,而不会产生任何 IOException
				//baos.close();
				bout.close();
			} catch (IOException e) {
				e.printStackTrace();
			}
		}
    	return null;
    }
        
    /**
     * 将base64编码转换成PDF
     * @param base64sString
     * 1.使用BASE64Decoder对编码的字符串解码成字节数组
     *  2.使用底层输入流ByteArrayInputStream对象从字节数组中获取数据;
     *  3.建立从底层输入流中读取数据的BufferedInputStream缓冲输出流对象;
     *  4.使用BufferedOutputStream和FileOutputSteam输出数据到指定的文件中
     */
    static void base64StringToPDF(String base64sString){
    	BufferedInputStream bin = null;
    	FileOutputStream fout = null;
    	BufferedOutputStream bout = null;
    	try {
    		 //将base64编码的字符串解码成字节数组
			byte[] bytes = decoder.decodeBuffer(base64sString);
    		//apache公司的API
    		//byte[] bytes = Base64.decodeBase64(base64sString);
			//创建一个将bytes作为其缓冲区的ByteArrayInputStream对象
			ByteArrayInputStream bais = new ByteArrayInputStream(bytes);
			//创建从底层输入流中读取数据的缓冲输入流对象
			bin = new BufferedInputStream(bais);
			//指定输出的文件
			File file = new File("/home/amarsoft/test.pdf");
			//创建到指定文件的输出流
			fout  = new FileOutputStream(file);
			//为文件输出流对接缓冲输出流对象
			bout = new BufferedOutputStream(fout);
			
			byte[] buffers = new byte[1024];
			int len = bin.read(buffers);
			while(len != -1){
				bout.write(buffers, 0, len);
				len = bin.read(buffers);
			}
			//刷新此输出流并强制写出所有缓冲的输出字节,必须这行代码,否则有可能有问题
			bout.flush();
			
		} catch (IOException e) {
			e.printStackTrace();
		}finally{
			try {
				bin.close();
				fout.close();
				bout.close();
			} catch (IOException e) {
				e.printStackTrace();
			}
		}
    }
}