Вход Регистрация
Файл: PROFIWM.COM/modules/zc/zip.php
Строк: 148
<?php

require '../../system/core.php';
include 
'../../system/header.php';
include 
'pclzip.lib.php';

function 
err($var){
if(!empty(
$var)){
echo 
'<div class="post1">'.$var.'</div>';
}
}

$onpage 10;
$id abs(intval($_GET['id']));
$page abs(intval($_GET['page']));
$start abs(intval($_GET['start']));

$action = (isset($_GET['action']) && $_GET['action'] == 'preview') ? TextGuard($_GET['action']) : NULL;
$d mysql_fetch_assoc(mysql_query('SELECT * FROM `zc_f` WHERE `id` = ' $id));

if (!
file_exists($d['url']))
{
    
err('Файл не найден!');
include 
'../../system/footer.php';
    exit();
}

###############Получаем каталог#############
$path TextGuard($_SERVER['DOCUMENT_ROOT']).'/modules/zc/files/'.$d['file'];
$filename pathinfo($path);
$ext strtolower($filename['extension']);
if (
$ext != 'zip') die('Файл не является ZIP архивом');
$dir $filename['dirname'] . '/';
$back mysql_fetch_assoc(mysql_query("SELECT * FROM `zc_f` WHERE `file` = '$dir'"));
###############Заголовок###################
#echo 'Просмотр архива ' . basename($d['url']) . '<br/>';
###############Содержимое###################
if (!$action)
{
    
$zip = new PclZip($d['url']);
    if (!
$list $zip->listContent()) die('Ошибка: '.$zip->errorInfo(true));
for(
$i 0$i sizeof($list); ++$i)
{
for(
reset($list[$i]); $key key($list[$i]); next($list[$i]))
{
    
$zfilesize strstr($listcontent'--size');
    
$zfilesize str_replace('--size:'''$zfilesize);
    
$zfilesize str_replace($zfilesize$zfilesize '|'$zfilesize);
    
$sizelist .= $zfilesize;
    
$listcontent "[$i]--$key:" $list[$i][$key];
    
$zfile strstr($listcontent'--filename');
    
$zfile str_replace('--filename:'''$zfile);
    
$zfile str_replace($zfile$zfile '|'$zfile);
    
$savelist .= $zfile;
}
}
$sizefiles2 explode('|'$sizelist);

$sizelist2 array_sum($sizefiles2);
$obkb round($sizelist2 10242);
$preview $savelist;

$preview explode('|'$preview);

$count count($preview) - 1;
echo 
'<div class="post2">Всего файлов: ' $count '<br/>Вес распакованного архива: ' $obkb ' kb</div>';
if (!isset(
$page)) $page 1;
$n 0;
$pages ceil($count $onpage);
if (!
$pages$pages 1;
if (
$page$n = ($onpage $page) - $onpage;
if (
$count == 0) echo 'Пусто...';
$sizefiles explode('|'$sizelist);
$selectfile explode('|'$savelist);
//------------------------------------------------------------------------------------------
for ($i 1$i <= $onpage; ++$i)
{
if (empty(
$selectfile[$n]))
{
    
$n++;
    continue;
}

$path $selectfile[$n];
$fname preg_replace('/.*[/]/'''$path);
#$zdir = preg_replace('/[/]?[^/]*$/', '', $path);

echo '<div class="post2">';
echo 
'<a href="/modules/zc/zip.php?action=preview&amp;id='.$id.'&amp;open='.$path.'">' $fname '</a>';
if (
$sizefiles[$n] != 0) echo ' [' round($sizefiles[$n] / 10242) . 'kb]';
echo 
'</div>';
    
$n++;
}


//------------------------------------------------------------------------------------------
echo '<br/>Страницы: ';
$asd $page 2;
$asd2 $page 3;

if (
$asd $count && $asd && $page 3) echo '<a href="zip.php?id='.$id.'&amp;page=1">1</a> ... ';

for(
$i $asd$i $asd2$i++)
{
if (
$i $count && $i 0)
{
if (
$i $pages) break;
if (
$page == $i) echo '<b>[' $i ']</b> ';
else echo 
'<a href="zip.php?id='.$id.'&amp;page='.$i.'">' $i '</a> ';
}
}
if (
$i <= $pages)
{
if (
$asd2 $count) echo ' ... <a href="zip.php?id='.$id.'&amp;page='.$pages.'">' $pages '</a>';
}
echo 
'<br/>';
}
###############Просмотр файла###################
if ($action == 'preview')
{
$open TextGuard($_GET['open']);
if (
strpos($open '..') !== false or strpos($open './') !== false)
{
    
err('В хакера решил поиграть?');
include 
'../../system/footer.php';
    exit();
}

$zip = new PclZip($d['url']);
$content $zip->extract(PCLZIP_OPT_BY_NAME$openPCLZIP_OPT_EXTRACT_AS_STRING);
$content $content[0]['content'];
$preview2 explode("n"$content);
$count count($preview2);

echo 
'<b>Файл: ' $open '</b><br/>';

$eX strtolower(strrchr($open'.'));

$php = array('.php''.pl''.js''.jsp''.html''.xhtml''.xml''.wml''.asp''.aspx');
$txt = array('.txt''.sql''.dat''.css''.ini''.function''.htaccess''.tpl');
$img = array('.gif''.jpg''.jpeg''.png''.bmp''.wbmp''.ico''.swf');

if (empty(
$content)) echo 'Файл пуст.<br/>';

if (isset(
$_GET['img']))
{
$ext strtolower(substr($openstrrpos($open'.') + 1));

ob_end_clean();
ob_clean();

header("Content-type: image/$ext");
header("Content-Length: " strlen($content));
header('Content-Disposition: inline; filename="' $open '"');

echo 
$content;
exit();
}

if (
in_array($eX$php))
{
    echo  (!empty(
$content) ? 'Строк: ' $count '<br/>' '');
if (
is_utf($content)) echo $content;
else echo 
$content;
}
elseif (
in_array($eX$txt))
{
$content htmlspecialchars($content);
echo  (!empty(
$content) ? 'Строк: ' $count '<br/>' '');
if (
is_utf($content)) echo '<div style="background:#dedede; color:#727272; overflow: auto;"><code>' wordwrap($content75'<br/>') . '</code></div>';
else echo 
'<div style="background:#dedede; color:#727272; overflow: auto;"><code>' wordwrap($content75'<br/>') . '</code></div>';
}
elseif (
in_array($eX$img))
{
    echo 
'<img src="?action=preview&amp;id='.$id.'&amp;open='.$open.'&amp;img" alt=""/><br/>';
}
else
{
    echo 
'Невозможно прочесть файл!<br/>';
}

}
echo 
'<br/>&laquo; <a href="info-'.$id.'">К файлу</a>';
if (isset(
$_GET['action'])) echo '<br/>&laquo; <a href="/modules/zc/zip.php?id='.$id.'">К просмотру архива</a>';
include 
'../../system/footer.php';
?>
Онлайн: 2
Реклама