Bagikan melalui


ZipArchive Kelas

Definisi

Mewakili paket file terkompresi dalam format arsip zip.

public ref class ZipArchive : IDisposable
public class ZipArchive : IDisposable
type ZipArchive = class
    interface IDisposable
Public Class ZipArchive
Implements IDisposable
Warisan
ZipArchive
Penerapan

Keterangan

Metode untuk memanipulasi arsip zip dan entri filenya tersebar di tiga kelas: ZipFile, , ZipArchivedan ZipArchiveEntry.

Untuk Gunakan
Create arsip zip dari direktori ZipFile.CreateFromDirectory
Mengekstrak konten arsip zip ke direktori ZipFile.ExtractToDirectory
Menambahkan file baru ke arsip zip yang sudah ada ZipArchive.CreateEntry
Mengambil file dari arsip zip ZipArchive.GetEntry
Mengambil semua file dari arsip zip ZipArchive.Entries
Membuka aliran ke satu file yang terkandung dalam arsip zip ZipArchiveEntry.Open
Menghapus file dari arsip zip ZipArchiveEntry.Delete

Saat Anda membuat entri baru, file dikompresi dan ditambahkan ke paket zip. Metode ini CreateEntry memungkinkan Anda menentukan hierarki direktori saat menambahkan entri. Anda menyertakan jalur relatif entri baru dalam paket zip. Misalnya, membuat entri baru dengan jalur AddedFolder\NewFile.txt relatif membuat file teks terkompresi di direktori bernama AddedFolder.

Jika Anda mereferensikan perakitan System.IO.Compression.FileSystem dalam proyek, Anda dapat mengakses empat metode ekstensi (dari ZipFileExtensions kelas) untuk ZipArchive kelas : CreateEntryFromFile(ZipArchive, String, String), , CreateEntryFromFile(ZipArchive, String, String, CompressionLevel)ExtractToDirectory(ZipArchive, String), dan ExtractToDirectory(ZipArchive, String, Boolean) (tersedia dalam .NET Core 2.0 dan versi yang lebih baru). Metode ekstensi ini memungkinkan Anda untuk memadatkan dan mendekompresi konten entri ke file. Rakitan System.IO.Compression.FileSystem tidak tersedia untuk aplikasi Windows 8.x Store. Di aplikasi Windows 8.x Store, Anda dapat mengompresi dan mendekompresi file dengan menggunakan DeflateStream kelas atau GZipStream , atau Anda dapat menggunakan jenis Compressor Windows Runtime dan Decompressor.

Contoh

Contoh pertama menunjukkan cara membuat entri baru dan menulisnya dengan menggunakan aliran.

using System;
using System.IO;
using System.IO.Compression;

namespace ConsoleApplication
{
    class Program
    {
        static void Main(string[] args)
        {
            using (FileStream zipToOpen = new FileStream(@"c:\users\exampleuser\release.zip", FileMode.Open))
            {
                using (ZipArchive archive = new ZipArchive(zipToOpen, ZipArchiveMode.Update))
                {
                    ZipArchiveEntry readmeEntry = archive.CreateEntry("Readme.txt");
                    using (StreamWriter writer = new StreamWriter(readmeEntry.Open()))
                    {
                            writer.WriteLine("Information about this package.");
                            writer.WriteLine("========================");
                    }
                }
            }
        }
    }
}
Imports System.IO
Imports System.IO.Compression

Module Module1

    Sub Main()
        Using zipToOpen As FileStream = New FileStream("c:\users\exampleuser\release.zip", FileMode.Open)
            Using archive As ZipArchive = New ZipArchive(zipToOpen, ZipArchiveMode.Update)
                Dim readmeEntry As ZipArchiveEntry = archive.CreateEntry("Readme.txt")
                Using writer As StreamWriter = New StreamWriter(readmeEntry.Open())
                    writer.WriteLine("Information about this package.")
                    writer.WriteLine("========================")
                End Using
            End Using
        End Using
    End Sub

End Module

Contoh berikut menunjukkan cara membuka arsip zip dan melakukan iterasi melalui kumpulan entri.

using System;
using System.IO;
using System.IO.Compression;

class Program
{
    static void Main(string[] args)
    {
        string zipPath = @".\result.zip";

        Console.WriteLine("Provide path where to extract the zip file:");
        string extractPath = Console.ReadLine();

        // Normalizes the path.
        extractPath = Path.GetFullPath(extractPath);

        // Ensures that the last character on the extraction path
        // is the directory separator char.
        // Without this, a malicious zip file could try to traverse outside of the expected
        // extraction path.
        if (!extractPath.EndsWith(Path.DirectorySeparatorChar.ToString(), StringComparison.Ordinal))
            extractPath += Path.DirectorySeparatorChar;

        using (ZipArchive archive = ZipFile.OpenRead(zipPath))
        {
            foreach (ZipArchiveEntry entry in archive.Entries)
            {
                if (entry.FullName.EndsWith(".txt", StringComparison.OrdinalIgnoreCase))
                {
                    // Gets the full path to ensure that relative segments are removed.
                    string destinationPath = Path.GetFullPath(Path.Combine(extractPath, entry.FullName));

                    // Ordinal match is safest, case-sensitive volumes can be mounted within volumes that
                    // are case-insensitive.
                    if (destinationPath.StartsWith(extractPath, StringComparison.Ordinal))
                        entry.ExtractToFile(destinationPath);
                }
            }
        }
    }
}
Imports System.IO
Imports System.IO.Compression

Module Module1

    Sub Main()
        Dim zipPath As String = ".\result.zip"

        Console.WriteLine("Provide path where to extract the zip file:")
        Dim extractPath As String = Console.ReadLine()

        ' Normalizes the path.
        extractPath = Path.GetFullPath(extractPath)

        ' Ensures that the last character on the extraction path
        ' is the directory separator char. 
        ' Without this, a malicious zip file could try to traverse outside of the expected
        ' extraction path.
        If Not extractPath.EndsWith(Path.DirectorySeparatorChar.ToString(), StringComparison.Ordinal) Then
            extractPath += Path.DirectorySeparatorChar
        End If

        Using archive As ZipArchive = ZipFile.OpenRead(zipPath)
            For Each entry As ZipArchiveEntry In archive.Entries
                If entry.FullName.EndsWith(".txt", StringComparison.OrdinalIgnoreCase) Then

                    ' Gets the full path to ensure that relative segments are removed.
                    Dim destinationPath As String = Path.GetFullPath(Path.Combine(extractPath, entry.FullName))
                    
                    ' Ordinal match is safest, case-sensitive volumes can be mounted within volumes that
                    ' are case-insensitive.
                    If destinationPath.StartsWith(extractPath, StringComparison.Ordinal) Then 
                        entry.ExtractToFile(destinationPath)
                    End If

                End If
            Next
        End Using
    End Sub

End Module

Contoh ketiga menunjukkan cara menggunakan metode ekstensi untuk membuat entri baru dalam arsip zip dari file yang ada dan mengekstrak konten arsip. Anda harus mereferensikan assembly System.IO.Compression.FileSystem untuk menjalankan kode.

using System;
using System.IO;
using System.IO.Compression;

namespace ConsoleApplication
{
    class Program
    {
        static void Main(string[] args)
        {
            string zipPath = @"c:\users\exampleuser\start.zip";
            string extractPath = @"c:\users\exampleuser\extract";
            string newFile = @"c:\users\exampleuser\NewFile.txt";

            using (ZipArchive archive = ZipFile.Open(zipPath, ZipArchiveMode.Update))
            {
                archive.CreateEntryFromFile(newFile, "NewEntry.txt");
                archive.ExtractToDirectory(extractPath);
            }
        }
    }
}
Imports System.IO
Imports System.IO.Compression

Module Module1

    Sub Main()
        Dim zipPath As String = "c:\users\exampleuser\end.zip"
        Dim extractPath As String = "c:\users\exampleuser\extract"
        Dim newFile As String = "c:\users\exampleuser\NewFile.txt"

        Using archive As ZipArchive = ZipFile.Open(zipPath, ZipArchiveMode.Update)
            archive.CreateEntryFromFile(newFile, "NewEntry.txt", CompressionLevel.Fastest)
            archive.ExtractToDirectory(extractPath)
        End Using
    End Sub

End Module

Konstruktor

ZipArchive(Stream)

Menginisialisasi instans ZipArchive baru kelas dari aliran yang ditentukan.

ZipArchive(Stream, ZipArchiveMode)

Menginisialisasi instans ZipArchive baru kelas dari aliran yang ditentukan dan dengan mode yang ditentukan.

ZipArchive(Stream, ZipArchiveMode, Boolean)

Menginisialisasi instans ZipArchive baru kelas pada aliran yang ditentukan untuk mode yang ditentukan, dan secara opsional membiarkan aliran terbuka.

ZipArchive(Stream, ZipArchiveMode, Boolean, Encoding)

Menginisialisasi instans ZipArchive baru kelas pada aliran yang ditentukan untuk mode yang ditentukan, menggunakan pengodean yang ditentukan untuk nama entri, dan secara opsional membiarkan aliran terbuka.

Properti

Comment

Mendapatkan atau mengatur komentar arsip opsional.

Entries

Mendapatkan koleksi entri yang saat ini ada di arsip zip.

Mode

Mendapatkan nilai yang menjelaskan jenis tindakan yang dapat dilakukan arsip zip pada entri.

Metode

CreateEntry(String)

Membuat entri kosong yang memiliki jalur dan nama entri yang ditentukan dalam arsip zip.

CreateEntry(String, CompressionLevel)

Membuat entri kosong yang memiliki nama entri dan tingkat pemadatan yang ditentukan dalam arsip zip.

Dispose()

Merilis sumber daya yang digunakan oleh instans ZipArchive kelas saat ini.

Dispose(Boolean)

Dipanggil oleh Dispose() metode dan Finalize() untuk merilis sumber daya yang tidak dikelola yang digunakan oleh instans ZipArchive kelas saat ini, dan secara opsional selesai menulis arsip dan merilis sumber daya terkelola.

Equals(Object)

Menentukan apakah objek yang ditentukan sama dengan objek saat ini.

(Diperoleh dari Object)
GetEntry(String)

Mengambil pembungkus untuk entri yang ditentukan dalam arsip zip.

GetHashCode()

Berfungsi sebagai fungsi hash default.

(Diperoleh dari Object)
GetType()

Mendapatkan instans Type saat ini.

(Diperoleh dari Object)
MemberwiseClone()

Membuat salinan dangkal dari yang saat ini Object.

(Diperoleh dari Object)
ToString()

Mengembalikan string yang mewakili objek saat ini.

(Diperoleh dari Object)

Metode Ekstensi

CreateEntryFromFile(ZipArchive, String, String)

Mengarsipkan file dengan mengompresinya dan menambahkannya ke arsip zip.

CreateEntryFromFile(ZipArchive, String, String, CompressionLevel)

Mengarsipkan file dengan mengompresinya menggunakan tingkat kompresi yang ditentukan dan menambahkannya ke arsip zip.

ExtractToDirectory(ZipArchive, String)

Mengekstrak semua file dalam arsip zip ke direktori pada sistem file.

ExtractToDirectory(ZipArchive, String, Boolean)

Mengekstrak semua file dalam arsip ke direktori pada sistem file.

Berlaku untuk

Lihat juga