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

Форум PHP

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

 

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

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

тема: Запрет вывод изображения из определенной папки
 
 автор: lElectroHardl   (04.01.2011 в 19:15)   письмо автору
 
 

Как сделать,
что бы через вид
http://site.ru/img/myfoto/img5.jpg
увидеть фотографию было нельзя, а через вид
<?php 
// http://site.ru?img=5

$a mysql_query ("SELECT img FROM images WHERE id = $_GET[img]");
$b mysql_fetch_array($a);

echo 
"<img src='img/myfoto/$b[img]' />";

ее видеть было можно.

  Ответить  
 
 автор: Trianon   (04.01.2011 в 19:20)   письмо автору
 
   для: lElectroHardl   (04.01.2011 в 19:15)
 

тег <img src='кудато-там' /> приводит к тому, что браузер за фотографией пытается залезть именно кудато-там , а не куда-то еще.

можно ожидать Referer, можно устраивать пляски с сессиями.
Но если Вы выкинули фотографию в браузер - точка. Она ушла клиенту.

  Ответить  
 
 автор: lElectroHardl   (04.01.2011 в 19:22)   письмо автору
 
   для: Trianon   (04.01.2011 в 19:20)
 

А как тогда реализовать такую вещь, как "доступ после авторизации"?
Ведь узнать адрес фотографии большого труда не составит.

  Ответить  
 
 автор: cheops   (04.01.2011 в 19:36)   письмо автору
 
   для: lElectroHardl   (04.01.2011 в 19:22)
 

В атрибут src подставляйте адрес PHP-скрипта, который проверяет, авторизован ли пользователь и если проверка успешная - выводит нужное изображение
<?php
  
// Авторизация
  
...
  echo 
file_get_conetents("path/to/img");
?>

Где path/to/img - путь к изображению, находящемуся в директории, закрытой для просмотра через браузера средствами Apache (разумеется это не распространяется на PHP, если путь относительный, а не сетевой).

  Ответить  
 
 автор: neadekvat   (04.01.2011 в 19:40)   письмо автору
 
   для: cheops   (04.01.2011 в 19:36)
 

или readfile, дабы без echo :)

  Ответить  
 
 автор: cheops   (04.01.2011 в 19:42)   письмо автору
 
   для: neadekvat   (04.01.2011 в 19:40)
 

Даже лучше, особенно, если файлы большие.

  Ответить  
 
 автор: lElectroHardl   (04.01.2011 в 19:50)   письмо автору
 
   для: cheops   (04.01.2011 в 19:42)
 

до 6000х6000 px (поэтому и жалко отдавать)

  Ответить  
 
 автор: cheops   (04.01.2011 в 20:00)   письмо автору
 
   для: lElectroHardl   (04.01.2011 в 19:50)
 

Обычным пользователям можно отдавать урезанную (средствами PHP) версию, еще и водяной знак можно разместить (также средтствами PHP).

  Ответить  
 
 автор: neadekvat   (04.01.2011 в 20:01)   письмо автору
 
   для: cheops   (04.01.2011 в 20:00)
 

По этому поводу уже ведется обсуджение :)

  Ответить  
 
 автор: lElectroHardl   (04.01.2011 в 20:18)   письмо автору
 
   для: cheops   (04.01.2011 в 19:36)
 

Если я поставлю защиту (Deny from all) для папки, можно ли будет извлечь из нее файлы не через браузер?

  Ответить  
 
 автор: neadekvat   (04.01.2011 в 20:21)   письмо автору
 
   для: lElectroHardl   (04.01.2011 в 20:18)
 

Вообще единственный способ достать оттуда файлы - скриптом (не считая ftp, ssh..)

  Ответить  
 
 автор: cheops   (04.01.2011 в 20:25)   письмо автору
 
   для: lElectroHardl   (04.01.2011 в 20:18)
 

Извлечь кому? Вам (вашим скриптам) или клиентам (которые обращаются к серверу через сеть)? Вам можно, клиентам - нет (если у них нет обходного пути, вроде FTP-доступа).

  Ответить  
 
 автор: lElectroHardl   (04.01.2011 в 20:37)   письмо автору
 
   для: cheops   (04.01.2011 в 20:25)
 

Спасибо.
Просто читал в предыдущих постах (за 2005-7) год читал, что их можно получить через командную строку.

  Ответить  
 
 автор: cheops   (04.01.2011 в 20:42)   письмо автору
 
   для: lElectroHardl   (04.01.2011 в 20:37)
 

Нет, Web-сервер просто ничего не отдаст на 80 порт, если это запрещено. А чтобы получить ресурсы через другие сервера (FTP, SSH и т.п.) они должны быть развернуты и у клиента должен быть соответствующие логин и пароль.

  Ответить  
 
 автор: lElectroHardl   (04.01.2011 в 20:52)   письмо автору
 
   для: cheops   (04.01.2011 в 19:36)
 

Что-то не получается. Когда использую эту функцию, выводится какие-то символы, много символов!

  Ответить  
 
 автор: cheops   (04.01.2011 в 21:04)   письмо автору
 
   для: lElectroHardl   (04.01.2011 в 20:52)
 

Нужно еще отправить соответствующие HTTP-заголовки, например, если у вас JEPG-файл, то перед файлом нужно отправить следующий HTTP-заголовок
<?php
    header
("Content-type: image/jpeg"); 
?>


PS Изображение выводится в отдельном PHP-файле, путь к которому помещается в атрибут src тэга img?

  Ответить  
 
 автор: lElectroHardl   (04.01.2011 в 21:18)   письмо автору
 
   для: cheops   (04.01.2011 в 21:04)
 

Я так понимаю, что я делаю не правильно, поэтому и не работает (а работает только при непосредственном обращении к img.php):
<img src='http://site.org/img.php' alt='$foto[title]' title='$foto[title]'  border='0' />

Если нет, то, есть ли возможность вывести картинку, через эту php функцию, после вывода основного контента?

  Ответить  
 
 автор: cheops   (04.01.2011 в 21:25)   письмо автору
 
   для: lElectroHardl   (04.01.2011 в 21:18)
 

Когда обращаетесь напрямую к http://site.org/img.php в строке браузера картинка выводится?

  Ответить  
 
 автор: lElectroHardl   (04.01.2011 в 21:27)   письмо автору
 
   для: cheops   (04.01.2011 в 21:25)
 

Да, конечно.

  Ответить  
 
 автор: cheops   (04.01.2011 в 21:29)   письмо автору
 
   для: lElectroHardl   (04.01.2011 в 21:27)
 

А выводитие IMG-тэг так?
<?php
  
echo "<img src='http://site.org/img.php' alt='$foto[title]' title='$foto[title]'  border='0' />";
?>

И не отображается? Вообще-то должно...

  Ответить  
 
 автор: lElectroHardl   (04.01.2011 в 21:35)   письмо автору
 
   для: cheops   (04.01.2011 в 21:29)
 

Все-все, выводиться. Забыл, что там еще проверка авторизации стоит :).

Все, всем спасибо большое за помощь.

  Ответить  
 
 автор: neadekvat   (04.01.2011 в 21:34)   письмо автору
 
   для: lElectroHardl   (04.01.2011 в 21:18)
 

$foto[title] следует заменить на {$foto['title']}, т.к. в первом случаи вы, по сути, в качестве индекса указываете некую константу. Вряд ли это на самом деле так. И пусть php в данном случаи "додумывает" сам, однако нотайс все-таки показывает.

  Ответить  
 
 автор: lElectroHardl   (04.01.2011 в 21:36)   письмо автору
 
   для: neadekvat   (04.01.2011 в 21:34)
 

Впервые вижу такую форму записи.
Я же вывожу $foto[""] через echo "";

  Ответить  
 
 автор: cheops   (04.01.2011 в 21:39)   письмо автору
 
   для: lElectroHardl   (04.01.2011 в 21:36)
 

Есть такая форма, как раз для сложных индексных значений.
<?php
  
echo "value = {$foto['key']}<br />";
?>

  Ответить  
 
 автор: neadekvat   (04.01.2011 в 21:40)   письмо автору
 
   для: lElectroHardl   (04.01.2011 в 21:36)
 

И то верно.. Нотайс не выдает. Привычка :)

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

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