Модераторы: skyboy, MoLeX, Aliance, ksnk
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Работа с текстовыми и графическими данными совместно в PHP и MySQL 
:(
    Опции темы
DezmASter
Дата 22.4.2007, 21:58 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Дизайнер :)
***


Профиль
Группа: Участник
Сообщений: 1520
Регистрация: 3.2.2006
Где: Украина, Запорожь е

Репутация: нет
Всего: 109



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

Итак, постановка задачи:

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

Фамилия, имя, отчество 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 Kossarik
E-mail автора: [email protected] 

PM WWW ICQ Skype GTalk Jabber   Вверх
Redstuff
Дата 20.11.2007, 22:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Команда REDSTUFF
**


Профиль
Группа: Участник
Сообщений: 497
Регистрация: 27.5.2006
Где: Санкт-Петербург

Репутация: нет
Всего: 1



Решил попробовать пример, но чето выдает ошибки в файле function.inc кое-что поправил но с этим не могу разобраться
Код

Fatal error: Cannot redeclare html_begin()


Проблема с повторным определением функции, решаеться подключением функцией include_once:
Код

include("function.inc");




Это сообщение отредактировал(а) Redstuff - 2.4.2008, 17:32


--------------------
ГОСТы, СНиПы, ТУ...
<реклама удалена администрацией форума>
PM MAIL WWW ICQ Skype   Вверх
mishaSL
Дата 21.11.2007, 11:52 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Участник Клуба
Сообщений: 1046
Регистрация: 10.1.2007
Где: Санкт-Петербург

Репутация: 7
Всего: 54



Мммдддааа.... статья очень низкого уровня....

Немного о недостатках скрипта:
1. Скрипт написан с использованием register_globals=ON Подробнее...
2. Неправильное обращение к элементам массива, к примеру $f[id_infouser]
3. Использование устаревших конструкций, к примеру $HTTP_GET_VARS
4. Подстановка в запрос к БД непроверенных данных: id_infouser = '$val'
5. В принципе отвратительный стиль написания кода и логические ошибки в скрипте, к примеру автор скрипта получает id пользователя перебором всего _GET массива:
Код

while (list ($key, $val) = each ($HTTP_GET_VARS)) {

и при каждом выполнении делает подключение к БД и запрос с использование переменной $val

ИМХО, эта статья не может принести никакой пользы начинающим PHP программистам.


--------------------
Лучший способ научиться программированию - это посмотреть как это делают другие...
PM MAIL   Вверх
Redstuff
Дата 2.4.2008, 17:33 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Команда REDSTUFF
**


Профиль
Группа: Участник
Сообщений: 497
Регистрация: 27.5.2006
Где: Санкт-Петербург

Репутация: нет
Всего: 1



mishaSL, Быть может перепишешь как следует?)


--------------------
ГОСТы, СНиПы, ТУ...
<реклама удалена администрацией форума>
PM MAIL WWW ICQ Skype   Вверх
awers
Дата 2.4.2008, 17:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Участник
Сообщений: 1465
Регистрация: 22.3.2006
Где: Россия, Таганрог

Репутация: нет
Всего: 31



Redstuff, тут то собственно и переписывать нечего
PM MAIL WWW ICQ Skype   Вверх
Feldmarschall
Дата 2.4.2008, 17:48 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок
****


Профиль
Группа: Участник
Сообщений: 2641
Регистрация: 11.12.2007

Репутация: 1
Всего: 32



Мда. Сказать по правде, лично мне было бы стыдно, если бы у меня на сайте висела такая "статья".
PM   Вверх
bars80080
Дата 2.4.2008, 17:53 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


прапор творюет
****
Награды: 1



Профиль
Группа: Завсегдатай
Сообщений: 12022
Регистрация: 5.12.2007
Где: Königsberg

Репутация: 9
Всего: 315



интересно, что на некоторые поля в БД стоит ограничение в 50 символов, в то время как средний блоб поднимает до 16 млн

у меня такой вопрос: (может глупый) если добавить запись в таблицу без фото, то какой объём в памяти забьёт эта запись?
PM MAIL WWW   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | PHP: Базы Данных | Следующая тема »


 




[ Время генерации скрипта: 0.0874 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.