ZipFile.OpenRead(String) ZipFile.OpenRead(String) ZipFile.OpenRead(String) ZipFile.OpenRead(String) Method

Définition

Ouvre une archive ZIP pour la lecture au chemin d'accès spécifié.Opens a zip archive for reading at the specified path.

public:
 static System::IO::Compression::ZipArchive ^ OpenRead(System::String ^ archiveFileName);
public static System.IO.Compression.ZipArchive OpenRead (string archiveFileName);
static member OpenRead : string -> System.IO.Compression.ZipArchive
Public Shared Function OpenRead (archiveFileName As String) As ZipArchive

Paramètres

archiveFileName
String String String String

Chemin d'accès à l'archive à ouvrir, spécifié sous forme de chemin d'accès relatif ou absolu.The path to the archive to open, specified as a relative or absolute path. Un chemin d'accès relatif est interprété comme étant relatif au répertoire de travail actif.A relative path is interpreted as relative to the current working directory.

Retours

Archive ZIP ouverte.The opened zip archive.

Exceptions

archiveFileName est Empty, ne contient qu'un espace blanc ou contient au moins un caractère non valide.archiveFileName is Empty, contains only white space, or contains at least one invalid character.

archiveFileName a la valeur null.archiveFileName is null.

Dans archiveFileName, le chemin d’accès spécifié, le nom de fichier spécifié ou les deux dépassent la longueur maximale définie par le système.In archiveFileName, the specified path, file name, or both exceed the system-defined maximum length.

archiveFileName n’est pas valide ou n’existe pas (par exemple, il se trouve sur un lecteur non mappé).archiveFileName is invalid or does not exist (for example, it is on an unmapped drive).

archiveFileName n’a pas pu être ouvert.archiveFileName could not be opened.

archiveFileName spécifie un répertoire.archiveFileName specifies a directory.

- ou --or- L’appelant n’a pas l’autorisation requise pour accéder au fichier spécifié dans archiveFileName.The caller does not have the required permission to access the file specified in archiveFileName.

Le fichier spécifié dans archiveFileName est introuvable.The file specified in archiveFileName is not found.

archiveFileName contient un format non valide.archiveFileName contains an invalid format.

archiveFileName n’a pas pu être interprété comme une archive ZIP.archiveFileName could not be interpreted as a zip archive.

Exemples

L’exemple suivant montre comment ouvrir une archive zip pour la lecture.The following example shows how to open a zip archive for reading.

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

Remarques

Cette méthode est équivalente à l' Open appel de la méthode mode et à Readl’affectation de la valeur au paramètre.This method is equivalent to calling the Open method and setting the mode parameter to Read. L’archive est ouverte avec FileMode.Open comme valeur de mode de fichier.The archive is opened with FileMode.Open as the file mode value. Si l’archive n’existe pas, une FileNotFoundException exception est levée.If the archive does not exist, a FileNotFoundException exception is thrown.

S’applique à