Чтение/показ из файлов или загрузка/получение из базы данных бинарных файлов.

www.karman.com.ua
портал о хостинге в Украине
Хостинг + Украина = Karman.com.ua

Сайт от А до Б

/

Основы сайта

/

Интересные скрипты

/

Изучаем PHP

/

Как заработать на сайте

/

Раскрутка сайта

/

CMS


Чтение/показ из файлов или загрузка/получение из базы данных бинарных файлов. 

Еще по теме:
  Автоматическая перезагрузка страниц (refresh)
  загрузка файлов по http
  хостинг файлов на сoolshare.com.ua
  Яндекс.Директ считает показы в РСЯ по-новому
  Услуги SEO копирайтера для получения высоких рейтингов
  проблемы с заливкой файлов
  Бегун Автоконтекст показы
  Domaining и Domainers – получение остаточной прибыли при помощи Domain Parking

Как с помощью ПХП выдать бинарный файл браузеру? Например, при клике мышкой по линку asd.php у человека в браузере грузиться картинка (именно картинка, а не HTML файл с тегом IMG) или выскакивает окошко с просьбой сохранить .ZIP файл.

Как загружать в базу данных бинарные файлы (картинки, архивы или др) и далее брать их в PHP программе.

Выполнте несколько примеров и вопросы исчезнут. Если проблемы с UPLOAD файлов на сервер - это совершенная другая проблема, просто новички лепят все в одну кучу - читатайте инструкцию "UPLOAD файлов на сервер".

1. Чтобы выдать браузеру картинку с диска сервера, надо...

Пример 1

Создайте файл test.php и в том же каталоге картинку image.jpg. Текст test.php:

header("Content-type: image/gif");
readfile("image.jpg");

?>

После этого в браузере загрузите http://ваш-сервер/.../test.php и на экране будет картинка.

Что такое Content-type: image/gif? Ответ: это тип файла, который вы собираетесь выдать браузеру. Для выдачи HTML файла пишите (вместо image/gif) text/html, для выдачи бинарного файла application/xxxxxxx ("xxxxxxx" можно заменить любым словом - браузеру по барабану, все неизвестное ему он предложит сохранить на диск). При выдаче бинарного файла, даже если это будет document.txt или image.jpg, в браузере всплывет окошко с просьбой сохранить файл, где имя файла совпадет с названием программы, т.е. test.php. Как предложить другое (заданное программером) имя, будет написано в другой раз (пока можете в форуме поискать).

Почему, выдавая JPG файл, мы пишем image/gif? Ответ: если не бы это не работало, то перед выдачей файла пришлось бы проверять тип файла (JPG/GIF/PNG). Но это работает, поэтому вегда так пишите, чтобы не делать лишнюю работу.

Пример 2

Сделайте такой файл test.html

и в том же каталоге разместите image.jpg и text.php (текст выше), загрузите его в браузере test.html. Таким образом вы можете скрывать имена картинок, которые читаете с диска. Или брать картинку не с диска, а из базы данных, о чем ниже.

Добрый совет

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

2. Размещение бинарных файлов (картинок) в базе данных

Для помещеня бинарного файла в базу данных, надо...

1. создайте таблицу с полем BLOB

2. прочитайте данные, которые надо поместить в базу данных, в переменную $upload. Если это файл (картинка) на диске, то сделайте это так:

$f=fopen("image.jpg","rb"); // имя файла или картинки -- открыли файл на чтение
$upload=fread($f,filesize("image.jpg")); // считали файл в переменную
fclose($f); // закрыли файл, можно опустить
...

3. защитите переменную от опасных символов ("прослешьте переменную"):

...
$upload=addslashes($upload);
...

4. загрузите переменную в базу данных:

...
mysql_query("INSERT INTO <таблица> (<поле>) VALUES ('$upload')");
?>

"Таблица" - имя таблицы, "поле" - название колонки в таблице типа BLOB, что были созданы при выполнении пункта 1. Разумеется, чтобы выполнить HTML запрос надо предварительно установить соединение с базой данных.

Для взятия бинарного файла из базы данных в браузере, надо...

Вы будете смеяться, но ничего особого не надо. Просто прочитайте ее как простую переемнную из базы данных. В переменную на языке ПХП можно упихать все, что надо. Правда, есть лимит памяти (будьте внимательны с переменными от 2 МБ), о котором надо помнить. Разумеется, лимит увеличить, но это тема не данной статьи.

Чтобы показать картинку их базы данных, надо...

Освоить пример 1 этой статьи, а вместо чтения из файла, взять переменную из базы данных, примерно вот так:

... // подключение к Б.Д.
$res=mysql_query("SELECT <поле> FROM <таблица> WHERE <условия>")
or die("SQL ERROR in line ".__LINE__.", function mysql_query");
$image=mysql_result($res, <строка>, <колонка>); // берем переменную из б.д.
header("Content-type: image/gif");
echo $image;
?>

Чтобы обсудить это в форуме, нажмите здесь.


Хостинг-источник: http://karman.com.ua, http://www.designer.kulichki.net/articles/php/2.html
  Как создать PDF схему моей базы данных?
  Как я могу восстановить базу данных или таблицу с помощью дампа? Как запустить ".sql" файл?
Есть вопросы о хостинге и о сайтах?
и получи ответ от профессионалов, которые обожают помогать людям :).
Еще по теме:
  Каким должен быть показатель uptime на сайте хостинг провайдера
  Посоветуйте Хостинг для подкачки файлов!
  базы для AllSubmitter
  Что большое всего влияет на скорость загрузки сайта?
  получение новостей из всемирной паутины
  Продвижение вебсайта - реклама для получения выгоды
  Свой сайт: От создания До получения прибыли
  После установки поддержки разделения в MySQL, Apache выдаёт дампы сразу после загрузки libphp4.so. Можно ли это исправить?
  Доступны ли прекомпилированные бинарники PHP?
  Как установить и настроить базу данных MySQL?
  Экспорт: Я слышал, phpMyAdmin может экспортировать данные в файлы Microsoft Excel files, как я могу осуществить такой экспорт?
  В MySQL 4, Я вижу множество баз данных, которые мне не принадлежат, и я не могу получить доступ к ним.
  Что происходит с нижним подчеркиванием в названии базы данных при создании привилегий?

© СПД Праведно-Счастливый Аладдин Ярославович, 2004-2008. Все права защищены. При цитировании материалов ссылка на www.karman.com.ua обязательна. Редакция "Кармана" может не разделять точку зрения авторов статей, сообщений и ответственности за их содержание не несет.

Быстрый переход к содержимому сайта Karman.com.ua:
Новости, советы, углубленные знания, знания для новичков, законодательство, интересные скрипты, фотогалереи, отчеты, статьи о хостинге: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24
Часто задаваемые общие вопросы о хостинге, про FTP, PHPMyAdmin и MySQL, CPanel, Предустановленные скрипты, WHM, Cron, .htaccess, SSH, Паролирование директорий, О доменах, о работе с сайтом, о Раскрутке сайта, об Электронной почте, про Основы web-программирования: 0, 1
Энциклопедия основных терминов хостинга, программного обеспечения, железной стороны хостинга, технологий, электронной почты и доменов: 0, 1, 2, 3, 4, 5, 6
Сайты о хостинге (форумы, хостинг-провайдеры, студии веб-дизайна, домен-регистраторы, инструментарии в помощь вебмастеру): 0, 1, 2

Rambler's Top100