2009-06-29 3 views
1

Ich habe ein PHP-Skript, das meine Tabelle im .SQL-Format sichern und ich möchte die Datei im Gzip-Format mit PHP speichern. Wie kann ich das machen.GZIP-Komprimierung in PHP

Antwort

5

Sie auch a filter verwenden können. Aus der Handbuchseite:

<?php 
$params = array('level' => 6, 'window' => 15, 'memory' => 9); 

$original_text = "You SQL queries here..."; 

$fp = fopen('yourfile.sql.gz', 'w'); 
stream_filter_append($fp, 'zlib.deflate', STREAM_FILTER_WRITE, $params); 
fwrite($fp, $original_text); 
fclose($fp); 
?> 
2

Verwenden Sie die Zlib-Funktionen.

Lesen Sie die documentation für Details

Ein Beispiel direkt aus der gelinkten Seite genommen:

<?php 

$filename = tempnam('/tmp', 'zlibtest') . '.gz'; 
$s = "Only a test, test, test, test, test, test, test, test!\n"; 

/***** WRITING THE FILE *****/ 
// open file for writing with maximum compression 
$zp = gzopen($filename, "w9"); 

// write string to file 
gzwrite($zp, $s); 

// close file 
gzclose($zp); 

/***** READING IT *****/ 
// open file for reading 
$zp = gzopen($filename, "r"); 

// read 3 char 
echo gzread($zp, 3); 

// output until end of the file and close it. 
gzpassthru($zp); 
gzclose($zp); 


/***** ANOTHER WAY TO READ (and print) IT *****/ 
// open file and print content (the 2nd time). 
if (readgzfile($filename) != strlen($s)) { 
     echo "Error with zlib functions!"; 
} 
?> 

Hoffnung, das hilft.

2

Hier ist eine andere Lösung, die im Grunde Carlos Lima Idee aufgreift:

<?php 
    ob_start(); /* start buffering */ 
    echo "your cvs or sql output!";  
    $content = ob_get_contents(); /* get the buffer */ 
    ob_end_clean(); 
    $content = gzencode($content, 9);  
    header("Content-Type: application/force-download"); 
    header("Content-Type: application/octet-stream"); 
    header("Content-Type: application/download"); 
    header("Content-Description: Download SQL Export"); 
    header('Content-Disposition: attachment; filename=test.txt.gz'); 
    echo $content; 
    die(); 
?>