PHPKonf 2020 Online

ZipArchive::setEncryptionName

(PHP >= 7.2.0, PECL zip >= 1.14.0)

ZipArchive::setEncryptionNameSet the encryption method of an entry defined by its name

Descrição

public ZipArchive::setEncryptionName ( string $name , int $method [, string $password ] ) : bool

Set the encryption method of an entry defined by its name.

Parâmetros

name

Name of the entry.

method

The encryption method defined by one of the ZipArchive::EM_ constants.

password

Optional password, default used when missing.

Valor Retornado

Retorna TRUE em caso de sucesso ou FALSE em caso de falha.

Exemplos

This example creates a ZIP file archive test.zip and add the file test.txt encrypted using the AES 256 method.

Exemplo #1 Archive and encrypt a file

<?php
$zip 
= new ZipArchive();
if (
$zip->open('test.zip'ZipArchive::CREATE) === TRUE) {
    
$zip->setPassword('secret');
    
$zip->addFile('text.txt');
    
$zip->setEncryptionName('text.txt'ZipArchive::EM_AES_256);
    
$zip->close();
    echo 
"Ok\n";
} else {
    echo 
"KO\n";
}
?>

Notas

Nota:

This function is only available if built against libzip ≥ 1.2.0.

Veja Também

add a note add a note

User Contributed Notes 1 note

up
1
mauro dot chojrin at leewayweb dot com
3 months ago
Files compressed using this function on Linux won't be decompressed using Windows.

There seems to be some incompatibility with Windows built-in decompressor.

There's an alternative library that works better here: https://github.com/Ne-Lexa/php-zip

I got windows to open a file created with it by using the PKWARE encryption method
To Top