Реферат Программирование в интернете
Работа добавлена на сайт bukvasha.net: 2015-10-28Поможем написать учебную работу
Если у вас возникли сложности с курсовой, контрольной, дипломной, рефератом, отчетом по практике, научно-исследовательской и любой другой работой - мы готовы помочь.
от 25%
договор
ВЕДЕНИЕ
В настоящее время существует большое количество сайтов о компьютерных играх. Эти сайты предоставляют разнообразную информацию и разных видах компьютерных играх и новинок этой области. Важно всегда держать своих пользователей в курсе событий, всегда быстро и удобно предложить им новую продукцию. Многие из таких сайтов работают по уже отлаженной схеме. Для начала идет процесс регистрации нового пользователя, с заполнением нужных полей. Затем проверяются необходимые поля. Если пользователь зарегистрирован в базе данных, то он может добавлять свои изображения, новости, оставлять сообщения на форуме и общаться с другими пользователями по средствам личных сообщений.
Данный проект должен удовлетворять следующим требованиям:
· удобство и простота интерфейса пользователя. Интерфейс должен быть интуитивно понятен и рассчитан на пользователей, обладающих минимальными навыками работы на персональном компьютере;
· достаточная информация обо всех объектах. Информация не должна быть избыточной, но и не должны быть минимальной;
· многофункциональность.
Для решения поставленных задач были применены следующие основные методы исследования: теоретические (исследование предметной области), эмпирические (анализ качества разработанного комплекса, методы построения дизайна сайта, выбор средств разработки).
Цель работы:
Разработать сайт о компьютерных играх. Он должен предоставлять возможность регистрации, просмотра новостей сайта, статей и пользователей, возможность добавления новой информации и комментариев.
Для достижения поставленной цели были сформулированы и решены следующие задачи:
· исследовать предметную область;
· собрать необходимую входную и выходную информацию;
· разработать базу данных для хранения информации;
· разработать PHP-программы для работы с базой данных;
· произвести тестирование отладку программного продукта;
В проекте реализованы следующие функции:
· добавление нового пользователя (регистрация);
· добавление пользователей в базу данных;
· извлечение пользователей из базы данных;
· редактирование и удаление пользователей и статей;
· удобный графический интерфейс.
Объектом исследования является сайт о компьютерных играх.
Предметом исследования является разработка сайта «Компьютерные игры».
Структура и объем работы:
Работа состоит из введения, 4 разделов, заключения, списка использованной литературы и приложения. Пояснительная записка изложена на 53 страницах печатного текста, содержит 6 рисунков. Список использованной литературы включает 12 наименований. Приложения представлены на 26 странице.
1. АНАЛИЗ ПРЕДМЕТНОЙ ОБЛАСТИ
1.1. Предметная область
Разработанный сайт представляет собой систему ведения информации о имеющихся продуктах, а так же пользователей этого интернет магазина. Он позволяет клиенту просматривать информацию о играх и других пользователей, а также добавлять новые, редактировать и удалять статьи, если данный пользователь добавлял информацию. Вся введенная пользователями информация хранится в базе данных.
При разработке проекта для обеспечения его максимальной эффективности очень важно учитывать все особенности информационной среды, в которой будет происходить эксплуатация. Информационная среда сайта представлена пользователями. Отсюда следует, что пользователи имеют ограниченные права на сайте, т.е. не зарегистрированные пользователи не могут добавлять новые статьи, а так же информацию о себе.
Для реализации потребуется выделить следующие сущности, и их атрибуты:
1) Пользователь. Это необходимо, для того чтобы пользователь прошел авторизацию. Если пользователь является новичком, то ему необходимо зарегистрироваться. Выделим атрибуты данной сущности:
· фамилия;
· имя;
· отчество;
· никнейм
· возраст;
· пол;
· e-mail;
· пароль.
2) Статьи. В данном разделе находиться список продуктов, которые имеются в базе. Выделим атрибуты данной сущности:
· наименование;
· содержание;
· дата статьи;
· фирма разработчик;
· дополнительная информация.
3) Пользователи. В данном разделе находиться список пользователей, которые имеются в базе. Выделим атрибуты данной сущности:
· фамилия;
· имя;
· отчество;
· никнейм
· возраст;
· контактная информация;
· дополнительная информация.
Добавлять новые статьи, а также осуществлять заказ могут только зарегистрированные пользователи, а редактировать и удалять существующие могут только те пользователи, которые их добавили.
1.2. Основные возможности и требования к сайту
Можно выделить следующие функциональные возможности:
· удобство и простота интерфейса пользователя. Интерфейс должен быть интуитивно понятен и рассчитан на пользователей, обладающих минимальными знаниями работы в Интернет.
· удобная навигация по сайту. Возможность перехода с любой страницы на любую другую.
· регистрация пользователей. Должна быть реализована возможность регистрации любого посетителя данного сайта.
· Должна предоставляться возможность только зарегистрированным пользователям добавлять разнообразные данные на сайт.
· Предоставление возможности редактирования и удаления данных, только пользователям, которые их добавили.
· небольшой объем страниц, для возможности быстрой загрузки на небольших скоростях.
При данном наборе функций и задач сайт будет наиболее близко приближен к поставленным целям.
Выводы:
1. В данном разделе проведен анализ предметной области.
2. Рассмотрена структура данных для создания сайта.
3. Выделены обязательные атрибуты всех сущностей.
4. Выделены основные функциональные возможности и требования к сайту
2. ПРОЕКТИРОВАНИЕ
2.1. Разработка моделей
Для разработки web-сайта будет применена модель динамической генерации страниц на основе базы данных. В данной модели доступ к БД осуществляется специальной PHP-программой, запускаемой WWW-сервером в ответ на запрос WWW - клиента. Эта программа, обрабатывая запрос, просматривает содержимое БД и создает выходной HTML-документ, возвращаемый клиенту (рис.2.1.).
Это решение эффективно для больших баз данных со сложной структурой и при необходимости поддержки операций поиска. Показаниями также являются частое обновление/добавление информации. Также существует возможность работы, с базой данных используя Web-интерфейс.
Физическая модель программы DFD (Контекстная диаграмма). Диаграмма потоков данных описывает модель обмена информации между пользователем и БД (рис. 2.2).
ДиаграммаUSECASE отражает работу, разрабатываемого приложения (рис.2.3.).
ER-диаграмма – диаграмма «сущность связь» (рис.2.4.)
Сайт представляет собой совокупность страниц. Имеется файл, определяющий характеристики сайта, таблицы стилей CSS - style.css, который определяет цвет фона, а также размеры и цвета шрифтов и присутствует на всех страницах сайта.
Главная страница.
Главная страница (П.2) предоставляет пользователю различного рода информацию. С этой страницы пользователь может перейти на страницы просмотра информации, а так же добавить свою информацию. Пользователь может перейти на страницу просмотра зарегистрированных пользователей, оставить о себе информацию. При переходе на каждую страницу выводится соответствующая теме информация.
Каталог статей.
Страница «Каталог статей» предназначена для вывода списка имеющихся в базе статей. Данную страницу могут просматривать любые пользователи. Для получения более подробной информации о выбранном продукте необходимо перейти по ссылке, нажав на наименование выбранной должности. Чтобы перейти на страницу редактирования и удаления продукта пользователю необходимо ввести логин и пароль, далее нужно выбрать статью, которую пользователь с данным логином добавлял и перейти на неё, перейти на неё и нажать на ссылку «Редактирование». После чего откроется форма редактирования, в которой можно изменить введенную ранее информацию, для сохранения информации имеется кнопка «Исправить», при нажатии на которую проверяется правильность заполнения необходимых полей и заносятся исправления в базу.
Пользователи.
Страница «Пользователи» предназначена для вывода списка имеющихся в базе пользователей. Данную страницу могут просматривать любые пользователи сайта. Для получения более подробной информации о заинтересовавшем человеке необходимо перейти по ссылке, нажав на выбранного пользователя. Если пользователь, переходящий по ссылке добавлял о себе информацию ранее, откроется страница с возможностью редактирования и удаления, в противном случае у пользователя такой возможности нет. Чтобы перейти на страницу редактирования и удаления пользователю необходимо ввести логин и пароль и нажать кнопку «Войти», далее нужно выбрать информацию, которую пользователь с данным логином добавлял, перейти на неё и нажать на ссылку «Редактирование». После чего откроется форма редактирования, в которой можно изменить введенную ранее информацию, для сохранения информации имеется кнопка «Исправить», при нажатии на которую проверяется правильность заполнения необходимых полей и заносятся исправления в базу.
Система состоит из различных страниц, которые просматривает пользователь. Все страницы содержат общий заголовок и основную – рабочую часть.
Вывод: Проанализирована предметная область, в ходе которой были разработаны модели страниц.
Рис. 2.1. Модель
Рис. 2.2. DFDдиаграмма
Пользователь
Рис.2.3. USECASE-диаграмма.
Рис.2.4.ER-диаграмма.
2.2 Описание алгоритмов
Рассмотрим основные алгоритмы работы сайта:
Регистрация: Для того чтобы пользователь получил возможность добавления новой статьи и информации о себе, он должен пройти процесс регистрации. После заполнения полей, производится просмотр базы на наличие аналогичной записи (сравнение идет по полю Login), если подобная запись не обнаружена, процесс регистрации продолжается, иначе пользователю выдается соответствующее сообщение.
Авторизация: Для получения доступа к добавлению продукта и информации о себе, пользователь должен ввести свой логин и пароль, указанные им при регистрации. После чего введенные данные проверяются, и если пользователь ввел верные имя и пароль то его логин сохраняется в PHP-сессии.
Продукты: При просмотре продуктов на странице отображаются продукты и ссылка для просмотра полной информации о них. При переходе по ссылке посетитель увидит всю имеющуюся информацию о выбранном продукте области компьютерных игр, если данный пользователь добавлял информацию об этом продукте, появится возможность её редактирования и удаления.
Пользователи: При просмотре личной информации на странице отображается личная информация пользователей и ссылка для просмотра полной информации о них. При переходе по ссылке посетитель увидит всю имеющуюся информацию о выбранном пользователе, если же данный пользователь добавлял о себе информацию, появится возможность его редактирования и удаления.
Выводы:
1. В данном разделе были рассмотрены модели и диаграммы функционирования сайта.
2. Рассмотрены алгоритмы необходимые для создания сайта.
3. ПРОГРАММНАЯ РЕАЛИЗАЦИЯ
3.1. Выбор языка программирования
Приступая к созданию сайта, можно использовать множество различных продуктов. Потребуется выбрать аппаратное обеспечение для Web-сервера, операционную систему, программное обеспечение Web-сервера, систему управления базами данных и язык программирования или создания сценариев. Выбор некоторых из этих компонентов будет зависеть от уже произведенных выборов. Например, не все операционные системы могут работать на любом оборудовании, не все языки создания сценариев могут обеспечить подключение ко всем базам данных и т.д.
При выборе программного средства для реализации проекта необходимо учитывать, что каждый язык программирования имеет свои положительные и отрицательные стороны и может быть использован эффективно только для реализации проектов определенного вида. Учитывая то, что основное требование для системы Интернет-голосования – работа в среде web, будем проводить обзор только тех средств, основным назначением которых является разработка web-приложений.
CGI является наиболее часто используемой сетевой технологией, используемой на стороне сервера. CGI-программа может быть написана почти на любом языке, хотя чаще всего для программирования CGI используется Perl. Веб-серверы, реализующие CGI, действуют как шлюз между запросом пользователя и требуемыми данными. Для этого сначала создается новый процесс, в котором будет выполнятся программа. Потом передается объект, представляющий запрос, и вызывается программа. По окончании работы программы веб-сервер считывает данные, которые она возвратила.
Наиболее крупным недостатком CGI-программирования является то, что оно плохо масштабируется. При каждом получении веб-сервером запроса создается совершенно новый процесс. Каждый процесс состоит из собственного набора переменных окружения, отдельного экземпляра необходимой среды этапа исполнения, экземпляра программы и памяти, выделенной для использования программой. Нетрудно представить себе, что может произойти с сервером, когда одновременно приходит большое количество запросов. Ресурсы сервера подвергаются большому испытанию, что может вызвать его отказ.
ASP (Active Server Pages) – популярная технология Microsoft, предназначенная для разработки эффективных Интернет-приложений и оживления Web-страниц различными динамическими данными, получаемых из самых разнообразных источников. ASP – это все те же VBScript-коды, только они не загружаются в браузер и не интерпретируются им, а выполняются непосредственно на сервере в контексте MS IIS (Microsoft Web Internet Information Server). Раньше необходимо было провести дополнительную инсталляцию специального 10-мегабайтного файла, чтобы модифицировать существующий IIS, входящий в состав операционной системы Windows NT 4.0, но, начиная с Win 2k, поддержка ASP в IIS стала стандартной. Текстовые файлы с расширением .asp – это обычные HTML-файлы с вставленными в них кодами на VBScript. В отличие от обычных кодов в них можно применять многочисленные встроенные методы, которые резко облегчают процесс программирования и используют объектную модель и объектно-ориентированные методы. ASP-поддержка в IIS выстроена в точном соответствии с 3-уровневой моделью клиент-серверных технологий.
JSP (Java Server Pages) – мощное средство для придания Web-страницам гибкого, динамически обновляемого содержания – очень нужный инструмент для разработки систем электронной коммерции. JSP-функции в современном сервере приложений – это повторно используемый код, основанный на последней по времени появления спецификации JSP Sun Microsystems.
Одна из главных особенностей JSP – это разделение бизнес-логики и представления данных на Web-страницах. JSP как раз помогает реализовать некоторые алгоритмы, связанные с данными, представляемыми клиентам, поскольку они помогают осуществить доступ к повторно используемым компонентам, таким как сервлеты, JavaBeans и написанные на Java Web-приложения. JSP так же поддерживает встроенный Java-код внутри Web-страниц.
Perl - интерпретируемый язык, приспособленный для обработки произвольных текстовых файлов, извлечения из них необходимой информации и выдачи сообщений. Perl также удобен для написания различных системных программ. Этот язык прост в использовании, эффективен, но про него трудно сказать, что он элегантен и компактен. Perl сочетает в себе лучшие черты C, shell, sed и awk, поэтому для тех, кто знаком с ними, изучение Perl-а не представляет особого труда. Синтаксис выражений Perl-а близок к синтаксису C. В отличие от большинства утилит ОС UNIX Perl не ставит ограничений на объем обрабатываемых данных и если хватает ресурсов, то весь файл обрабатывается как одна строка. Рекурсия может быть произвольной глубины. Хотя Perl приспособлен для сканирования текстовых файлов, он может обрабатывать так же двоичные данные и создавать .dbm файлы, подобные ассоциативным массивам. Perl позволяет использовать регулярные выражения, создавать объекты, вставлять в программу на С или C++ куски кода на Perl-е, а также позволяет осуществлять доступ к базам данных, в том числе Oracle.РНР
РНР (Personal Home Page Tools - средства для персональной домашней страницы) - это мощный кроссплатформенный набор средств, который располагается на сервере и предназначен для обработки специального кода, встраиваемого в HTML-страницу. Благодаря этому, появляется возможность легко создавать динамические сайты. Файлы, созданные таким образом, хранятся и обрабатываются на сервере, и когда посетитель запрашивает документ с РНР, скрипт обрабатывается не браузером посетителя, как например Java Script, а сервером, и посетителю передаются уже только результаты работы. Точно также работает CGI-программа, написанная на С или Perl. Но в отличии от CGI, код РНР можно встраивать в любое место HTML-странички, что является основным преимуществом по отношению к CGI. А кроме того, сам язык РНР очень прост для изучения, и не требует каких-либо специфических знаний. РНР был создан для работы в сети и превосходен для использования в этой области, однако он не приспособлен для создания больших и сложных проектов. Процессор сценариев РНР хорошо оптимизирован для времени оклика, необходимого Web-приложениям; он может быть включен в состав самого сервера, в результате чего возрастет производительность. Еще одно достоинство РНР – это, что он является «open source».
Учитывая специфику выбранной темы курсовой работы – форум, оптимальным языком программирования для решения этой задачи был выбран РНР, так как он обладает всеми необходимыми качествами для создания подобных приложений и достаточно простой для перехода с других языков программирования.
Выбор системы управления базами данных.
Были рассмотрены следующие СУБД, реализующие реляционную модель базы данных:
mSQL;
MySQL;
Microsoft SQL Server 2000;
Oracle.
Microsoft SQL Server 2000 - Функциональная, гибкая в настройке, масштабируемая реляционная СУБД, разработанная фирмой Microsoft. В основном, эта СУБД ориентирована на корпоративный сектор, как и большинство продуктов Microsoft.
Oracle - СУБД, изначально ориентирована на обработку очень больших объемов данных и большую нагрузку на сервер. В подавляющем большинстве случаев используется только на крупных предприятиях в крупномасштабных проектах автоматизации. Учитывая особенности этой СУБД, далее ее не рассматриваем.
MySQL – это еще одна реализация реляционной СУБД. Основными целями, преследуемыми при разработке которой, выступали скорость и стабильность, что и является основными достоинствами этой СУБД. К достоинствам MySQL можно отнести еще и то, что версия для UNIX распространяется бесплатно, что также немаловажно для российских условий. Кроме того, на сегодняшний день использование СУБД MySQL является стандартом де-факто при разработке Веб-приложений. К недостаткам MySQL можно отнести отсутствие поддержки механизма транзакций и хранимых процедур. Однако, несмотря на это, учитывая специфику разрабатываемого проекта, СУБД MySQL является оптимальным выбором.
mSQL, наверняка, хорош для обучения в области проектирования приложений на основе СУБД. Но применить на деле практически нельзя. Много недостатков и нехватка документации делают данную СУБД непригодной для многих задач.
В результате был выбран продукт MySQL 4.0.15 на платформе Windows 2000 Server.
Выбор web-сервера.
Для реализации проекта был выбран Apache, так как имеет следующие неоспоримые преимущества:
· открытость (исходный код поставляется вместе с инсталляционным пакетом);
· многообразие — существуют версии сервера почти для всех известных операционных систем и платформ;
· простота в конфигурировании (почти все параметры работы сервера задают, изменяя тексты лишь двух файлов);
· высокая скорость обработки запросов;
· легкость конфигурирования и стабильная работа дополнительных модулей (PHP, Perl);
· удобство администрирования;
· безопасность (найденные по всему миру уязвимости тут же закрываться выпущенными патчами (patch)).
Кроме всего выше перечисленного веб сервер Apache признан многими компаниями использующими его как наибольшее надежный и отказоустойчивый веб сервер. MySQL является самой распространенной СУБД для веб приложений и в большинстве случаев используется именно в связке с веб сервером Apache.
Для разработки Web-сайта будет использоваться сервер баз данных MySQL, и язык сценариев PHP.
3.2 Разработка интерфейса
Разработанный сайт состоит из множества страниц, которые может просматривать пользователь, а именно:
· главная;
· информация о сайте;
· каталог файлов;
· регистрация;
· каталог статей;
· блог;
· форум;
· фотоальбомы;
· гостевая книга;
· редактирование статей.
Связь между модулями осуществляется посредством гиперссылок и переменных. Использование каскадных таблиц стилей CSS (файл style.css) позволяет использовать один дизайн для всех web-страницсайта.
На главной странице представлена следующая информация:
· Навигационное меню
· Форма авторизации
· Список последних статей
Главная страница представлена на рисунке 1.1. Все остальные страницы представлены в Приложении 1.
| меню | меню | меню | меню | Аутентификация |
| |||||
меню | | ||||
меню | Основная часть | ||||
меню | |
Рис.3.1. Структура страниц
Рис.3.2. Страница «Главная»
3.3 Программная реализация алгоритмов
Любая страница, запрашиваемая пользователем, выводится как часть страницы Index.php.
<?php
session_start();
include("config.php");
?>
<? include("top.php");?>
<table class="main">
<tr><td class="left"><table class="left1" >
<tr class="avt">
<td><? include("aut.php");?>
</td>
</tr>
<tr class="add"><td><? include("add.php");?></td></tr>
<tr><td></td></tr></table>
<td class="right"><? include("centr.php");?></td></tr>
</table>
<? include("niz.php");?>
Рассмотрим реализацию некоторых алгоритмов сайта:
Авторизация
:
<?php
session_start();
include ("db_connect.php");
if (isset($_GET['go'])) {
$login=$_GET['login'];
$pass=$_GET['Password'];
if($login!='' AND $pass!='') {
$q1 = "select * from user where Log like \"".$login."\"" ;
$q2 = "select * from user where Password like \"".$pass."\"";
$res1=mysql_query($q1);
$res2=mysql_query($q2);
$nr=mysql_num_rows($res1);
$nr1=mysql_num_rows($res2);
if($nr===1 and $nr1===1) {
$r=mysql_fetch_array($res1);
$_SESSION['user']=$r['Log'];
$_SESSION['password']=$r['Password'];
$_SESSION['SID'] = $r['id_user'];
print "<META HTTP-EQUIV='Refresh' CONTENT='0; URL=index.php'>\n";
}
else {echo 'неверый логин или пароль'; }}}?>
Выводы:
1. В данном разделе рассмотрены некоторые алгоритмы Web-сайта.
2. Разработанный сайт магазин состоит из множества страниц, которые может просматривать пользователь.
3. Рассмотрена структура базы данных – атрибуты и сущности.
4. ТЕСТИРОВАНИЕ И ОТЛАДКА
В ходе разработки сайта было проведено несколько изменений. Самым первым изменением стало проектирование страниц как модулей, таким образом, все запрашиваемые страницы выводятся как часть главной страницы Index.php, в которой производится вывод верхней часть с навигационным меню, основной части и нижней части страницы.
В ходе разработки сайта было проведено несколько изменений. Одним из них было изменение в форме регистрации. Были исправлены некоторые недочеты по интерфейсу сайта.
В процессе тестирования рабочей версии проекта были найдены некоторые недоработки и недостатки. При разработке была забыта возможность перехода на страницы редактирования только тех пользователей, который изначально добавляли информацию. Были приняты меры по устранению недостатков.
Выводы:
В данном разделе были рассмотрены некоторые недостатки и недоработкиWeb-сайта, которые впоследствии были исправлены.
ЗАКЛЮЧЕНИЕ
1. При создании сайта была применена древовидная структура, т.е. с главной страницы можно перейти по ссылкам на другие страницы. Сайт разработан на языке программирования - PHP, с помощью среды разработки - Macromedia Dreamweaver.
2. Разработана структура сайта и структура, используемой базы данный. Рассмотрены основные сущности и их атрибуты.
3. Разработан сайт, который предоставляет возможность регистрации, просмотра списка статей, форумов и пользователей. Также предоставляется возможность добавлять, редактировать и удалять статьи и прочие данные, а также личную информацию, которые ранее были добавлены данным пользователем. Зарегистрированные пользователи могут добавлять статьи и личную информацию о себе.
4. Произведено тестирование, в результате которого были найдены некоторые не существенные неполадки и приняты все меры по их устранению.
5. При выполнении данной курсовой работы были изучены:
· язык сценариев PHP;
· СУБД MySQL;
СПИСОК ИСПОЛЬЗОВАННОЙ ЛИТЕРАТУРЫ
1. Томсон Лаура. Разработка Web-приложений на РНР и MySQL: Пер. с англ./Лаура Томсон, Люк Веллинг. — 2-е изд., испр. — СПб: ООО «ДиаСофтЮП», 2003. — 672 с.
2. Химоменко А.Н., Цыганков В.М., Мальцев М.Г. Базы данных: Учебник для высших учебных заведений / Под ред. проф. А.Д. Хомоненко. - СПб.: Корона принт. 2000. - 416 с.
3. Мамаев Е.В. Microsoft® SQL Server 2000.-СПб.: БХВ-Петербург,2001.-1280 с.: ил.
4. Котеров Д. В. Самоучитель PHP 4. — СПб.: БХВ-Петербург, 2001. — 576 с.: ил.
5. Шкарина Л.Н. Методические рекомендации по выполнению научно-исследовательских работ для студентов информационных специальностей университета / Вестник Хакасского гос. ун-та им. Н.Ф. Катанова. Выпуск 4. Серия 1: Информатика. - Абакан: Изд-во ХГУ им. Н.Ф. Катанова. 2001.- 251 с.
6. Модульное программирование на PHP или как написать маленький портал. - www.webscript.ru
7. Сессии в PHP. Алексей Куликов. - www.webscript.ru
8. Технологии разработки программного обеспечения: Учебник для вузов. 3-е изд./С.А. Орлов. – Спб.: Питер, 2004. – 527 с.: ил.
9. http://dreamweaver3.narod.ru/
10. http://dmsdesign.ru/html-edit1.html
11. http://www.metodlab.ru/technology/perl.shtml
12. http://www.domovoy.org/states.php?view=php&name=Php&full=10
ПРИЛОЖЕНИЕ
П.1. Внешний вид сайта
Рис.1. Страница «Главная»
Рис.2. Аутентификация
Рис.3. Страница «Регистрация нового пользователя»
Рис.4. Ошибка регистрации
Рис.6. Страница «статьи»
П.2 Листинги
Index.
php
<?php
session_start();
include("config.php");
?>
<? include("top.php");?>
<table class="main">
<tr><td class="left"><table class="left1" >
<tr class="avt">
<td><? include("aut.php");?>
</td>
</tr>
<tr class="add"><td><? include("add.php");?></td></tr>
<tr><td></td></tr></table>
<td class="right"><? include("centr.php");?></td></tr>
</table>
<? include("niz.php");?>
Config.php
<?
$hostname=localhost;
$hostuser=root;
$dbname=Rabota;
?>
Db_connect.php
<?
include('config.php');
$db=mysql_connect($hostname,$hostuser);
if(!mysql_select_db($dbname,$db))
{
echo "Ошибка не могу подключится к базе";
}?>
top.php
<?php?><html>
<head>
<title>ИщуРаботу.ру</title>
<link href="style.css" rel="stylesheet" type="text/css">
</head>
<body bgcolor="#D0CC93"><center>
<table class="first"><tr><td>
<table class="top" ><tr><td class="logo"><img src="Image/logoo.gif"></td><td><img src="Image/img.gif" align="right"></td></tr></table>
<table class="menu" border="1"><tr><td class="poisk">
<? echo 'Привет '.$_SESSION['user'].'!';
?></td>
<td><a class="menu1" href="index.php">Главная</a></td>
<td><a class="menu1" href="vacansii.php">Вакансии</a></td>
<td><a class="menu1" href="rezum.php">Резюме</a></td>
</table>
aut.php
<?php ?>
<table class="avt"><tr><td colspan="2"><form action="authen.php" method="GET" name="enter">
<font color="#1020F0">Аутентификация<br></td></tr>
<tr><td>Логин</td><td><input name="login" type="text" value="" size="15" ></td></tr>
<tr><td>Пароль</td><td><input name="Password" type="text" value="" size="15" ></td></tr>
<tr><td colspan="2"><input type="submit" name='go' value="Вход"></td></tr>
<tr><td colspan="2"><a class=reg href=reg.php>Регистрация на сайте</a></td></tr>
</table></form>
authen.php
<?php
session_start();
include ("db_connect.php");
if (isset($_GET['go'])) {
$login=$_GET['login'];
$pass=$_GET['Password'];
if($login!='' AND $pass!='') {
$q1 = "select * from user where Log like \"".$login."\"" ;
$q2 = "select * from user where Password like \"".$pass."\"";
$res1=mysql_query($q1);
$res2=mysql_query($q2);
$nr=mysql_num_rows($res1);
$nr1=mysql_num_rows($res2);
if($nr===1 and $nr1===1) {
$r=mysql_fetch_array($res1);
$_SESSION['user']=$r['Log'];
$_SESSION['password']=$r['Password'];
$_SESSION['SID'] = $r['id_user'];
print "<META HTTP-EQUIV='Refresh' CONTENT='0; URL=index.php'>\n";
}
else {echo 'неверый логин или пароль'; }
}}?>
add.php
<?php?>
<table class="add" ><tr><td colspan="2"><font color="#1020F0">Добавить:<br><br></td></tr>
<tr><td ><img src="Image/vac1.gif"></td>
<td><a class="menu1" href=<? if ($_SESSION['user']!='' ) {echo "addv.php";}?>>Вакансию</a></td>
</tr>
<tr><td><img src="Image/ree.gif"></td>
<td><a class="menu1" href=<? if ($_SESSION['user']!='' ) {echo "addr.php";} ?>>Резюме</a></td>
</tr><br><br><br></table>
<table class="add">
<tr><td colspan="2"><a href='search.php' >Поиск вакансии</a></td>
</tr>
<tr><td colspan="2"><a href='searchr.php'>Поиск резюме</a></td>
</tr><br><br><br></table>
addv.php
<?php session_start();?>
<? include("top.php");?>
<table class="main">
<tr><td class="left"><table class="left1" >
<tr class="avt">
<td><? include("aut.php");?></td>
</tr>
<tr class="add"><td><? include("add.php");?></td></tr>
<tr><td></td></tr></table>
<td class="right">
<table class="left1"><tr class="vac"><td>
<form action=addvac.php method="post" name="addvac" id="addvac"><center>
<Table class="reg" border="3" bgcolor="#EFF7B3" >
<tr>
<td><center><br><fontcolor="#1020F0">Заполните следующие поля, чтобы добавить вакансию!!!</font><br><br>
<table width=90%>
<tr><td>Должность<font color="red" size="-2"></font></td>
<td><input name="D" type="text" value="" size="30"><br><br></td>
</tr>
<tr><td>Заработная плата<font color="red" size="-2"></font><br><br></td>
<td><input name="ZP" type="text" value="" size="30"></td>
</tr>
<tr><td>Образование</td>
<td><select name="obr">
<option>Среднее</option>
<option>Среднее специальное</option>
<option>Высшее</option>
</select></td>
</tr>
<tr><td>Опыт работы<font color="red" size="-2"></font><br><br></td>
<td><input name="opit" type="text" value="" size="30"></td>
</tr>
<tr><td>График работы</td>
<td><select name="GR">
</select></td>
</tr>
<tr><td>Возраст:<br><br></td>
<td><input name="Age" type="text" value="" size="3"></td>
</tr>
<tr><td>Контактная информация<br><br></td>
<td><textarea name="KI" cols ='20' rows = '3'></textarea></td></tr></td>
</tr>
<tr><td>Дополнительная информация<br></td>
<td><textarea name="DI" cols ='30' rows = '5'></textarea></td></tr></td>
</tr>
</table><br><br><br>
<input type="submit" name='b1' value="Отправить">
<input type="Reset" name='b2' value="Сбросить">
<br><br></td></tr>
</Table>
<input name="gogogo" type="hidden" id="gogogo" value="fromaddvac">
<input name="LO1" type="hidden" value="<?echo $_SESSION['user']?>">
</form></td></tr></table></td></tr>
</table>
<? include("niz.php");?>
addr.php
<?php session_start();
include("top.php");
?>
<table class="main">
<tr><td class="left"><table class="left1" >
<tr class="avt">
<td><? include("aut.php");?></td>
</tr>
<tr class="add"><td><? include("add.php");?></td></tr>
<tr><td></td></tr></table>
<td class="right">
<table class="left1"><tr class="vac"><td>
<form action="addrez.php" method="post" name="addrez" id="addrez"><center>
<Table class="reg" border="3" bgcolor="#EFF7B3" >
<tr>
<td><center><br><fontcolor="#1020F0">Заполните следующие поля, чтобы добавить продукт!!!</font><br><br>
<table width=90%>
<tr><td>Фамилия<font color="red" size="-2"></font></td>
<td><input name="F" type="text" value="" size="30"><br><br></td>
</tr>
<tr><td>Имя<font color="red" size="-2"></font><br><br></td>
<td><input name="I" type="text" value="" size="30"></td>
</tr>
<tr><td>Отчество<font color="red" size="-2"></font><br><br></td>
<td><input name="O" type="text" value="" size="30"></td>
</tr>
<tr><td>Образование</td>
<td><select name="obr">
<option>Среднее</option>
<option>Среднее специальное</option>
<option>Высшее</option>
</select></td>
</tr>
<tr><td>Должность<font color="red" size="-2"></font><br><br></td>
<td><input name="cpec" type="text" value="" size="30"></td>
</tr>
<tr><td>Стаж работы<font color="red" size="-2"></font><br><br></td>
<td><input name="opit" type="text" value="" size="30"></td>
</tr>
<tr><td>Возраст:<br><br></td>
<td><input name="age" type="text" value="" size="3"></td>
</tr>
<tr><td>Контактная информация<br><br></td>
<td><textarea name="KI" cols ='20' rows = '3'></textarea></td></tr></td>
</tr>
<tr><td>Дополнительная информация<br></td>
<td><textarea name="DI" cols ='30' rows = '5'></textarea></td></tr></td>
</tr>
</table><br><br><br>
<input type="submit" name='b1' value="Отправить">
<input type="Reset" name='b2' value="Сбросить">
<br><br></td></tr>
</Table>
<input name="gogogo" type="hidden" value="fromaddrez">
<input name="LO" type="hidden" value="<?echo $_SESSION['user']?>">
</form></td></tr></table></td></tr>
</table>
<? include("niz.php");?>
addrez.php
<html>
<head>
<title></title>
</head>
<body background="fon2.jpg">
<? include ("db_connect.php");
$F=$_POST["F"];
$I=$_POST["I"];
$O=$_POST["O"];
$obr=$_POST["obr"];
$cpec=$_POST["cpec"];
$opit=$_POST["opit"];
$Age=$_POST["age"];
$KI=$_POST["KI"];
$DI =$_POST["DI"];
$LO=$_POST["LO"];
echo "$go";
echo "$F";
echo "$I";
echo "$O";
echo "$obr";
echo "$cpec";
echo "$opit";
echo "$Age";
echo "$KI";
echo "$DI";
$error=false;
if ($obr == "" or $obr == "" or $KI == "")
{$error=true;
print "<div align=center><font size=3>Ошибка!!!<br>
Заполните пожалуйста все поля и <ahref=index.php>попробуйте еще раз</a></font></div>"; echo 'Привет '.$LO.'!';
}
else { echo 'Привет '.$_SESSION['user'].'!';
$query = "select * from rez where F like \"".$F."\"";
$result=mysql_query($query);
$query="INSERT INTO `rez` ( `id_rez` , `F` ,`I` ,`O` ,`obr` , `cpec` ,`opit` , `Age` , `KI` , `DI`, `Log`)
VALUES ('', '$F', '$I','$O','$obr', '$cpec','$opit', '$Age', '$KI', '$DI', '$LO')";
$result=mysql_query($query);
print "<HTML><HEAD>\n";
print "<META HTTP-EQUIV='Refresh' CONTENT='0; URL=index.php'>\n";
print "</HEAD></HTML>\n";
}?>
</body></html>
addvac.php
<html>
<head>
<title></title>
</head>
<body background="fon2.jpg">
<? include ("db_connect.php");
$D=$_POST["D"];
$ZP=$_POST["ZP"];
$obr=$_POST["obr"];
$opit=$_POST["opit"];
$GR=$_POST["GR"];
$Age=$_POST["Age"];
$KI=$_POST["KI"];
$DI =$_POST["DI"];
$LO1 =$_POST["LO1"];
$d = time();
$data = date('d - F - Y',$d);
echo "$go";
$error=false;
if ($D == "" or $KI == "" )
{$error=true;
print "<div align=center><font size=3>Ошибка!!!<br>
Заполните пожалуйста все поля и <ahref=index.php>попробуйте еще раз</a></font></div>";
}
else {$query = "select * from vacansii where D like \"".$D."\"";
$result=mysql_query($query);
$query="INSERT INTO `vacansii` ( `id_vac` , `D` ,`ZP` ,`obr` , `opit` ,`GR` , `Age` , `KI` , `DI` , `Data`, `Log`)
VALUES ('', '$D', '$ZP','$obr', '$opit','$GR', '$Age', '$KI', '$DI', '$data', '$LO1')";
$result=mysql_query($query);
print "<HTML><HEAD>\n";
print "<META HTTP-EQUIV='Refresh' CONTENT='0; URL=index.php'>\n";
print "</HEAD></HTML>\n";
}?>
</body>
</html>
search.php
<?php session_start();
include("top.php");?>
<table class="main">
<tr><td class="left"><table class="left1" >
<tr class="avt">
<td><? include("aut.php");?>
</td>
</tr>
<tr class="add"><td><? include("add.php");?></td></tr>
<tr><td></td></tr></table>
<td class="right">
<table class="left1" >
<tr><td height="10%" valign="top" >
<center><u><font color="#1020F0"></font></u><br>
<form action="search.php" method="POST" >
<Table >
<tr><td colspan=3><center>Должность<input type='checkbox' name='dol'></td></tr>
<tr><td>Выбрать</td>
<td><select name="d0">
</select></td><td><input type='checkbox' name='d1'></td>
</tr>
<tr><td>Написать</td>
<td><input name="d" type="text" value="" size="10"></td>
<td><input type='checkbox' name='d2'></td></table>
<Table >
<tr><td colspan=3><center>График работы<input type='checkbox' name='gra'></td></tr>
<tr><td colspan=3
</select></td>
</tr>
</table>
<input type="submit" name='submit' value="Найти">
</form></td></tr>
<tr><td valign="top">
<? include ('db_connect.php');
$dol=$_POST['dol'];
$d1=$_POST['d1'];
$d2=$_POST['d2'];
if ($dol=='on')
{if ($d1=='on'){$P=$_POST['d0'];}
else {if ($d2=='on') {$P=$_POST['d'];}};
$s="select * from vacansii where (D='$P')";
$r3=mysql_query($s);
$n3=mysql_num_rows($r3);
echo ": ".$n3;
echo "<center><table border=2 width=100% >";
echo "<tr bgcolor=ffffaa><td width=30%>Должность</td><td>ФИО</td><td width=150>Дата</td></tr>";
while ($myrow=mysql_fetch_array($r3))
{
echo "<tr bgcolor=eeeeee>"; if ($myrow['Log']!==$_SESSION['user']){ $put='vacansii3.php?id_vac';}
else {if ($myrow['Log']==$_SESSION['user']) {$put='vacansii2.php?id_vac';}}
echo "<td width=550><a href='".$put."=".$myrow['id_vac']."'>".$myrow['D']."</td>";
echo "<td>".$myrow['ZP']."</td>";
echo "<td>".$myrow['Data']."</td>";
echo "</tr>";
}
echo "</table></center>";}
else {if ($_POST['gra']=='on')
{$G=$_POST['g0'];}
$s="select * from vacansii where (GR='$G')";
$r3=mysql_query($s);
$n3=mysql_num_rows($r3);
echo "Результатов поиска: ".$n3;
echo "<center><table border=2 width=100% >";
echo "<tr bgcolor=ffffaa><td width=30%>Должность</td><td>Заработная плата</td><td width=150>Дата</td></tr>";
while ($myrow=mysql_fetch_array($r3))
{echo "<tr bgcolor=eeeeee>"; if ($myrow['Log']!==$_SESSION['user']){ $put='vacansii3.php?id_vac';}
else {if ($myrow['Log']==$_SESSION['user']) {$put='vacansii2.php?id_vac';}}
echo "<td width=550><a href='".$put."=".$myrow['id_vac']." '>".$myrow['D']."</td>";
echo "<td>".$myrow['ZP']."</td>";
echo "<td>".$myrow['Data']."</td>";
echo "</tr>"; }
echo "</table></center>";}
echo "</td></td></tr>";
include("niz.php");?>
searchr.php
<?php session_start();
include("top.php");?>
<table class="main">
<tr><td class="left"><table class="left1" >
<tr class="avt">
<td><? include("aut.php");?>
</td> </tr>
<tr class="add"><td><? include("add.php");?></td></tr>
<tr><td></td></tr></table>
<td class="right">
<table class="left1" >
<tr><td height="10%" valign="top" >
<center><u><font color="#1020F0"></font></u><br>
<form action="searchr.php" method="POST" >
<Table >
<tr><td colspan=3><center>Специальность<input type='checkbox' name='cpec'></td></tr>
<tr><td>Выбрать</td>
<td><select name="c0">
</select></td><td><input type='checkbox' name='c1'></td>
</tr>
<tr><td>Написать</td>
<td><input name="c" type="text" value="" size="10"></td>
<td><input type='checkbox' name='c2'></td></table>
<Table >
<tr><td colspan=3><center>Образование<input type='checkbox' name='ob'></td></tr>
<tr><td colspan=3><select name="ob0">
<option>Среднее</option>
<option>Среднее специальное</option>
<option>Высшее</option>
</select></td>
</tr>
</table> <input type="submit" name='submit' value="Найти">
</form></td></tr>
<tr><td valign="top">
<? include ('db_connect.php');
$cpec=$_POST['cpec'];
$c1=$_POST['c1'];
$c2=$_POST['c2'];
if ($cpec=='on')
{if ($c1=='on'){$P=$_POST['c0'];}
else {if ($c2=='on') {$P=$_POST['c'];}};
$s="select * from rez where (cpec='$P')";
$r3=mysql_query($s);
$n3=mysql_num_rows($r3);
echo "Результатов поиска: ".$n3;
echo "<center><table border=2 width=100% >";
echo "<tr bgcolor=ffffaa><td width=50% height=10>Специальность</td><td width=50%>ФИО</td ></tr>";
while ($myrow=mysql_fetch_array($r3))
{
echo "<tr bgcolor=eeeeee>"; if ($myrow['Log']!==$_SESSION['user']){ $put='rezum3.php?id_rez';}
else {if ($myrow['Log']==$_SESSION['user']) {$put='rezum2.php?id_rez';}}
echo "<td width=550><a href='".$put."=".$myrow['id_rez']."'>".$myrow['cpec']."</td>";
echo "<td>".$myrow['F']." ".$myrow['I']." ".$myrow['O']."
</td>";
echo "</tr>";
}
echo "</table></center>";}
else {if ($_POST['ob']=='on')
{$G=$_POST['ob0'];}
$s="select * from rez where (obr='$G')";
$r3=mysql_query($s);
$n3=mysql_num_rows($r3);
echo "Результатов поиска: ".$n3;
echo "<center><table border=2 width=100% >";
echo "<tr bgcolor=ffffaa><td width=50% height=10>Специальность</td><td width=50%>ФИО</td ></tr>";
while ($myrow=mysql_fetch_array($r3))
{
echo "<tr bgcolor=eeeeee>"; if ($myrow['Log']!==$_SESSION['user']){ $put='rezum3.php?id_rez';}
else {if ($myrow['Log']==$_SESSION['user']) {$put='rezum2.php?id_rez';}}
echo "<td width=550><a href='".$put."=".$myrow['id_rez']."'>".$myrow['cpec']."</td>";
echo "<td>".$myrow['F']." ".$myrow['I']." ".$myrow['O']."
</td>";
echo "</tr>";
}
echo "</table></center>";}
echo "</td></td></tr>";
include("niz.php");?>
reg.php
<? include("top.php");?>
<table class="main">
<tr><td class="left"><table class="left1" >
<tr class="avt">
<td><? include("aut.php");?></td>
</tr>
<tr class="add"><td><? include("add.php");?></td></tr>
<tr><td></td></tr></table>
<td class="right">
<table class="left1"><tr class="vac"><td>
<form action=REGIST.PHP method="post" name="Reg" id="Reg">
<Table class="reg" border="3" bgcolor="#EFF7B3" >
<tr>
<td><center><br> Заполните следующие поля, чтобы зарегистрироваться!!!<br><br>
<tablewidth=90%>
<tr><td>Фамилия:<fontcolor="red" size="-2"> *Введите вашу Фамилию</font></td>
<td><input name="F" type="text" value="" size="20"></td>
</tr>
<tr><td>Имя:<font color="red" size="-2"> *Введите ваше Имя</font></td>
<td><input name="I" type="text" value="" size="20"></td>
</tr>
<tr><td>Отчество:<font color="red" size="-2"> *Введите ваше Отчество</font></td>
<td><input name="O" type="text" value="" size="20"></td>
</tr>
<tr><td>Логин:<font color="red" size="-2"></font></td>
<td><input name="Log" type="text" value="" size="20"></td>
</tr>
<tr><td>e-mail:<font color="red" size="-2"> *Введите ваш e-mail</font></td>
<td><input name="Mail" type="text" value="" size="20"></td>
</tr>
<tr><td>Пароль:<font color="red" size="-2"> *Введите пароль</font></td>
<td><input name="Password" type="password" value="" size="20"></td>
</tr>
<tr><td>Повторите пароль:</td>
<td><input name="Password1" type="password" value="" size="20"></td>
</tr>
</table><br><br><br>
<input type="submit" name='submit' value="Отправить">
<input type="Reset" name='b2' value="Сбросить">
<br><br></td></tr>
</Table>
<input name="gogogo" type="hidden" id="gogogo" value="fromadduser">
</form></td></table></td></tr>
</table>
<? include("niz.php");?>
REGIST.php
<? include ("db_connect.php");
$name1=$_POST["F"];
$name2=$_POST["I"];
$name3=$_POST["O"];
$login=$_POST["Log"];
$pass1=$_POST["Password"];
$pass2=$_POST["Password1"];
$mail =$_POST["Mail"];
$error=false;
if ($login == "" or $mail == "" or $pass1=="" or $pass2=="")
{$error=true;
print "<div align=center><font size=3>Ошибка!!!<br>
Заполните пожалуйста все поля и <ahref=Index.php>попробуйте еще раз</a></font></div>";
}
if ($pass1!=$pass2)
{ $error=true;
print "<div align=center><font size=3>Ошибка!!!<br>
Пароль не совпал <ahref=Index.php>попробуйте еще раз</a></font></div>";
}
if ((strlen($pass1)<4) && (strlen($pass1)>0)) {
$error=true;
print "<div align=center><font size=3>Ошибка!!!<br>
Пароль не короче 4-х символов <ahref=Index.php>попробуйте еще раз</a></font></div>";
}
else if (!eregi("^([0-9a-z]([-_.]?[0-9a-z])*@[0-9a-z]([-.]?[0-9a-z])*\\.[a-wyz][a-z](fo|g|l|m|mes|o|op|pa|ro|seum|t|u|v|z)?)$", $mail))
{ $error=true;
print "<div align=center><font size=3>Ошибка!!!<br>
Пожалуйста ведите корректный <b>E-mail</b> адрес и <br>
<a href=Index.php>попробуйте еще раз</a></font></div>";
}
if ($go=="fromadduser") {
if (!$error) {
$query = "select * from user where Log like \"".$login."\"";
$result=mysql_query($query);
$nr=mysql_num_rows($result);
$query1 = "select * from user where mail like \"".$mail."\"";
$result1=mysql_query($query1);
$nr1=mysql_num_rows($result1);
if ($nr>0 or $nr1>0) {$est=true;} else {$est=false;}
if (!$est) {
$query="INSERT INTO `user` ( `id_user` , `F` ,`I` ,`O` , `Log` , `Password` , `mail` )
VALUES ('', '$name1', '$name2','$name3','$login', '$pass1', '$mail')";
$result=mysql_query($query);
}
}
if ($est) $error=true;
if ($error || !$result){
echo "<center>Во время регистрации произошла ошибка<br>";
if ($est) echo "Такой пользователь уже существует. <br>Проверьте логин или e-mail и повторите попытку";
}
else {
// После удачного добавления переходим к
// дальнейшему администрированию гостевой книги
print "<HTML><HEAD>\n";
print "<META HTTP-EQUIV='Refresh' CONTENT='0; URL=Index.php'>\n";
print "</HEAD></HTML>\n";
}}?>
centr.php
<?php session_start();?>
<table class="left1" >
<tr><td height="10%" valign="top" ><font size=6><center>Вакансии дня</font></td></tr>
<tr><td valign="top">
<? include ('db_connect.php');
$d = time();
$data = date('d - F - Y',$d);
$sql = "select * from vacansii where (Data='$data')";
$result=mysql_query($sql);
echo "<center><table border=2 width=100% >";
echo "<tr bgcolor=ffffaa><td width=30%></td><td></td><td width=150>Дата</td></tr>";
while ($myrow=mysql_fetch_array($result))
{
echo "<tr bgcolor=eeeeee>"; if ($myrow['Log']!==$_SESSION['user']){ $put='vacansii3.php?id_vac';}
else {if ($myrow['Log']==$_SESSION['user']) {$put='vacansii2.php?id_vac';}}
echo "<td width=550><a href='".$put."=".$myrow['id_vac']."'>".$myrow['D']."</td>";
echo "<td>".$myrow['ZP']."</td>";
echo "<td>".$myrow['Data']."</td>";
echo "</tr>";
}
echo "</table></center>";
echo "</body>";
?>
</td></table>
niz.php
<?php?>
<table class="niz">
<tr><td>© 2009 The UrbanHome Compani</td></tr>
</table></td></tr></table>
vacansii.php
<?php session_start();?>
<? include("top.php");?>
<table class="main">
<tr><td class="left"><table class="left1" >
<tr class="avt">
<td><? include("aut.php");?></td>
</tr>
<tr class="add"><td><? include("add.php");?></td></tr>
<tr><td></td></tr></table>
<td class="right"><? include("vacansii1.php");?></td></tr>
</table>
<? include("niz.php");?>
vacansii1.php
<?php?>
<table class="left1" >
<tr><td height="10%" valign="top" ><font size=6><center>Вакансии</font></td></tr>
<tr><td valign="top">
<? include ('db_connect.php');
$sql = 'SELECT `vacansii`.`id_vac`, `vacansii`.`D`, `vacansii`.`ZP`, `vacansii`.`obr`, `vacansii`.`opit`,`vacansii`.`GR`, `vacansii`.`Age`, `vacansii`.`KI`, `vacansii`.`DI`, `vacansii`.`Data`, `vacansii`.`Log`'. ' FROM `vacansii` LIMIT 0, 30';
$result=mysql_query($sql);
echo "<center><table border=2 width=100% >";
echo "<tr bgcolor=ffffaa><td width=30%></td><td></td><td width=150>Дата</td></tr>";
while ($myrow=mysql_fetch_array($result))
{
echo "<tr bgcolor=eeeeee>"; if ($myrow['Log']!==$_SESSION['user']){ $put='vacansii3.php?id_vac';}
else {if ($myrow['Log']==$_SESSION['user']) {$put='vacansii2.php?id_vac';}}
echo "<td width=550><a href='".$put."=".$myrow['id_vac']."'>".$myrow['D']."</td>";
echo "<td>".$myrow['ZP']."</td>";
echo "<td>".$myrow['Data']."</td>";
echo "</tr>";
}
echo "</table></center>";
echo "</body>";
?>
</td></table>
vacansii2.php
<?php session_start();?>
<? include("top.php");?>
<table class="main">
<tr><td class="left"><table class="left1" >
<tr class="avt">
<td><? include("aut.php");?></td>
</tr>
<tr class="add"><td><? include("add.php");?></td></tr>
<tr><td></td></tr></table>
<td class="right"><table class="left1">
<tr><td class="vac" valign="top"><font size=5><center></font></td></tr>
<tr><td valign="top">
<? include ('db_connect.php');
$id=$_GET['id_vac'];
$sql = 'SELECT `vacansii`.`id_vac`, `vacansii`.`D`, `vacansii`.`ZP`, `vacansii`.`obr`,`vacansii`.`opit`, `vacansii`.`GR`, `vacansii`.`Age`, `vacansii`.`KI`, `vacansii`.`DI`, `vacansii`.`Data`'. ' FROM `vacansii` WHERE (`vacansii`.`id_vac` ='.$id.')';
$result=mysql_query($sql);
echo "<center><table border=2 width=100% >";
while ($myrow=mysql_fetch_array($result))
{echo "<tr ><td bgcolor=ffffaa height=10>Наименование</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['D']."</td>"; echo "</tr>";
echo "<tr ><td bgcolor=ffffaa height=10>Версия</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['ZP']."</td>"; echo "</tr>";
echo "<tr ><td bgcolor=ffffaa height=10>Годвыпуска</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['obr']."</td>"; echo "</tr>";
echo "<tr ><td bgcolor=ffffaa height=10>Фирмаразработчик</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['opit']."</td>"; echo "</tr>";
echo "<tr ><td bgcolor=ffffaa height=10>Дополнительная информация</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['DI']."</td>"; echo "</tr>";
}
echo "</table></center>";
echo "<tr><td><a href='redactvac.php?id=$id'>Редактировать</a> <a href='delvac.php?id=$id'>Удалить</a></td><td></td></tr>";
echo "</body>";
?>
</td></table>
</td></tr>
</table>
<? include("niz.php");?>
vacansii3.php
<?php session_start();?>
<? include("top.php");?>
<table class="main">
<tr><td class="left"><table class="left1" >
<tr class="avt">
<td><? include("aut.php");?></td>
</tr>
<tr class="add"><td><? include("add.php");?></td></tr>
<tr><td></td></tr></table>
<td class="right"><table class="left1">
<tr><td class="vac" valign="top"><font size=5><center></font></td></tr>
<tr><td valign="top">
<? include ('db_connect.php');
$id=$_GET['id_vac'];
$sql = 'SELECT `vacansii`.`id_vac`, `vacansii`.`D`, `vacansii`.`ZP`, `vacansii`.`obr`,`vacansii`.`opit`, `vacansii`.`GR`, `vacansii`.`Age`, `vacansii`.`KI`, `vacansii`.`DI`, `vacansii`.`Data`'. ' FROM `vacansii` WHERE (`vacansii`.`id_vac` ='.$id.')';
$result=mysql_query($sql);
echo "<center><table border=2 width=100% >";
while ($myrow=mysql_fetch_array($result))
{echo "<tr ><td bgcolor=ffffaa height=10>Фамилия</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['D']."</td>"; echo "</tr>";
echo "<tr ><td bgcolor=ffffaa height=10>Имя</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['ZP']."</td>"; echo "</tr>";
echo "<tr ><td bgcolor=ffffaa height=10>Отчество</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['obr']."</td>"; echo "</tr>";
echo "<tr ><td bgcolor=ffffaa height=10>Стаж работы</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['opit']."</td>"; echo "</tr>";
echo "<tr><td bgcolor=ffffaa height=10>Возраст</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['Age']."</td>"; echo "</tr>";
echo "<tr ><td bgcolor=ffffaa height=10>Контактная информация</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['KI']."</td>"; echo "</tr>";
echo "<tr ><td bgcolor=ffffaa height=10>Дополнительная информация</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['DI']."</td>"; echo "</tr>";
}
echo "</table></center>";
echo "<tr><td>";
echo "</body>";
?>
</td></table>
</td></tr>
</table>
<? include("niz.php");?>
delvac.php
<?php
include ('db_connect.php');
$id=$_GET['id'];
$query = 'DELETE FROM vacansii WHERE (id_vac='.$id.')';
echo $query;
if(mysql_query($query))
{ print "<HTML><HEAD>\n";
print "<META HTTP-EQUIV='Refresh' CONTENT='0; URL=vacansii.php'>\n";
print "</HEAD></HTML>\n";
}
?>
rez.php
<?php session_start();?>
<? include("top.php");?>
<table class="main">
<tr><td class="left"><table class="left1" >
<tr class="avt">
<td><? include("aut.php");?></td>
</tr>
<tr class="add"><td><? include("add.php");?></td></tr>
<tr><td></td></tr></table>
<td class="right"><? include("rezum1.php");?></td></tr>
</table>
<? include("niz.php");?>
rezum1.php
<?php?>
<table class="left1" ><tr><td height="10%" valign="top" ><font size=6><center>Резюме</font></td></tr>
<tr><td valign="top">
<? include ('db_connect.php');
$sql = 'SELECT `rez`.`id_rez`, `rez`.`F`, `rez`.`I`, `rez`.`O`, `rez`.`obr`, `rez`.`cpec`, `rez`.`opit`, `rez`.`Age`, `rez`.`KI`, `rez`.`DI`, `rez`.`Log`'. ' FROM `rez` LIMIT 0, 30';
$result=mysql_query($sql);
echo "<center><table border=1 width=100% >";
echo "<tr bgcolor=ffffaa><td width=50% height=10>Специальность</td><td width=50%>ФИО</td ></tr>";
while ($myrow=mysql_fetch_array($result))
{
echo "<tr bgcolor=eeeeee>"; if ($myrow['Log']!==$_SESSION['user']){ $put='rezum3.php?id_rez';}
else {if ($myrow['Log']==$_SESSION['user']) {$put='rezum2.php?id_rez';}}
echo "<td width=550><a href='".$put."=".$myrow['id_rez']."'>".$myrow['cpec']."</td>";
echo "<td>".$myrow['F']." ".$myrow['I']." ".$myrow['O']."
</td>";
echo "</tr>";
}
echo "</table></center>";
echo "</body>";
?>
</td></tr></table>
rezum2.php
<?php session_start();?>
<? include("top.php");?>
<table class="main">
<tr><td class="left"><table class="left1" >
<tr class="avt">
<td><? include("aut.php");?></td>
</tr>
<tr class="add"><td><? include("add.php");?></td></tr>
<tr><td></td></tr></table>
<td class="right"><table class="left1">
<tr><td class="vac" valign="top"><font size=5><center>Резюме</font></td></tr>
<tr><td valign="top">
<? include ('db_connect.php');
$id=$_GET['id_rez'];
$sql = 'SELECT `rez`.`id_rez`, `rez`.`F`, `rez`.`I`, `rez`.`O`, `rez`.`obr`, `rez`.`cpec`, `rez`.`opit`, `rez`.`Age`, `rez`.`KI`, `rez`.`DI`'. ' FROM `rez` WHERE (`rez`.`id_rez` ='.$id.')';
$result=mysql_query($sql);
echo "<center><table border=1 width=100% >";
while ($myrow=mysql_fetch_array($result))
{echo "<tr ><td bgcolor=ffffaa height=10>Фамилия</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['F']."</td>"; echo "</tr>";
echo "<tr ><td bgcolor=ffffaa height=10>Имя</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['I']."</td>"; echo "</tr>";
echo "<tr ><td bgcolor=ffffaa height=10>Отчество</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['O']."</td>"; echo "</tr>";
echo "<tr ><td bgcolor=ffffaa height=10>Образование</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['obr']."</td>"; echo "</tr>";
echo "<tr><td bgcolor=ffffaa height=10>Специальность</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['cpec']."</td>"; echo "</tr>";
echo "<tr ><td bgcolor=ffffaa height=10>Стаж работы</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['opit']."</td>"; echo "</tr>";
echo "<tr ><td bgcolor=ffffaa height=10>Возраст</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['Age']."</td>"; echo "</tr>";
echo "<tr ><td bgcolor=ffffaa height=10>Контактная информация</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['KI']."</td>"; echo "</tr>";
echo "<tr ><td bgcolor=ffffaa height=10>Дополнительная информация</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['DI']."</td>"; echo "</tr>";
}
echo "</table></center>";
echo "<tr><td><a href='redact.php?id=$id'>Редактировать</a> <a href='del.php?id=$id'>Удалить</a></td><td></td></tr>";
echo "</body>";
?>
</td></table>
</td></tr>
</table>
<? include("niz.php");?>
rezum3.php
<?php session_start();?>
<? include("top.php");?>
<table class="main">
<tr><td class="left"><table class="left1" >
<tr class="avt">
<td><? include("aut.php");?></td>
</tr>
<tr class="add"><td><? include("add.php");?></td></tr>
<tr><td></td></tr></table>
<td class="right"><table class="left1">
<tr><td class="vac" valign="top"><font size=5><center>Резюме</font></td></tr>
<tr><td valign="top">
<? include ('db_connect.php');
$id=$_GET['id_rez'];
$sql = 'SELECT `rez`.`id_rez`, `rez`.`F`, `rez`.`I`, `rez`.`O`, `rez`.`obr`, `rez`.`cpec`, `rez`.`opit`, `rez`.`Age`, `rez`.`KI`, `rez`.`DI`'. ' FROM `rez` WHERE (`rez`.`id_rez` ='.$id.')';
$result=mysql_query($sql);
echo "<center><table border=1 width=100% >";
while ($myrow=mysql_fetch_array($result))
{echo "<tr ><td bgcolor=ffffaa height=10>Фамилия</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['F']."</td>"; echo "</tr>";
echo "<tr ><td bgcolor=ffffaa height=10>Имя</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['I']."</td>"; echo "</tr>";
echo "<tr ><td bgcolor=ffffaa height=10>Отчество</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['O']."</td>"; echo "</tr>";
echo "<tr ><td bgcolor=ffffaa height=10>Образование</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['obr']."</td>"; echo "</tr>";
echo "<tr><td bgcolor=ffffaa height=10>Специальность</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['cpec']."</td>"; echo "</tr>";
echo "<tr ><td bgcolor=ffffaa height=10>Опыт работы</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['opit']."</td>"; echo "</tr>";
echo "<tr ><td bgcolor=ffffaa height=10>Возраст</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['Age']."</td>"; echo "</tr>";
echo "<tr ><td bgcolor=ffffaa height=10>Контактная информация</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['KI']."</td>"; echo "</tr>";
echo "<tr ><td bgcolor=ffffaa height=10>Дополнительная информация</td>";
echo "<td bgcolor=ffffff width=550>".$myrow['DI']."</td>"; echo "</tr>";
}
echo "</table></center>";
echo "<tr><td>";
echo "</body>";?>
</td></table>
</td></tr>
</table>
<? include("niz.php");?>
del.php
<?php
include ('db_connect.php');
$id=$_GET['id'];
$query = 'DELETE FROM vacansii WHERE (id_vac='.$id.')';
echo $query;
if(mysql_query($query))
{ print "<HTML><HEAD>\n";
print "<META HTTP-EQUIV='Refresh' CONTENT='0; URL=vacansii.php'>\n";
print "</HEAD></HTML>\n";
}
?>
redact.php
<? include ('db_connect.php');
$id=$_GET['id'];
$sql = 'SELECT `rez`.`id_rez`, `rez`.`F`, `rez`.`I`, `rez`.`O`, `rez`.`obr`, `rez`.`cpec`, `rez`.`opit`, `rez`.`Age`, `rez`.`KI`, `rez`.`DI`'. ' FROM `rez` WHERE (`rez`.`id_rez` ='.$id.')';
$result=mysql_query($sql);
while ($myrow=mysql_fetch_array($result)) {?>
<form action="redactcom.php" method="POST"><center>
<Table class="reg" border="3" bgcolor="#EFF7B3" >
<tr>
<td><center><br><fontcolor="#1020F0">РедактированиеВашейличнойзаписи</font><br><br>
<table width=90%>
<tr><td>Фамилия<font color="red" size="-2"></font></td>
<td><input name="F" type="text" value="<? echo $myrow['F']; ?>" size="30"><br><br></td>
</tr>
<tr><td>Имя<font color="red" size="-2"></font><br><br></td>
<td><input name="I" type="text" value="<? echo $myrow['I']; ?>" size="30"></td>
</tr>
<tr><td>Отчество<font color="red" size="-2"></font><br><br></td>
<td><input name="O" type="text" value="<? echo $myrow['O']; ?>" size="30"></td>
</tr>
<tr><td>Образование<font color="red" size="-2"></font><br><br></td>
<td><input name="obr" type="text" value="<? echo $myrow['obr']; ?>" size="30"></td>
</tr>
<tr><td>Специальность<font color="red" size="-2"></font><br><br></td>
<td><input name="cpec" type="text" value="<? echo $myrow['cpec']; ?>" size="30"></td>
</tr>
<tr><td>Опыт работы<font color="red" size="-2"></font><br><br></td>
<td><input name="opit" type="text" value=<? echo $myrow['opit']; ?> size="30"></td>
</tr>
<tr><td>Возраст:<br><br></td>
<td><input name="age" type="text" value="<? echo $myrow['Age']; ?>" size="3"></td>
</tr>
<tr><td>Контактная информация<br><br></td>
<td><textarea name="KI" cols ='20' rows = '3'><? echo $myrow['KI']; ?></textarea></td></tr></td>
</tr>
<tr><td>Дополнительная информация<br></td>
<td><textarea name="DI" cols ='30' rows = '5'><? echo $myrow['DI']; ?></textarea></td></tr></td>
</tr>
</table><br><br><br>
<input type="submit" name='redact' value="Исправить">
<input type=hidden name=id_rez value=<?php echo $id; ?>>
<br><br></td></tr>
</Table>
</form><?}?>
</td></table>
</td></tr>
</table>
<? include("niz.php");?>
redactcom.php
<?php
include ('db_connect.php');
$id=$_POST['id_rez'];
$F=$_POST['F'];
$I=$_POST['I'];
$O=$_POST['O'];
$obr=$_POST['obr'];
$cpec=$_POST['cpec'];
$opit=$_POST['opit'];
$age=$_POST['age'];
$KI=$_POST['KI'];
$DI=$_POST['DI'];
$query = "UPDATE `rez` SET `F`='$F', `I`='$I' , `O`='$O', `obr`='$obr', `cpec`='$cpec', `opit`='$opit', `Age`='$age', `KI`='$KI', `DI`='$DI' WHERE (`id_rez`=$id)";
$result=mysql_query($query);
echo $result;
if($result)
{
print "<HTML><HEAD>\n";
print "<META HTTP-EQUIV='Refresh' CONTENT='0; URL=rezum.php'>\n";
print "</HEAD></HTML>\n";
}?>
redactvac.php
<?php session_start();?>
<? include("top.php");?>
<table class="main">
<tr><td class="left"><table class="left1" >
<tr class="avt">
<td><? include("aut.php");?></td>
</tr>
<tr class="add"><td><? include("add.php");?></td></tr>
<tr><td></td></tr></table>
<td class="right"><table class="left1">
<tr><td>
<? include ('db_connect.php');
$id=$_GET['id'];
$sql = 'SELECT `vacansii`.`id_vac`, `vacansii`.`D`, `vacansii`.`ZP`, `vacansii`.`obr`,`vacansii`.`opit`, `vacansii`.`GR`, `vacansii`.`Age`, `vacansii`.`KI`, `vacansii`.`DI`, `vacansii`.`Data`'. ' FROM `vacansii` WHERE (`vacansii`.`id_vac` ='.$id.')';
$result=mysql_query($sql);
while ($myrow=mysql_fetch_array($result)) {?>
<form action="redactvaccom.php" method="POST"><center>
<Table class="reg" border="3" bgcolor="#EFF7B3" >
<tr>
<td><center><br><font color="#1020F0">Редектирование Вашей личнойзаписи</font><br><br>
<table width=90%>
<tr><td>Должность<font color="red" size="-2"></font></td>
<td><input name="D" type="text" value="<? echo $myrow['D']; ?>" size="30"><br><br></td>
</tr>
<tr><td>Заработная плата<font color="red" size="-2"></font><br><br></td>
<td><input name="ZP" type="text" value="<? echo $myrow['ZP']; ?>" size="30"></td>
</tr>
<tr><td>Образование<font color="red" size="-2"></font><br><br></td>
<td><input name="obr" type="text" value="<? echo $myrow['obr']; ?>" size="30"></td>
</tr>
<tr><td>Опыт работы<font color="red" size="-2"></font><br><br></td>
<td><input name="opit" type="text" value="<? echo $myrow['opit']; ?>" size="30"></td>
</tr>
<tr><td>График работы<font color="red" size="-2"></font><br><br></td>
<td><select name="GR">
<option>Полный рабочий день</option>
<option>Неполный рабочий день</option>
<option>Свободный график</option>
</select></td>
</tr>
<tr><td>Возраст:<br><br></td>
<td><input name="Age" type="text" value="<? echo $myrow['Age']; ?>" size="3"></td>
</tr>
<tr><td>Контактная информация<br><br></td>
<td><textarea name="KI" cols ='20' rows = '3'><? echo $myrow['KI']; ?></textarea></td></tr></td>
</tr>
<tr><td>Дополнительная информация<br></td>
<td><textarea name="DI" cols ='30' rows = '5'><? echo $myrow['DI']; ?></textarea></td></tr></td>
</tr>
</table><br><br><br>
<input type="submit" name='redact' value="Исправить">
<input type=hidden name=id_vac value=<?php echo $id; ?>>
<br><br></td></tr>
</Table>
</form>
<?}?>
</td></table>
</td></tr>
</table>
<? include("niz.php");?>
redactvaccom.php
<? include ('db_connect.php');
$id=$_POST['id_vac'];
$D=$_POST['D'];
$ZP=$_POST['ZP'];
$obr=$_POST['obr'];
$opit=$_POST['opit'];
$GR=$_POST['GR'];
$age=$_POST['Age'];
$KI=$_POST['KI'];
$DI=$_POST['DI'];
$d = time();
$data = date('d - F - Y',$d);
echo $data;
echo $D;
echo $ZP;
echo $GR;
$query = "UPDATE `vacansii` SET `D`='$D', `ZP`='$ZP' , `obr`='$obr', `opit`='$opit', `GR`='$GR', `Age`='$age', `KI`='$KI', `DI`='$DI' ,`Data`='$data' WHERE (`id_vac`=$id)";
echo $query;
$result=mysql_query($query);
echo $result;
if($result)
{
print "<HTML><HEAD>\n";
print "<META HTTP-EQUIV='Refresh' CONTENT='0; URL=vacansii.php'>\n";
print "</HEAD></HTML>\n";
}?>
<? include ('db_connect.php');
$id=$_POST['id_rez'];
$F=$_POST['F'];
$I=$_POST['I'];
$O=$_POST['O'];
$obr=$_POST['obr'];
$cpec=$_POST['cpec'];
$opit=$_POST['opit'];
$age=$_POST['age'];
$KI=$_POST['KI'];
$DI=$_POST['DI'];
$query = "UPDATE `rez` SET `F`='$F', `I`='$I' , `O`='$O', `obr`='$obr', `cpec`='$cpec', `opit`='$opit', `Age`='$age', `KI`='$KI', `DI`='$DI' WHERE (`id_rez`=$id)";
$result=mysql_query($query);
echo $result;
if($result)
{ print "<HTML><HEAD>\n";
print "<META HTTP-EQUIV='Refresh' CONTENT='0; URL=rezum.php'>\n";
print "</HEAD></HTML>\n";
}?>