Util for extracting *.jar, *.war and *.zip archives. : Zip Tar File « File Input Output « Java

Home
Java
1.2D Graphics GUI
2.3D
3.Advanced Graphics
4.Ant
5.Apache Common
6.Chart
7.Class
8.Collections Data Structure
9.Data Type
10.Database SQL JDBC
11.Design Pattern
12.Development Class
13.EJB3
14.Email
15.Event
16.File Input Output
17.Game
18.Generics
19.GWT
20.Hibernate
21.I18N
22.J2EE
23.J2ME
24.JDK 6
25.JNDI LDAP
26.JPA
27.JSP
28.JSTL
29.Language Basics
30.Network Protocol
31.PDF RTF
32.Reflection
33.Regular Expressions
34.Scripting
35.Security
36.Servlets
37.Spring
38.Swing Components
39.Swing JFC
40.SWT JFace Eclipse
41.Threads
42.Tiny Application
43.Velocity
44.Web Services SOA
45.XML
Java » File Input Output » Zip Tar FileScreenshots 
Util for extracting *.jar, *.war and *.zip archives.
        
//Copyright 2007-2008 David Yu [email protected]
//------------------------------------------------------------------------
//Licensed under the Apache License, Version 2.0 (the "License");
//you may not use this file except in compliance with the License.
//You may obtain a copy of the License at 
//http://www.apache.org/licenses/LICENSE-2.0
//Unless required by applicable law or agreed to in writing, software
//distributed under the License is distributed on an "AS IS" BASIS,
//WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
//See the License for the specific language governing permissions and
//limitations under the License.

//package com.dyuproject.util;

import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.URI;
import java.net.URL;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.jar.JarEntry;
import java.util.jar.JarInputStream;

/**
 * Util for extracting *.jar, *.war and *.zip archives.
 
 @author David Yu
 * @created Feb 25, 2008
 */

public final class ArchiveUtil
{
    
    /**
     * The suffixes of the files to support.
     */
    public static final String[] SUPPORTED_FILES = new String[]{
        ".zip",
        ".jar",
        ".war"
    };
    
    private static File __tempDir;
    
    static
    {
        __tempDir = new File(System.getProperty("java.io.tmpdir"));
    }
    
    public static void setTempDir(File tempDir)
    {
        if(tempDir.isDirectory() && tempDir.exists())
            __tempDir = tempDir;
    }
    
    /**
     * Gets the temp dir (the sys property "java.io.tmpdir" if not 
     * overridden via {@link #setTempDir(File)}). 
     */
    public static File getTempDir()
    {
        return __tempDir;
    }
    
    /**
     * Returns true if the given {@code resource} is either a zip, jar or war file.
     */
    public static boolean isSupported(String resource)
    {
        int idx = resource.lastIndexOf('.');
        if(resource.length()==idx+4)
        {         
            for(int i=0; i<SUPPORTED_FILES.length; i++)
            {
                if(resource.endsWith(SUPPORTED_FILES[i]))
                    return true;
            }
        }
        return false;           
    }
    
    public static boolean extract(File archive, File targetDirthrows IOException
    {
        return extract(archive.toURI().toURL(), targetDir, true);
    }
    
    public static boolean extract(File archive, File targetDir, boolean deleteOnExitthrows IOException
    {
        return extract(archive.toURI().toURL(), targetDir, deleteOnExit);
    }
    
    public static boolean extract(URL archive, File targetDirthrows IOException
    {
        return extract(archive, targetDir, true);
    }
    
    /**
     * Extracts the file {@code archive} to the target dir {@code targetDir} and deletes the 
     * files extracted upon jvm exit if the flag {@code deleteOnExit} is true.
     */
    public static boolean extract(URL archive, File targetDir, boolean deleteOnExitthrows IOException
    {
        String archiveStr = archive.toString();
        String jarEntry = null;        
        int idx = archiveStr.indexOf("!/");
        if(idx!=-1)
        {
            if(!archiveStr.startsWith("jar:"&& archiveStr.length()==idx+2)
                return false;
            archive = new URL(archiveStr.substring(4, idx));
            jarEntry = archiveStr.substring(idx+2);            
        }
        else if(!isSupported(archiveStr))
            return false;          
           
        JarInputStream jis = new JarInputStream(archive.openConnection().getInputStream());        
        if(!targetDir.exists())
            targetDir.mkdirs()
        JarEntry entry = null;
        while((entry=jis.getNextJarEntry())!=null)
        {
            String entryName = entry.getName();            
            File entryFile = new File(targetDir, entryName);
            if(!entry.isDirectory())
            {
                if(jarEntry==null || entryName.startsWith(jarEntry))
                {
                    if(!entryFile.exists() || entryFile.lastModified()!=entry.getTime())
                        extractEntry(entryFile, jis, entry, deleteOnExit);                    
                }
            }
        }
        try{jis.close();}catch(Exception e){}
        return true;
    }
    
    private static void extractEntry(File entryFile, JarInputStream jis, JarEntry entry, 
            boolean deleteOnExitthrows IOException
    {            
        File parent = new File(entryFile.getParent());
        if(!parent.exists())
            parent.mkdirs();                
        ResourceUtil.copy(jis, new FileOutputStream(entryFile));     
        entryFile.setLastModified(entry.getTime());
        if(deleteOnExit)
        {
            parent.deleteOnExit();
            entryFile.deleteOnExit();
        }
    }
    
}

/**
 * Util for files and streams.
 
 @author David Yu
 */

 final class ResourceUtil
{
    
    static int __copyBufferSize = 4096;
    
    /**
     * Sets the buffer size to use when copying data from streams.
     */
    public static void setCopyBufferSize(int size)
    {
        __copyBufferSize = size;
    }
    
    /**
     * Gets the buffer size to use when copying data from streams.
     */
    public static int getCopyBufferSize()
    {
        return __copyBufferSize;
    }    

    /**
     * Reads the contents of the file into a byte array.
     */
    public static byte[] readBytes(File filethrows IOException 
    {
        return readBytes(file.toURI());
    }
    
    /**
     * Reads the contents of the given file into a byte array.
     */
    public static byte[] readBytes(String filethrows IOException 
    {
        return readBytes(URI.create(file));
    }
    
    /**
     * Reads the contents of the given file into a byte array.
     */
    public static byte[] readBytes(URI filethrows IOException 
    {
        return readBytes(file.toURL());
    }
    
    /**
     * Reads the contents of the given file into a byte array.
     */
    public static byte[] readBytes(URL filethrows IOException 
    {       
        return readBytes(file.openStream());
    }
    
    /**
     * Reads the contents of the given input stream into a byte array.
     */
    public static byte[] readBytes(InputStream inthrows IOException 
    {
        return getByteArrayOutputStream(in).toByteArray();
    }
    
    /**
     * Gets the ByteArrayOutputStream that was filled when reading from the 
     * given input stream {@code in}.
     */
    public static ByteArrayOutputStream getByteArrayOutputStream(InputStream inthrows IOException 
    {
        ByteArrayOutputStream out = new ByteArrayOutputStream();
        byte[] buffer = new byte[__copyBufferSize];
        int length = 0;
        while((length=in.read(buffer, 0, __copyBufferSize)) != -1
            out.write(buffer, 0, length);           
        try{in.close();}catch(Exception e){}
        return out;
    }
    
    /**
     * Copies the contents of the  input url to the output url.
     */
    public static void copy(URL in, URL outthrows IOException
    {
        copy(in.openStream(), out.openConnection().getOutputStream());
    }
    
    /**
     * Copies the contents of the  input file to the output file.
     */
    public static void copy(File in, File outthrows IOException
    {
        copy(new FileInputStream(in)new FileOutputStream(out));
    }
    
    /**
     * Copies the contents of the input url to the output file.
     */
    public static void copy(URL in, File outthrows IOException
    {
        copy(in.openStream()new FileOutputStream(out));
    }
    
    /**
     * Copies the contents of the input stream to the output stream.
     */
    public static void copy(InputStream in, OutputStream outthrows IOException 
    {
        byte[] buffer = new byte[__copyBufferSize];
        int length = 0;
        while((length=in.read(buffer, 0, __copyBufferSize)) != -1
            out.write(buffer, 0, length);        
        try{out.close();}catch(Exception e){}     
    }
    
    /**
     * Copies the contents of the input stream to the output stream with the specified 
     * buffer size to use for copying.
     */
    public static void copy(InputStream in, OutputStream out, int bufferSizethrows IOException 
    {
        byte[] buffer = new byte[bufferSize];
        int length = 0;
        while((length=in.read(buffer, 0, bufferSize)) != -1
            out.write(buffer, 0, length);        
        try{out.close();}catch(Exception e){}     
    }
    
    static void copyDir(File dirFrom, File dirTothrows IOException
    {
        File[] files = dirFrom.listFiles();
        if(!dirTo.exists())
            dirTo.mkdirs();
        for(int i=0; i<files.length; i++)
        {
            File f = files[i];
            if(f.isDirectory())                                            
                copyDir(f, new File(dirTo, f.getName()));                
            else                
                copy(f, new File(dirTo, f.getName()));                                    
        }
    }
    
    /**
     * Copies the given {@code file} to the given dir.
     */
    public static void copyFileToDir(File file, File dirTothrows IOException
    {
        if(file.exists())
        {
            if(file.isDirectory())            
                copyDir(file, dirTo);            
            else
            {
                if(!dirTo.exists())
                    dirTo.mkdirs();
                copy(file, new File(dirTo, file.getName()));
            }
        }            
    }
    
    /**
     * Returns a list of file filtered by their file types/extensions; (E.g ".zip")
     */
    public static List<File> getFilesByExtension(File dir, String[] extensions)
    {
        if(!dir.isDirectory() || extensions==null)
            return Collections.emptyList();
        List<File> files = new ArrayList<File>();
        addFilesByExtension(files, dir, extensions);
        return files;
    }
    
    static void addFilesByExtension(List<File> list, File dir, String[] extensions)
    {
        File[] files = dir.listFiles();
        for(int i=0; i<files.length; i++)
        {
            File f = files[i];
            if(f.isDirectory())
                addFilesByExtension(list, f, extensions);
            else
            {
                for(String s : extensions)
                {
                    if(f.getName().endsWith(s))
                    {
                        list.add(f);
                        break;
                    }
                }
            }
        }
    }

}

   
    
    
    
    
    
    
    
  
Related examples in the same category
1.Extract contents of a zip file
2.List the contents of a zip file
3.Read entries in a zip / compressed file
4.Decompress a zip file using ZipInputStream
5.Decompress a zip file using ZipFile
6.Create checksum for a zip file
7.Read a zip file checksum value
8.Create a zip file with java.util.zip package
9.Extract file/files from a zip file
10.Read files within a zip file
11.Retrieve a compressed file from a ZIP file
12.Retrieve the contents of a ZIP file
13.Making a zip file of directory including its subdirectories recursively
14.Displaying contents of a compressed zip file
15.Compress a Byte Array
16.Decompress a Byte Array
17.Read zip file
18.Write Zip file
19.The java.util.zip package can be used to create a checksum.
20.Read the content of a zip file ZipFile
21.List the entries of a zip file
22.Compressing Streams: Zipper, Java example
23.Compressing Streams: Parity Checksum
24.Compressing Streams: File Summer
25.Create a simple ZIP File: not retain any directory path information about the files.
26.Decompress a ZIP file.
27.Decompressing a Byte Array
28.Zip unzip byte array
29.Creating a ZIP File
30.Listing the Contents of a ZIP File
31.Retrieving a Compressed File from a ZIP File
32.Calculating the Checksum of a Byte Array (Compute Adler-32 checksum)
33.Compute CRC-32 checksum
34.Calculating the Checksum of a File
35.Compress string(byte array) by Deflater
36.Use Java code to zip a folder
37.Uses Zip compression to compress any number of files given on the command line
38.Load zip file and scan zip file
39.Reading the Contents of a ZIP File
40.UnZip -- print or unzip a JAR or PKZIP file using java.util.zip
41.Tape Archive Lister: Tar file
42.Compressing a Byte Array
43.Tar file stream
44.Tar file and untar file
45.bzip source code
46.Unpack an archive from a URL
47.Compare two zip files
48.Determine whether a file is a ZIP File.
49.Zip up a directory
50.Check sum for a path
51.Check sum for an InputStream
52.Extract zip file to destination folder
53.Return the first directory of this archive. This is needed to determine the plugin directory
54.Makes a zip file named xmlFileName from xmlURL at path
55.Unzipps a zip file placed at zipURL to path
56.A single checksum calculation for multiple files
57.Put file To Zip File
58.Provides both writing and reading from a file which is transparently compressed in Zip
59.TarInputStream reads a UNIX tar archive as an InputStream
60.TarOutputStream writes a UNIX tar archive as an OutputStream
61.Package files utility
62.Zip Compare
63.Unpack a segment from a zip
64.Unpack a zip file
65.Unzip file to a directory
66.Zip a list of file into one zip file.
67.Validate that an archive contains a named entry
68.A frame with a text area to show the contents of a file inside a ZIP archive
69.Compress object and decompress
java2s.com  | Contact Us | Privacy Policy
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.