<?php
require_once('../classes/body.class.php');
require_once('../classes/db.class.php');
require_once('../classes/system.class.php');
$title= new Body;
$title->SetTitle('Загруз-центр - Просмотр архива');
$title->GetHeader();
error_reporting(0);
echo'<div class="tile"><div class="t-header th-alt bg-teal"><div class="th-title"><i class="zmdi zmdi-widgets"></i><a href="/"style="text-decoration:none; color:white;"> Главная</a> :: <a href="/downs"style="text-decoration:none; color:white;"> Загрузки</a> :: Просмотр архива</div></div></div>';
require_once('lib/pclzip.lib.php');
/* не трогать функции */
function win_to_utf($str){
if(function_exists('mb_convert_encoding')) return mb_convert_encoding($str, 'utf-8', 'windows-1251');
if (function_exists('iconv')) return iconv('windows-1251', 'utf-8', $str);
$win1251utf8 = [
"xC0"=>"А","xC1"=>"Б","xC2"=>"В","xC3"=>"Г","xC4"=>"Д","xC5"=>"Е","xA8"=>"Ё","xC6"=>"Ж","xC7"=>"З","xC8"=>"И","xC9"=>"Й","xCA"=>"К","xCB"=>"Л","xCC"=>"М",
"xCD"=>"Н","xCE"=>"О","xCF"=>"П","xD0"=>"Р","xD1"=>"С","xD2"=>"Т","xD3"=>"У","xD4"=>"Ф","xD5"=>"Х","xD6"=>"Ц","xD7"=>"Ч","xD8"=>"Ш","xD9"=>"Щ","xDA"=>"Ъ",
"xDB"=>"Ы","xDC"=>"Ь","xDD"=>"Э","xDE"=>"Ю","xDF"=>"Я","xE0"=>"а","xE1"=>"б","xE2"=>"в","xE3"=>"г","xE4"=>"д","xE5"=>"е","xB8"=>"ё","xE6"=>"ж","xE7"=>"з",
"xE8"=>"и","xE9"=>"й","xEA"=>"к","xEB"=>"л","xEC"=>"м","xED"=>"н","xEE"=>"о","xEF"=>"п","xF0"=>"р","xF1"=>"с","xF2"=>"т","xF3"=>"у","xF4"=>"ф","xF5"=>"х",
"xF6"=>"ц","xF7"=>"ч","xF8"=>"ш","xF9"=>"щ","xFA"=>"ъ","xFB"=>"ы","xFC"=>"ь","xFD"=>"э","xFE"=>"ю","xFF"=>"я"];
return strtr($str, $win1251utf8);
}
function is_utf($str)
{
$c = 0;
$b = 0;
$bits = 0;
$len = strlen($str);
for($i = 0; $i < $len; $i++)
{
$c = ord($str[$i]);
if($c > 128) {
if (($c >= 254)) return false;
elseif ($c >= 252) $bits = 6;
elseif ($c >= 248) $bits = 5;
elseif ($c >= 240) $bits = 4;
elseif ($c >= 224) $bits = 3;
elseif ($c >= 192) $bits = 2;
else return false;
if (($i + $bits) > $len) return false;
while ($bits > 1) {
$i++;
$b = ord($str[$i]);
if ($b < 128 || $b > 191) return false;
$bits--;
}
}
}
return true;
}
/* Подсвечиваем код */
function hightlight($code) {
$code = stripslashes($code);
if(!strpos($code,"<?") && substr($code,0,2)!="<?"){
$code="<?php
".trim($code)."
?>";}
$code = trim($code);
$code=highlight_string($code,true);
return '<div class="citat">'.$code.'</div>';
}
//---------------//
$onpage = 10;
$id = abs(intval($_GET['id']));
$page = abs(intval($_GET['page']));
$start = abs(intval($_GET['start']));
$act = (isset($_GET['act']) && $_GET['act'] == 'preview') ? htmlspecialchars($_GET['act']) : NULL;
$d = DB::$dbs->queryFetch("SELECT * FROM `downs` WHERE `id` = ?",[$id]);
$di = $_SERVER['DOCUMENT_ROOT'].'/'.$d['url'];
if (!file_exists($di)) {
header('location:/');
exit();
}
/* Получаем каталог */
$filename = pathinfo($di);
$ext = strtolower($filename['extension']);
if ($ext != 'zip') die('Файл не является ZIP архивом');
$dir = $filename['dirname'] . '/';
$back = DB::$dbs->queryFetch("SELECT * FROM `downs` WHERE `url` = ?",[$dir]);
/* Содержимоe */
if (!$act){
$zip = new PclZip($di);
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 / 1024, 2);
$preview = $savelist;
$preview = explode('|', $preview);
$count = count($preview) - 1;
echo'<div class="list-group-item media">Всего файлов: ' .$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);
$open = htmlspecialchars($_GET['open']);
for ($i = 1; $i <= $onpage; ++$i)
{
if (empty($selectfile[$n]))
{
$n++;
continue;
}
$path = $selectfile[$n];
$fname = $path;
#$zdir = preg_replace('/[/]?[^/]*$/', '', $path);
echo '<div class="list-group-item media"><a href="zip.php?act=preview&id='.$id.'&open='.$path.'"><i class="zmdi zmdi-download"></i> ' . $fname.'</a>';
if ($sizefiles[$n] != 0) echo ' (' . round($sizefiles[$n] / 1024, 2) . 'kb)';
echo '<br/>';
echo'</div>';
$n++;
}
echo '<div class="list-group-item media">';
echo 'Страницы: ';
$asd = $page - 2;
$asd2 = $page + 3;
if ($asd < $count && $asd > 0 && $page > 3) echo '<a href="zip.php?id='.$id.'&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.'&page='.$i.'">' . $i . '</a> ';
}
}
if ($i <= $pages)
{
if ($asd2 < $count) echo ' ... <a href="zip.php?id='.$id.'&page='.$pages.'">' . $pages . '</a>';
}
echo '</div>';
}
/* Просмотр файла */
if ($act == 'preview'){
$open = check($_GET['open']);
if (strpos($open , '..') !== false or strpos($open , './') !== false) {
echo 'В хакера решил поиграть?';
$title->GetMenu();
$title->GetFooter();
exit();
}
$zip = new PclZip($di);
$content = $zip->extract(PCLZIP_OPT_BY_NAME, $open, PCLZIP_OPT_EXTRACT_AS_STRING);
$content = $content[0]['content'];
$preview2 = explode("n", $content);
$count = count($preview2);
echo '<div class="list-group-item media"><b>Файл: ' . $open . '</b></div>';
$eX = strtolower(strrchr($open, '.'));
$php = ['.php', '.pl', '.js', '.jsp', '.html', '.xhtml', '.xml', '.wml', '.asp', '.aspx'];
$txt = ['.txt', '.sql', '.dat', '.css', '.ini', '.function', '.htaccess', '.tpl'];
$img = ['.gif', '.jpg', '.jpeg', '.png', '.bmp', '.wbmp', '.ico', '.swf'];
if (empty($content)) die('<div class="alert alert-danger"role="alert">Файл пуст.</div>');
if (isset($_GET['img'])){
$ext = strtolower(substr($open, strrpos($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;
$title->GetMenu();
$title->GetFooter();
exit();
}
if (in_array($eX, $php))
{
echo (!empty($content) ? '<div class="list-group-item media">Строк: ' . $count . '</div>' : '');
if (is_utf($content)) echo '<div class="list-group-item media">' . hightlight($content).'</div>';
else echo ' <div class="list-group-item media">' . hightlight(win_to_utf($content)). '</div>';
}
elseif (in_array($eX, $txt))
{
$content = htmlspecialchars($content);
echo (!empty($content) ? '<div class="list-group-item media">Строк: ' . $count . '</div>' : '');
if ($content) echo '<div class="list-group-item media">' . nl2br($content) . '</div>';
else echo '<div class="list-group-item media">' . win_to_utf(nl2br($content)) . '</div>';
}
elseif (in_array($eX, $img)){
echo '<div class="list-group-item media"><img src="zip.php?act=preview&id='.$id.'?
&open='.$open.'&img" alt=""/></div>';
}
else
{
die('Невозможно прочесть файл!');
}
}
echo '<div class="list-group-item media"><a href="file.php?id='.$id.'"><i class="zmdi zmdi-home"></i> Вернуться к файлу</a></div>';
if (isset($_GET['act'])) echo '<div class="list-group-item media"><a href="zip.php?id='.$id.'"><i class="zmdi zmdi-apps"></i> К просмотру архива</a></div>';
$title->GetMenu();
$title->GetFooter();
?>