на тему рефераты Информационно-образоательный портал
Рефераты, курсовые, дипломы, научные работы,
на тему рефераты
на тему рефераты
МЕНЮ|
на тему рефераты
поиск
Создание инструментального средства для организации социологических опросов
p align="left">· имеется большой арсенал функций для работы со строками;

· работа с регулярными выражениями PCRE выполняется функциями с префиксом preg_

· работа с базами данных осуществляется посредством модулей php5-mysql для MySQL, php5-pgsql для PostgreSQL и др. Функции этих модулей позволяют открывать соединение, выполнять SQL-запросы к СУБД, получать данные в удобной для обработки виде и т.д. В серьезных проектах рекомендуется использовать модули абстракции базы данных и объектно-реляционные проекции (ORM);

· для PHP разработаны средства шаблонирования web-страниц, позволяющие эффективно разделить представление от модели в духе MVC, например Smarty[4];

3 СТРУКТУРА БАЗЫ ДАННЫХ

Таблица `anketa`:- Предназначена для хранения параметров анкет

`idank` int(11) NOT NULL auto_increment,

Унифицированный номер анкеты. Используется как PK, не может быть не заполнено, автоматическое увеличение поля, целочисленное.

`title` varchar(100) NOT NULL default '',

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

`votes` int(11) NOT NULL default '0',

Поле, содержащее количество ответов на анкеты пользователей, не может быть не заполнено, по умолчанию значение 0, целочисленное.

Таблица `answer`: - Таблица предназначена для хранения ответов пользователя на анкеты.

`id` int(11) NOT NULL auto_increment,

Унифицированный номер ответа пользователя на анкету. Используется как PK, не может быть не заполнено, автоматическое увеличение поля, целочисленное.

`iduser` int(11) NOT NULL default '0',

Унифицированный номер пользователя используется как FK к таблице `users`, не может быть не заполнено, по умолчанию значение 0, целочисленное.

`idank` int(11) NOT NULL default '0',

Унифицированный номер анкеты используется как FK к таблице `ankets`, не может быть не заполнено, по умолчанию значение 0, целочисленное.

`idquest` int(11) NOT NULL defa-ult '0',

Унифицированный номер вопроса (для формирования анкет) используется как FK к таблице `quest`, не может быть не заполнено, по умолчанию значение 0, целочисленное.

`answer` varchar(100) NOT NULL default '0',

Записывается текст самого ответа, не может быть не заполнено, по умолчанию значение 0, символьное(100).

Таблица `quest`:-Предназначена для хранения вопросов для анкет.

`id` int(11) NOT NULL auto_increment,

Унифицированный номер вопроса (для формирования анкет) . Используется как PK.

`idank` int(4) NOT NULL default '0', ИД анкеты

Унифицированный номер анкеты используется как FK к таблице `ankets`, не может быть не заполнено, по умолчанию значение 0, целочисленное.

`text` text NOT NULL, текст вопроса. Содержит текст вопроса, не может быть не заполнено, текстовое.

Таблица `users`: -Предназначена для хранения данных пользователей.

`id` int(11) NOT NULL auto_increment,

Унифицированный номер пользователя. Используется как PK.

`name` text NOT NULL,

Содержит Логин пользователя, не может быть не заполнено, текстовое.

`pass` text NOT NULL,

Содержит пароль пользователя, не может быть не заполнено, текстовое.

`type` boolean NOT NULL default '0',

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

4 Структура приложения

Приложение состоит из следующих 8 файлов:

1. ankets_manager.php

Форма управления администратора, администрирование анкет, создание сохранение, правка. Под каждое действие рисуется отдельная форма. Для редактирования одна, для панели администратора другая.

2. answer.php

Работа с ответами и с базой. Реализует функцию администратора для проверки ответов конкретных пользователей на конкретную анкету. Так же реализует счетчик, для подсчета количества ответов на анкету.

3. form.php

Прорисовка форм. Производит sql выборки из таблицы ank по её ID номеру и многое другое.

4. function.php

Реализованы функции по работе с сессиями, подключение к базе. Удаление пользователя, добавление, и остальные функции.

5. index.php

Начальная страница, создает начальную форму авторизации, создает сессию, рисует форму.

6. register.php

Реализация регистрации. Создает форма регистрации пользователя, используются функции для её обработки.

7. result_view.php

Форматирование и вывод результатов.

8. users_manager.php

Редактирование добавление записями пользователей.

Примерная работа приложения отражена на рис. 4.1, который приведен ниже.

Рис. 4.1 Структура работы приложения

5 Описание интерфейса и отчетных форм

Формы в приложении:

1. Форма для регистрации будет отражена на рис. 5.1.

Рис. 5.1 Форма регистрации

2. Форма для авторизации будет отражена на рис. 5.2.

Рис. 5.2 Форма регистрации

3. Форма редактирования личных данных пользователя отражена на рис. 5.3.

Рис 5.3 Форма редактирования личных данных пользователя

4. Форма для добавления изменения и удаления анкет отражена на рис. 5.4

Рис 5.4 Форма для добавления изменения и удаления анкет

Интерфейс создается динамически в зависимости от того, какую форму выбрал пользователь. Для построения интерфейса использовались элементы управления и теги HTML.

5. Форма редактирования анкеты

Рис. 5.5 Форма редактирования анкеты

6. Форма отчетности

Рис. 5.6 Форма отчетности

6 Программная реализация

Язык программирования - php. Хранилище данных - база MYSQL. Программа используется для анкетирования пользователей, управления анкетами, создания своих анкет.

В программе реализована авторизация. Клиент может быть пользователем и может быть администратором. В зависимости от того, кем он авторизовался, ему представляется соответствующая форма с различными возможностями.

Возможности пользователя:

· изменения личных данных

· прохождения анкетирования.

Возможности администратора:

· Добавление изменение или удаления анкет

· редактирование структуры самих анкет

· редактирование пользователей

Данные записываются и извлекаются из базы с помощью SQL - запросов.

Для того чтобы знать кто на данный момент находится на странице пользователь или администратор, чтобы санкционировать доступ к формам, используется механизм сессий.

Для реализации интерфейса используются стандартные элементы управления и теги HTML.

Основные функции приложения и их описание

· function admin_menu() Реализация панели администратора

· function admin_sess_beg() Работает для реализации функций администратора, записывает в массив сессий что пользователь является администратором

· function apply_change($name, $pass) Исполняет изменение пароля и имени (для редактирования паролей). Принимает название пользователя и его пароль.

· function check_sess() Проверка текущей записи в массиве сессий

· function check_user($name,$pass) Проверка на наличие данного пользователя в базе. Принимает название пользователя и его пароль.

· function html_footer() Дополняет страницу информацией снизу.

· function html_head() Динамический вывод заголовка для каждой страницы

· function Print_ank() Создает HTML код самой анкеты

· function show_my_body() создает ссылки для панели администратора

· function show_quest($quest,$i) Формирует вывод вопросов на конкретную анкету. Принимает текст вопроса и его ID номер.

· function show_text_quest($quest) Записывает в массив текущий вопрос. Принимает текст вопроса.

· function showuser($name) Выборка на пользователя по его имени.

· Принимает имя пользователя.

· function user_sess_beg() Записывает в массив сессий значение того, что вошел пользователь.

· function EditAnk($ankID) Реализует возможность редактирования анкет. Принимает ID номер анкеты.

· function ListAnk() Выборка на список анкет.

· function NewAnk() Реализует функцию создания анкет.

7 Руководство пользователя

Для регистрации требуется перейти по ссылке.

Будет форма с 3 полями в 1 поле надо ввести имя, во 2 пароль, в 3 подтверждение пароля.

Форма регистрации отражена на рисунке 7.1.

Рис 7.1 Форма регистрации

Для подтверждения информации нажмите кнопку.

Совершится переход на главную страницу, где следует ввести ваш зарегистрированный логин и пароль.

Если вы авторизуетесь как пользователь, вам следует выбрать любую анкету и нажать на её называние.

Требуется заполнить анкету, после чего нажмите на кнопку для её сохранения. Пользователь может пройти анкету одного типа один раз.

Для авторизации как администратор вам следует перейти к панели администратора нажатием на ссылку, для авторизации нужно проделать те же действия как и обычному пользователю.

На Рис. 7.2 отражена панель администратора.

Рис. 7.2. Панель администратора.

После авторизации вы увидите форму, на которой вы можете изменять имя и пароль пользователей.

Так же есть возможность редактировать анкеты, то есть удалять изменять и добавлять новые. Чтобы сделать это нажимайте на соответствующие кнопки.

7.3 Форма управления пользователями

После добавления или изменения анкеты нажмите на кнопку, чтобы изменения вступили в силу.

ЗАКЛЮЧЕНИЕ

PHP (читается как пи-эйч-пи) - один из популярнейших языков программирования в сети Интернет. Дословно аббревиатура переводиться как Personal Home Page[5].

PHP практикует в разных направлениях, но больше его используют в глобальной сети Интернет. Главной ее задачей становится создать динамическую Web-страницу. Яркими примерами можно взять чаты, форумы, гостевые книги, доски объявлений, средства голосования, почты, поиска, в общем, при помощи этого языка можно сделать все, что сейчас можно увидеть в сети[6].

В процессе выполнения курсового проекта, были выполнены следующие задачи:

· Постановка задачи;

· Обоснование выбранных технических средств и программного обеспечения (системного и средств разработки);

· Структура базы данных;

· Структура приложения;

· Описание интерфейса и отчетных форм;

· Программная реализация;

· Руководство пользователя;

· Реализация приложения.

В процессе выполнения курсового проекта были сделаны следующие выводы:

· Для реализации системы авторизации следует использовать механизм сессий.

· Хранения данных регистраций и анкет следует осуществлять в базе данных MYSQL

· HTML-страницы следует строить с помощью таблиц, для последующего удобного форматирования.

Список используемых источников

1.
Кузнецов Максим, Симдянов Игорь Объектно-ориентированное программирование на PHP. -- Спб.: «БХВ-Петербург», 2007. -- С. 608. -- ISBN 978-5-9775-0142-2

2. Кристиан Уэнц PHP. Карманный справочник = PHP Phrasebook. -- М.: «Вильямс», 2007. -- С. 384. -- ISBN 0-672-32817-8

3. Эд Леки-Томпсон, Алек Коув, Стивен Новицки, Хьяо Айде-Гудман PHP 5 для профессионалов = Professional PHP 5. -- М.: «Диалектика», 2006. -- С. 608. -- ISBN 0-7645-7282-2

4. Кузнецов Максим, Симдянов Игорь Самоучитель PHP 5. -- 2-е изд., перераб. и доп.. -- Спб.: «БХВ-Петербург», 2006. -- С. 608. -- ISBN 5-94157-884-9

5. Кузнецов Максим, Симдянов Игорь, Голышев Сергей PHP 5. Практика создания Web-сайтов. -- Спб.: «БХВ-Петербург», 2005. -- С. 960. -- ISBN 5-94157-552-1

6. Кузнецов Максим, Симдянов Игорь Головоломки на PHP для хакера. -- Спб.: «БХВ-Петербург», 2006. -- С. 464. -- ISBN 5-94157-837-7

7. Кузнецов Максим, Симдянов Игорь, Голышев Сергей PHP 5 на примерах. -- Спб.: «БХВ-Петербург», 2005. -- С. 576. -- ISBN 5-94157-670-6

8. Дмитрий Котеров, Алексей Костарев PHP. В подлиннике. -- Спб.: «БХВ-Петербург», 2005. -- С. 1120. -- ISBN 5-94157-245-Х

приложение 1

Разработанная анкета

Рис 1.1 Форма добавления новой анкеты

приложение 2

Схема базы данных

Рис 2.1 Схема базы данных

Названия с пометкой T - это название таблиц, названия с пометкой PK - первичный ключ. База данных состоит из 4 таблиц. Связями указаны поля взаимодействия с первичных ключей с остальными полями.

приложение 3

Листинг программных модулей

Function.php

<?php

$db_host = "localhost";

$db_user = "root";

$db_pass = "";

$db_name = "sql";

$rezult = @mysql_connect($db_host,$db_user,$db_pass);

if(!$rezult)

die('Ошибка соединение с БД');

$rez = @mysql_select_db($db_name);

if(!$rezult)

die('База данных не найдена');

function user_sess_beg() {

global $CURRENT_USER;

$_SESSION['name']=$_REQUEST['name'];

$_SESSION['user']=true;

$_SESSION['check']=md5(session_id().$_REQUEST['name'].$_REQUEST['pass']);

$CURRENT_USER = htmlspecialchars($_SESSION['name']);

}

function admin_sess_beg(){

global $CURRENT_USER;

$_SESSION['admin']=md5("Admin"."pass");

$_SESSION['name'] = "Ann & Katya";

$CURRENT_USER = "Ann & Katya";

}

function check_user($name,$pass){

Страницы: 1, 2, 3



© 2003-2013
Рефераты бесплатно, курсовые, рефераты биология, большая бибилиотека рефератов, дипломы, научные работы, рефераты право, рефераты, рефераты скачать, рефераты литература, курсовые работы, реферат, доклады, рефераты медицина, рефераты на тему, сочинения, реферат бесплатно, рефераты авиация, рефераты психология, рефераты математика, рефераты кулинария, рефераты логистика, рефераты анатомия, рефераты маркетинг, рефераты релиния, рефераты социология, рефераты менеджемент.