ZipFileExtensions Classe
Definição
Importante
Algumas informações dizem respeito a um produto pré-lançado que pode ser substancialmente modificado antes de ser lançado. A Microsoft não faz garantias, de forma expressa ou implícita, em relação à informação aqui apresentada.
Fornece métodos de extensão para as ZipArchive classes e ZipArchiveEntry .
public ref class ZipFileExtensions abstract sealed
public static class ZipFileExtensions
type ZipFileExtensions = class
Public Module ZipFileExtensions
- Herança
-
ZipFileExtensions
Exemplos
O exemplo seguinte mostra como criar uma nova entrada num arquivo zip a partir de um ficheiro existente e extrair o conteúdo do arquivo para um diretório.
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
O exemplo seguinte mostra como iterar pelo conteúdo de um arquivo zip e extrair ficheiros que tenham uma extensão .txt.
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
Observações
A ZipFileExtensions classe contém apenas métodos estáticos que estendem as ZipArchive classes e ZipArchiveEntry . Não se cria uma instância da ZipFileExtensions classe; em vez disso, utiliza-se estes métodos a partir de instâncias de ZipArchive ou ZipArchiveEntry.
Para usar os métodos de extensão, deve referenciar a System.IO.Compression.FileSystem montagem no seu projeto. A montagem System.IO.Compression.FileSystem não está disponível nas aplicações da Windows 8.x Store. Portanto, as classes ZipFileExtensions e ZipFile (ambas no assembly System.IO.Compression.FileSystem) não estão disponíveis nas aplicações da Windows 8.x Store. Nas aplicações Windows 8.x Store, trabalhas com ficheiros comprimidos usando os métodos em ZipArchive, ZipArchiveEntry, DeflateStream e GZipStream.
A ZipFileExtensions classe contém quatro métodos que se estendem ZipArchive:
- CreateEntryFromFile(ZipArchive, String, String)
- CreateEntryFromFile(ZipArchive, String, String, CompressionLevel)
- ExtractToDirectory(ZipArchive, String)
- ExtractToDirectory(ZipArchive, String, Boolean)
A ZipFileExtensions classe contém dois métodos que se estendem ZipArchiveEntry:
Métodos
| Name | Description |
|---|---|
| CreateEntryFromFile(ZipArchive, String, String, CompressionLevel) |
Arquiva um ficheiro comprimindo-o usando o nível de compressão especificado e adicionando-o ao arquivo zip. |
| CreateEntryFromFile(ZipArchive, String, String) |
Arquiva um ficheiro comprimindo-o e adicionando-o ao arquivo zip. |
| ExtractToDirectory(ZipArchive, String, Boolean) |
Extrai todos os ficheiros do arquivo para um diretório no sistema de ficheiros. |
| ExtractToDirectory(ZipArchive, String) |
Extrai todos os ficheiros do arquivo zip para um diretório no sistema de ficheiros. |
| ExtractToFile(ZipArchiveEntry, String, Boolean) |
Extrai uma entrada no arquivo zip para um ficheiro e, opcionalmente, sobrescrive um ficheiro existente com o mesmo nome. |
| ExtractToFile(ZipArchiveEntry, String) |
Extrai uma entrada do arquivo zip para um ficheiro. |