Разработка информационного web-сайта на основе системы «1С-Битрикс: Управление сайтом»

Автор работы: Пользователь скрыл имя, 29 Апреля 2014 в 17:16, дипломная работа

Краткое описание

Web-приложение – клиент-серверное приложение, в котором сервером выступает web-сервер, клиентом программа или устройство, способное получить доступ к web-серверу. Логика web-приложения распределена между сервером и клиентом, хранение данных осуществляется преимущественно на сервере, обмен информацией происходит по сети.
Web - сервер — это сервер, принимающий HTTP-запросы от клиентов, обычно веб-браузеров, и выдающий им HTTP-ответы, обычно вместе с HTML-страницей, изображением, файлом, медиа-потоком или другими данными.
CMS (Content management system) – компьютерная система или программа, используемая для обеспечения и организации совместного процесса создания, редактирования и управления текстовыми и мультимедиа документами.

Содержание

Обозначения и сокращения 6
Определения 7
Введение 9
1. Описание основных используемых технологий и языков программирования 10
1.1. Общие сведения 10
1.2. Язык программирования PHP 10
1.3. Web-сервер Apache 11
1.4. СУБД MySQL 12
1.5. Язык программирования JavaScript 12
1.6. Технология AJAX 13
1.7. Таблица стилей CSS 14
1.8. Общая схема работы web-приложения 14
2. Описание системы «1С – Битрикс: Управление сайтом» 16
2.1. Общие сведения 16
2.2. Преимущества и недостатки системы 16
2.3. Целесообразность использования системы 18
2.4. Сравнение с другими системами 19
3. Описание API системы «1С – Битрикс: Управление сайтом» 21
3.1. Общие сведения 21
3.2. API модуля «Главный модуль» 21
3.3. API модуля «Информационные блоки» 23
4. Формирование требований к сценариям работы web-приложения 26
4.1. Общие сведения 26
4.2. Список требований 26
5. Диаграмма информационных блоков 29
5.1. Общие сведения 29
5.2. ER – диаграмма данных web-приложения 29
5.3. Определение информационных блоков 31
6. Описание программных компонентов 34
6.1. Создание общей структуры страниц web-приложения 34
6.2. Реализация структуры страниц web-приложения, физическая структура 36
6.3. Список программных компонентов 39
6.3.1. Компонент «Список всех игр» 39
6.3.2. Компонент «Список новых и выходящих игр» 40
6.3.3. Компонент «Список лучших игр» 42
6.3.4. Компонент «Список 100 лучших игр» 43
6.3.5. Компонент «Фильтр по играм» 44
6.3.6. Компонент «Поиск по играм» 45
6.3.7. Компонент «Автоподсказки в поиске» 46
6.3.8. Компонент «Список обзоров к игре» 47
6.3.9. Компонент «Детальная страница игры» 48
6.3.10. Компонент «Форма поиска» 48
6.3.11. Компонент «Страница разработчика игры» 49
6.3.12. Компонент «Список лучших игр за год» 50
6.4. Диаграмма связей между страницами web-приложения и компонентами 51
6.5. Особенности реализации сценариев работы web-приложения. 51
6.5.1. Общие сведения 51
6.5.2. Сохранение состояния страниц при использовании AJAX – запросов 52
6.5.3. Обработка событий панели управления. 55
7. Резервное копирование данных web-приложения. Система управления версиями 59
7.1. Общие сведения 59
7.2. Реализация резервного копирования 59
7.3. Система управления версиями 62
7.3.1. Описание системы Subversion 62
7.3.2. Настройка Subversion для работы с web-приложением 64
8. Нагрузочное тестирование 69
8.1. Общие сведения 69
8.2. Техника проведения нагрузочного тестирования 69
8.3. Оценка результатов тестирования 71
Заключение 76
Список использованных источников 77
Приложение A. Принцип работы системы «1С – Битрикс: Управление сайтом» 78
А.1. Общие сведения 78
А.2. Модульная структура системы 78
А.2.1. Главный модуль 79
А.2.2. Модуль «Управление структурой» 79
А.2.3. Модуль «Информационные блоки» 80
А.3. Компоненты 81
А.3.1. Общие сведения 81
А.3.2. Файловая структура компонента 81
А.3.3. Схема обмена данными между файлами компонента 85
А.3.4. Публичный раздел системы 87
А.3.4.1. Порядок загрузки страницы web-приложения 87
А.3.4.2. Подключение модулей системы 87
А.3.4.3. Подключение шаблонов web-приложения 88
А.3.4.4. Подключение компонентов web-приложения 88
Приложение Б. Требования заказчика к работе web-приложения и дизайн-концепция 90
Приложение В. Исходные коды программных компонентов 95
В.1. Компонент games.calendar 95
В.2. Компонент games.raiting 99
В.3. Компонент games.filter 102
В.4. Компонент games.search 113
В.5. Компонент games.detail 117
В.6. Компонент search_autocomplete 121
В.7. Компонент reviews.list 126

Прикрепленные файлы: 1 файл

СОЗДАНИЕ САЙТА.doc

— 1.87 Мб (Скачать документ)

    }

    if(empty($arParams["IBLOCK_ID"])){

        $arParams["IBLOCK_ID"] = IB_GAMES_PC;

    }

    $arParams["COUNT"] = intval($arParams["COUNT"]);

    if($arParams["COUNT"] <= 0){

        $arParams["COUNT"] = 10;

    }

    if(strlen($arParams["SORT_BY1"]) <= 0){

        $arParams["SORT_BY1"] = "ID";

    }

    if($arParams["SORT_ORDER1"] != "DESC"){

        $arParams["SORT_ORDER1"] = "ASC";

    }

    if(strlen($arParams["SORT_BY2"]) <= 0){

        $arParams["SORT_BY2"] = "NAME";

    }

    if($arParams["SORT_ORDER2"] != "DESC"){

        $arParams["SORT_ORDER2"] = "ASC";

    }

    if(empty($arParams["DATE_REL_RUS_PROPERTY_CODE"])){

        $arParams["DATE_REL_RUS_PROPERTY_CODE"] = "DATES_DATE_REL_RUS";

    }

    if(empty($arParams["MAIN_METAMARK_PROPERTY_CODE"])){

        $arParams["MAIN_METAMARK_PROPERTY_CODE"] = "MAIN_METAMARK";

    }

    if(empty($arParams["FILTER_VARIABLE_NAME"])){

        $arParams["FILTER_VARIABLE_NAME"] = "arrFilter";

    }

    $arParams["DETAIL_DATE_MIN"] = intval($arParams["DETAIL_DATE_MIN"]);

    if($arParams["DETAIL_DATE_MIN"] <= 0){

        $arParams["DETAIL_DATE_MIN"] = 1997;

    }

    $arParams["DETAIL_DATE_MAX"] = intval($arParams["DETAIL_DATE_MAX"]);

    if($arParams["DETAIL_DATE_MAX"] <= 0){

        $arParams["DETAIL_DATE_MAX"] = date("Y");

    }

    $period_list = $arParams["PERIOD_LIST"];

    $arParams["PERIOD_LIST"] = array();

    //проверка вариантов  интервалов времени

    $j = 1;

    foreach($period_list as $key => $value){

        if(!$matches = get_parts_reg($value, "/\[(\-|\+*)(\d+)(.)\]/i")){

            continue;

        }

        $text = $matches["text"];

        $matches = $matches["matches"];

        //print_r($matches);

        $matches[3] = mb_strtolower($matches[3], LANG_CHARSET);

        if($matches[3] != "m" && $matches[3] != "d" && $matches[3] != "y"){

            continue;

        }

        $arParams["PERIOD_LIST"][$j] = array(

          "TITLE" => $text,

          "TYPE" => $matches[3],

          "VALUE" => ($matches[1] == "-" ? (-1)*intval($matches[2]) : intval($matches[2]))

        );

        $j++;

    }

    //проверка метаоценок

    $mark_list = $arParams["MARKS_LIST"];

    $arParams["MARKS_LIST"] = array();

    $j = 1;

    foreach($mark_list as $key => $value){

        if(!$matches = get_parts_reg($value, "/\[\b(\d+)\]\[(.+)\]/i")){

            continue;

        }

        $text = $matches["text"];

        $matches = $matches["matches"];

        $arParams["MARKS_LIST"][$j] = array(

          "TITLE" => $text,

          "VALUE" => intval($matches[1]),

          "COLOR" => $matches[2]

        );

        $j++;

    }

    $arResult = array(

      "GENRES" => array(),

      "PLATFORMS" => array(),

      "POST_VARIABLES" => array()

    );

    /******

    Обработка отправленной  формы фильтра и формирование  выходного массива с параметрами фильтрации

    ******/

    if(isset($_REQUEST["filter"]) || isset($_REQUEST["with_no_script"])){

        //временный массив для фильтра

        $filter_var = array();

        //предварительная  обработка данных пришедшего  запроса

        $_REQUEST["marki"] = intval($_REQUEST["marki"]);

        $_REQUEST["datei"] = intval($_REQUEST["datei"]);

        $_REQUEST["platform"] = trim($_REQUEST["platform"]);

        $_REQUEST["genre"] = trim(htmlspecialchars(urldecode($_REQUEST["genre"])));

        $_REQUEST["markv"] = floatval($_REQUEST["markv"]);

        $_REQUEST["daterange"] = intval($_REQUEST["daterange"]);

        $_REQUEST["dfrom"] = trim($_REQUEST["dfrom"]);

        $_REQUEST["dto"] = trim($_REQUEST["dto"]);

        $_REQUEST["alpha"] = mb_substr(trim(urldecode($_REQUEST["alpha"])), 0, 1, LANG_CHARSET);

        if(!empty($_REQUEST["platform"])){

            $filter_var["SECTION_CODE"] = $_REQUEST["platform"];

        }

        if(strlen($_REQUEST["alpha"]) > 0){

            if($_REQUEST["alpha"] == "1"){

                $numbs = array();

                for($i=0; $i <= 9; $i++){

                    $numbs[] = $i."%";

                }

                //$filter_var["NAME"] = implode("|", $numbs);

                $filter_var[">NAME"] = "-1%";

                $filter_var["<=NAME"] = "9%";

            }

            else{

                $filter_var["NAME"] = $_REQUEST["alpha"]."%";

            }

            //echo $filter_var["NAME"];

        }

        if(eregi("^[0-9]{4}$", $_REQUEST["dfrom"])){

            $f_date_from = "year";

            $_REQUEST["dfrom"] = intval($_REQUEST["dfrom"]);

            if($_REQUEST["dfrom"] <= 0){

                $_REQUEST["dfrom"] = $arParams["DETAIL_DATE_MIN"];

            }

        }

        else{

            if(strtotime($_REQUEST["dfrom"]) <= 0){

                $_REQUEST["daterange"] = 0;

            }

        }

        if(eregi("^[0-9]{4}$", $_REQUEST["dto"])){

            $f_date_to = "year";

            if($_REQUEST["dto"] <= 0){

               $_REQUEST["dto"] = $arParams["DETAIL_DATE_MAX"];

            }

        }

        else{

            if(strtotime($_REQUEST["dto"]) <= 0){

                $_REQUEST["daterange"] = 0;

            }

        }

        //выьранный  в списке временной интервал

        $datei_key = $_REQUEST["datei"];

        if($_REQUEST["daterange"] == 1){

            $datei_key = 0;

            $date_from = $_REQUEST["dfrom"];

            $date_to = $_REQUEST["dto"];

            if($f_date_from == "year" && $f_date_to == "year" && $date_to < $date_from){

                $date_to = $date_from;

            }

            if($f_date_from == "year"){

                $filter_var[">=PROPERTY_".$arParams["DATE_REL_RUS_PROPERTY_CODE"]] = date("Y-m-d", strtotime("01.01.".$date_from));

            }

            else{

                $filter_var[">=PROPERTY_".$arParams["DATE_REL_RUS_PROPERTY_CODE"]] = date("Y-m-d", strtotime($date_from));

            }

            if($f_date_to == "year"){

                $filter_var["<=PROPERTY_".$arParams["DATE_REL_RUS_PROPERTY_CODE"]] = date("Y-m-d", strtotime("31.12.".$date_to));

            }

            else{

                $filter_var["<=PROPERTY_".$arParams["DATE_REL_RUS_PROPERTY_CODE"]] = date("Y-m-d", strtotime($date_to));

            }

            $arResult["POST_VARIABLES"]["datei"] = $date_from." - ".$date_to;

        }

        if($datei_key > 0){

            //обрабатываем пришедший интервал, в зависимости от типа задавая  параметры фильтру

            $filter_var["<=PROPERTY_".$arParams["DATE_REL_RUS_PROPERTY_CODE"]] = date("Y-m-d");

            $datei_type = $arParams["PERIOD_LIST"][$datei_key]["TYPE"];

            $datei_value = intval($arParams["PERIOD_LIST"][$datei_key]["VALUE"]);

            switch($datei_type)

            {

                //обрабатываем день

                case "d":

                    //добавляем к текущей дате  наше число со знаком минус

                    $interval_from = AddToTimestamp(array("DD" => -$datei_value));

                break;

                //месяц

                case "m":

                    $interval_from = AddToTimestamp(array("MM" => -$datei_value));

                break;

                //год

                case "y":

                    $interval_from = AddToTimestamp(array("YYYY" => -$datei_value));

                break;

                default:

                break;

            }

            if($datei_value > 0){

                $filter_var[">=PROPERTY_".$arParams["DATE_REL_RUS_PROPERTY_CODE"]] = date("Y-m-d", $interval_from);

            }

            else{

                $filter_var["<=PROPERTY_".$arParams["DATE_REL_RUS_PROPERTY_CODE"]] = date("Y-m-d", $interval_from);

            }

            $arResult["POST_VARIABLES"]["datei"] = $arParams["PERIOD_LIST"][$datei_key]["TITLE"];

        }

        //формируем в отдельном блоке фильтр по месяцам, если запрос пришел оттуда

        $_REQUEST["month"] = intval($_REQUEST["month"]);

        $_REQUEST["year"] = intval($_REQUEST["year"]);

        if($_REQUEST["month"] > 0 && $_REQUEST["year"] > 0){

            $top_day = get_max_day($_REQUEST["month"], $_REQUEST["year"]);

    


Информация о работе Разработка информационного web-сайта на основе системы «1С-Битрикс: Управление сайтом»