Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
PHP 5. На примерах. Авторы: Кузнецов М.В., Симдянов И.В., Голышев С.В. MySQL на примерах. Авторы: Кузнецов М.В., Симдянов И.В. Социальная инженерия и социальные хакеры. Авторы: Кузнецов М.В., Симдянов И.В. PHP Puzzles. Авторы: Кузнецов М.В., Симдянов И.В. Самоучитель PHP 5 / 6 (3 издание). Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум PHP

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: как проверить, что загруженный файл - архив?
 
 автор: Bvz   (06.12.2010 в 21:32)   письмо автору
 
 

сабж...

  Ответить  
 
 автор: Trianon   (06.12.2010 в 21:38)   письмо автору
 
   для: Bvz   (06.12.2010 в 21:32)
 

Что загруженный файл - архив какого типа?

  Ответить  
 
 автор: Bvz   (06.12.2010 в 23:56)   письмо автору
 
   для: Trianon   (06.12.2010 в 21:38)
 

zip, rar

  Ответить  
 
 автор: Trianon   (07.12.2010 в 01:21)   письмо автору
 
   для: Bvz   (06.12.2010 в 23:56)
 

так zip или rar ?
У них разная структура.

zip

rar

  Ответить  
 
 автор: Bvz   (07.12.2010 в 07:12)   письмо автору
 
   для: Trianon   (07.12.2010 в 01:21)
 

zip

  Ответить  
 
 автор: Bvz   (10.12.2010 в 09:58)   письмо автору
 
   для: Bvz   (07.12.2010 в 07:12)
 

посмотрел в hex-редакторе архивы у zip - PK у 7z - 7z, а у rar-RAR стоит в первые байты,
пропустил архивы через file_get_contents() аналогичная ситуация, а если я меняю расширения у скрипта на zip то заголовки пустые, т.е. его не обманешь, а вот $_FILES['file']['type'] показывает тип соответственно расширению, т.е. обманывает :)

достаточно ли проверки file_get_contents($uploadfile, null, null, 0, 2) - условно, зная изначально что нам нужно; для того чтоб удостовериться, что нам загружают нужный файл?

  Ответить  
 
 автор: Trianon   (10.12.2010 в 11:05)   письмо автору
 
   для: Bvz   (10.12.2010 в 09:58)
 

недостаточно.

  Ответить  
 
 автор: Bvz   (10.12.2010 в 11:07)   письмо автору
 
   для: Trianon   (10.12.2010 в 11:05)
 

а что еще надо?

  Ответить  
 
 автор: Trianon   (10.12.2010 в 11:17)   письмо автору
 
   для: Bvz   (10.12.2010 в 11:07)
 

надо...удостовериться, что нам загружают нужный файл...
Цитирую непосредственно Вас.

...а не фигню с буковками PK или RAR

  Ответить  
 
 автор: Bvz   (10.12.2010 в 11:23)   письмо автору
 
   для: Trianon   (10.12.2010 в 11:17)
 

>надо...удостовериться, что нам загружают нужный файл...
>Цитирую непосредственно Вас.
>
>...а не фигню с буковками PK или RAR
а как понять что загружают нужный файл?

  Ответить  
 
 автор: Trianon   (10.12.2010 в 11:33)   письмо автору
 
   для: Bvz   (10.12.2010 в 11:23)
 

для этого как минимум нужно описать критерий "при каких условиях файл считать хорошим, годным"

  Ответить  
 
 автор: Bvz   (10.12.2010 в 11:41)   письмо автору
 
   для: Trianon   (10.12.2010 в 11:33)
 

про какие условия вы говорите?
мне надо чтоб он был zip архив

  Ответить  
 
 автор: Trianon   (10.12.2010 в 11:48)   письмо автору
 
   для: Bvz   (10.12.2010 в 11:41)
 

Про описываемые Вами условия.
ну вот что значит "он был"?
имел такое расширение?
начинался с указанных буковок?
содержал центральный каталог?
содержал незашифрованные файлы, которые можно успешно извлечь?

  Ответить  
 
 автор: Bvz   (10.12.2010 в 12:16)   письмо автору
 
   для: Trianon   (10.12.2010 в 11:48)
 

чтоб он был zip-архив

  Ответить  
 
 автор: Trianon   (10.12.2010 в 12:24)   письмо автору
 
   для: Bvz   (10.12.2010 в 12:16)
 

Он был степной волк какой-то...

Файл будет zip архивом тогда и только тогда, и в глазах того и только того, кто его (файл) за этот термин (zip архив) посчитает.

  Ответить  
 
 автор: Bvz   (10.12.2010 в 12:25)   письмо автору
 
   для: Trianon   (10.12.2010 в 12:24)
 

извените понял :)

чтоб один или несколько файлов были заархивированы архиватором и на выходе получен архив с именем заданным пользователем и расширением zip, rar, 7z

а ведь это мысль, если архив содержит файлы и распаковывается, то это архив, это можно использовать для проверки

  Ответить  
 
 автор: Bvz   (10.12.2010 в 14:34)   письмо автору
 
   для: Bvz   (10.12.2010 в 12:25)
 

а mime_content_type для этого подойдет?

  Ответить  
 
 автор: Trianon   (10.12.2010 в 15:12)   письмо автору
 
   для: Bvz   (10.12.2010 в 14:34)
 

чойта?

  Ответить  
 
 автор: Bvz   (10.12.2010 в 15:15)   письмо автору
 
   для: Trianon   (10.12.2010 в 15:12)
 

типа такая фунция есть но йа так поняф что это геморный путь, есть исчо?

  Ответить  
 
 автор: Trianon   (10.12.2010 в 15:33)   письмо автору
 
   для: Bvz   (10.12.2010 в 15:15)
 

надо смотреть, как она реализована, и подходит ли Вам такая проверка.

  Ответить  
 
 автор: Bvz   (10.12.2010 в 15:39)   письмо автору
 
   для: Trianon   (10.12.2010 в 15:33)
 

пока нашел такое решение

if(! is_resource(zip_open($filename))) {
    die("Загруженный файл не является ZIP-архивом");
}

  Ответить  
 
 автор: Trianon   (10.12.2010 в 16:08)   письмо автору
 
   для: Bvz   (10.12.2010 в 15:39)
 

вполне.

  Ответить  
 
 автор: Bvz   (10.12.2010 в 20:06)   письмо автору
 
   для: Trianon   (10.12.2010 в 16:08)
 

ура!

а так можно запретить прямой доступ к файлу где лежит .htaccess следующего содержимого
Deny from all 

  Ответить  
 
 автор: Trianon   (10.12.2010 в 20:17)   письмо автору
 
   для: Bvz   (10.12.2010 в 20:06)
 

Благородному дону не объясняли, что оффтопить нехорошо?
какое отношение вопрос имеет к типу архива?

  Ответить  
 
 автор: Bvz   (10.12.2010 в 20:22)   письмо автору
 
   для: Trianon   (10.12.2010 в 20:17)
 

теперь я знаю что нехорошо оффтопить )))

  Ответить  
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования