Навигация
Главная
Поиск
Форум
FAQ's
Ссылки
Карта сайта
Чат программистов

Статьи
-Delphi
-C/C++
-Turbo Pascal
-Assembler
-Java/JS
-PHP
-Perl
-DHTML
-Prolog
-GPSS
-Сайтостроительство
-CMS: PHP Fusion
-Инвестирование

Файлы
-Для программистов
-Компонеты для Delphi
-Исходники на Delphi
-Исходники на C/C++
-Книги по Delphi
-Книги по С/С++
-Книги по JAVA/JS
-Книги по Basic/VB/.NET
-Книги по PHP/MySQL
-Книги по Assembler
-PHP Fusion MOD'ы
-by Kest
Professional Download System
Реклама
Услуги

Автоматическое добавление статей на сайты на Wordpress, Joomla, DLE
• Заказать продвижение сайта
• Программа для рисования блок-схем
• Инженерный калькулятор онлайн
• Таблица сложения онлайн
Популярные статьи
OpenGL и Delphi... 65535
Форум на вашем ... 65535
HACK F.A.Q 65535
Гостевая книга ... 65535
Содержание сайт... 65535
Вызов хранимых ... 65535
Эмулятор микроп... 65535
Бип из системно... 58094
Invision Power ... 57350
Организация зап... 57154
Модуль Forms 56354
Создание отчето... 54768
Приложение «Про... 54148
Подключение Mic... 53942
Оператор выбора... 53729
ТЕХНОЛОГИИ ДОСТ... 50631
Программируемая... 47064
Пример работы с... 46390
Имитационное мо... 46385
21 ошибка прогр... 41470
Реклама
Сейчас на сайте
Гостей: 11
На сайте нет зарегистрированных пользователей

Пользователей: 13,006
новичок: margaritamoroz
Новости
Реклама
Выполняем курсовые и лабораторные по разным языкам программирования
Подробнее - курсовые и лабораторные на заказ
Delphi, Turbo Pascal, Assembler, C, C++, C#, Visual Basic, Java, GPSS, Prolog, 3D MAX, Компас 3D
Заказать программу для Windows Mobile, Symbian

База данных студентов на Delphi (файл записей) + Блок схемы
Моделирование работы аэропорта на GPSS + Пояснительная записка
Моделирование информационно-поисковой библиографической системы на gpss ...

Реклама

Работа с текстовыми и графическими данными совместно в PHP и MySQL
Я прочитал много документов посвященных этой теме, в результате попробовал десяток из них, и ничего не получив в ответ правильно работающего, решил сам написать более менее подходящий для моей задачи решение.

Итак, постановка задачи:
Требуется хранить в базе данных такую информацию:

Фамилия, имя, отчество email, фотографию и краткое описание (или биографию) человека.

Для достижения поставленной цели выбран вполне распространенный комплект веб-сервера: Apache 1.3.20, PHP 4.1.0, MySQL 4.0.0.

Для начала создаем БД:
mysqladmin -p create testdb

затем делаем ее текущей:
use testdb.

Дальше создаем таблицу для хранения информации:
CREATE TABLE infouser (
id_infouser int(7) unsigned NOT NULL auto_increment,
lastname varchar(255) NOT NULL default '',
firstname varchar(255) NOT NULL default '',
patronym varchar(255) NOT NULL default '',
imageinfouser mediumblob,
filename1 varchar(50) default NULL,
filesize1 varchar(50) default NULL,
filetype1 varchar(50) default NULL,
infoinfouser varchar(255) default NULL,
emailinfouser varchar(100) default NULL,
PRIMARY KEY (id_infouser))


Сначала создадим файл для хранения функций, таких как, соединение с БД, и шаблонов, чтобы десять раз не переписывать одно и то же:
<?php
// tags for open html-docs
function html_begin($header)
{
print("<html>\n");
print("<head>\n");
print("<META HTTP-EQUIV=\"Content-Type\"
Content=\"text/html">");
print("<title>Тестовая БД</title>\n");
print("</head>\n");
print("<body text = \"#000000\" bgcolor
= \"#52FA90\">\n");
print("<br><center><table width = \"90%\"
border = \"1\" bgcolor = \"green\" cols = \"1\">");
print("<tr><td><p style = \"text-align:
justify; margin-left: 50 px; margin-right: 50 px\">");
if ($header)
print("<h3>$header</h3>\n");
print("</p><hr width = \"100%\"
size = \"1\" color = \"#c0c0c0\"><p>");
}
//
// tags for close html-docs
function html_end()
{
print("</td></tr></table></center>");
print("</body></html>");
}
//
// function for connect mysql and select database
function connect_mysql()
{
define("DBName","testdb");
define("HostName","localhost");
define("UserName","valery");
define("Password","");
if(!mysql_connect(HostName,UserName,Password))
{ echo "Сервер временно не работает, заходите позже.".DBName."!<br>";
echo mysql_error();
exit;
}
mysql_select_db(DBName);
}
?>
Делаем форму для ввода информации.
Файл с именем insert.php
<?php
include("function.inc");
$header = ("ввести нового человека");
html_begin ($header);
?>
<form action = "insert2.php" method = "post"
enctype = "multipart/form-data">
Фамилия: <input type = "text" name = "lastname"
size = "30" maxlenght = "30"><br>
Имя: <input type = "text" name = "firstname"
size = "30" maxlenght = "30"><br>
Отчество: <input type = "text" name = "patronym"
size = "30" maxlenght = "30"><br>
Email: <input type = "text" name = "email"
size = "30" maxlenght = "30"><br>
Фотография: <input type = "file" name = "userfile"><br>
Информация о человеке:<br>
<textarea name = "infoinfouser" cols = "40"
rows = "5"></textarea>
<br>
<input type = "submit" value = "Ввести нового человека"><br>
</form>
<?php
html_end();
?>

затем идет страница принимающая информацию имя файла достаточно очевидно insert2.php:
<?php
include("function.inc");
$header = ("ввод информации");
html_begin ($header);
//
//read file image
$fd = fopen ($userfile, "rb");
$userfile2 = fread ($fd, filesize ($userfile));
fclose ($fd);
$userfile2 = addslashes($userfile2);
//
// insert in db
//
connect_mysql();
mysql_query("SELECT * FROM infouser");
mysql_query("INSERT INTO infouser(id_infouser, lastname, firstname, patronym,
imageinfouser, filename1, filesize1, filetype1, infoinfouser, email_infouser)
VALUES('','$lastname', '$firstname', '$patronym', '$userfile2', '$userfile_name',
'$userfile_size', '$userfile_type', '$infoinfouser', '$email')");
echo "<br>";
print "Новый пользователь успешно введен";
mysql_close();
html_end();
?>
вот и все мы ввели данные, теперь их надо как-то прочитать.
Для этого используем еще три файла.
Первый файл выдает список пользователей.
prev.php
<?php
include("function.inc");
//
$header = ("просмотр записей");
html_begin ($header);
//
connect_mysql();
//
print ("<table cols =\"1\">");
// Выводим все записи
$r=mysql_query("SELECT * FROM infouser");
for($i=0; $i<mysql_num_rows($r); $i++)
{ $f=mysql_fetch_array($r);
print "<tr>";
print "<td align = \"center\">";
print "<a target = \"_new\" href = \"sample.php?id=$f[id_infouser]\">$f[lastname]
$f[firstname] $f[patronym] </a>";
print "<p>";
//
print "</td>";
print "</tr>";
}
print "</table>";
mysql_close();
html_end();
?>

второй файл используется для выдачи данных по одному пользователю: sample.php
<?php
//
include("function.inc");
$header = ("просмотр записей");
html_begin ($header);
//
connect_mysql();
//
reset ($HTTP_GET_VARS);
while (list ($key, $val) = each ($HTTP_GET_VARS)) {
//
$sql = "SELECT * FROM infouser WHERE id_infouser = '$val'";
$result = mysql_query($sql);
$rows = mysql_num_rows($result);
echo "<table border = \"0\" width = \"70%\">\n";
for ($i = 0; $i < $rows; $i++) {
$data = mysql_fetch_object($result);
echo " <tr>\n";
echo " <td><font color = \"red\" size
= \"+1\">$data->lastname<br> $data->firstname<br>
$data->patronym<br></font></td>\n";
echo " <td rowspan = \"2\"><center><img
src = 'download.php?id=$data->id_infouser' border =
'2' bgcolor = '#01cccc'></center></td>\n";
echo " </tr>\n";
echo " <tr>\n";
echo " <td><font color = \"green\">$data->emailinfouser</font></td>\n";
echo " </tr>\n";
echo " <tr>\n";
echo " <td colspan = \"2\">$data->infoinfouser</td>\n";
echo " </tr>\n";
}
mysql_free_result($result);
}
mysql_close();
//
html_end();
?>

следующий файл реализует обработку фотографий и выдачу их: download.php
<?php
//
reset ($HTTP_GET_VARS);
while (list ($key, $val) = each ($HTTP_GET_VARS)) {
//
//
define("DBName","testdb");
define("HostName","localhost");
define("UserName","valery");
define("Password","");
if(!mysql_connect(HostName,UserName,Password))
{ echo "Сервер временно не работает, заходите
позже.".DBName."!<br>";
echo mysql_error();
exit;
}
mysql_select_db(DBName);
//
//
$sql = "SELECT imageinfouser, filename1, filetype1 FROM
infouser WHERE id_infouser='$val'";
$result = @mysql_query($sql);
$data = @mysql_result($result, 0, "imageinfouser");
$name = @mysql_result($result, 0, "filename1");
$type = @mysql_result($result, 0, "filetype1");
header("Content-type: $type");
echo $data;
}
mysql_close();
?>

если есть вопросы пишите: valery_lek@mail.ru

Опубликовал Kest November 06 2008 00:52:41 · 1 Комментариев · 4211 Прочтений · Для печати

• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •


Комментарии
MAЙЯ May 26 2009 10:36:31
Текст лично мне ничего не дал. Хотя для многих может оказаться очень полезным... smiley
Добавить комментарий
Имя:



smiley smiley smiley smiley smiley smiley smiley smiley smiley
Запретить смайлики в комментариях

Введите проверочный код:* =
Рейтинги
Рейтинг доступен только для пользователей.

Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.

Нет данных для оценки.
Гость
Имя

Пароль



Вы не зарегистрированны?
Нажмите здесь для регистрации.

Забыли пароль?
Запросите новый здесь.
Поделиться ссылкой
• Фолловь меня в Твиттере!
Загрузки
Новые загрузки
iChat v.7.0 Final...
iComm v.6.1 - выв...
Visual Studio 200...
CodeGear RAD Stud...
Шаблон для новост...

Случайные загрузки
Prolog Interprete...
NotePad Pro [Исхо...
Разработка клиент...
Пятнашки и крести...
ComboBox97
C++ Builder: Книг...
БД студентов
Email
PHP, MySQL и Drea...
PHP: Полезные приемы
C++ Builder 6 СПР...
Page Promoter 7.7...
IMtale
Динамические за...
Язык программиров...
Интерактивный инт...
Mass Photo Upload
Ведение справочны...
SMLPack v1.0
OnlineIP

Топ загрузок
Приложение Клие... 100264
Delphi 7 Enterp... 74750
WAV 1.7.1" class="side">Converter AMR<-... 20015
Borland C++Buil... 10459
GPSS World Stud... 8749
Borland Delphi ... 7441
Turbo Pascal fo... 6866
Visual Studio 2... 4864
Калькулятор [Ис... 3828
FreeSMS v1.3.1 3480
Случайные статьи
Метод резолюции в ...
Выполнение лаборат...
5-9).contoso.
Использование CRON...
Фокус на объеме работ
На компьютерах Mac...
Впрочем, зачастую ...
Измерение времени ...
Задачу упрощения в...
Аэродинамическое м...
Ограничение объясн...
Маршрутизации марш...
Иерархические стру...
изучение основных ...
лесу Windows 2000
Планирование за не...
Виртуальные машины...
Журналы протокола ...
Обратные сортировк...
Изображение TIFF
Оценка с точностью...
Сообщения имеют сл...
Элемент select con...
— обновления серти...
— отправлять сообщ...
Статистика



Друзья сайта
Программы, игры


Полезно
В какую объединенную сеть входит классовая сеть? Суммирование маршрутов Занимают ли таблицы память маршрутизатора?