- •Оглавление
- •I. Инструментарий
- •II. Шаблоны проектирования
- •1. Простой
- •2. Шаблонная функция
- •3. Метод буферизации
- •III. Фрэймворк Kohana
- •1. Знакомство с Kohana
- •2. Роутинг
- •7. Взаимодействие модели, контроллера и шаблона
- •8. Создание новых классов и подключение сторонних библиотек
- •9. Конфигурирование
- •10. Языковые файлы
- •11. Системные сообщения
- •12. Хелперы
- •Мы можем использовать любые строковые функции php, добавляя к ним класс utf8
- •13. Этапы создания проекта
- •14. Виджеты
- •Сложные запросы
- •17. Модуль orm
- •Т.Е. Если мы вторым параметромне указываем идендификатор, мы добавляем запись, если указываем – мы обновляем строку с указанным идентификатором.
- •Но если мы попытаемся удалить запись, которой не существует, то увидим сообщение об ошибке. Чтобы избавиться от этой ошибки, есть специальный метод, который проверяет, возвращает ли запрос результат.
- •Если метод возвращает true, то происходит удаление записи.
- •Если таблица userimage связана стаблице user связью belongs_to, то таблица user связана с таблицей userimage связью has_many.
- •19. Использование orm в виджетах
- •20. Модуль Auth
- •21. Модуль Image
- •22. Совместное использование модуля Image и js-скриптов, об-рабатывающих изображения.
- •Далее в контроллер добавим функцию для работы с изображениями.
- •В контроллере произведем вставку изображений в папку и запись в таблицу.
- •Чтобы вывести постраничную навигацию, например, на страницу пользователей, нам сперва нужно узнать общее количество пользователей, которое впоследствии нужно передать в параметр total_items.
- •А вот и сам экшн:
- •Как видно из листинга в шаблон мы передали переменную pagination, в которой будет находиться шаблон вывода ссылок на страницы. Осталось только вывести данную переменную в шаблоне.
- •Если в роуте используются параметры controller, action, directory либо id, то их необходимо передавать в класс pagination в метод route_params().
- •24. Операции crud. Разработка системы администрирования.
- •25. Модуль кэширования
- •В kohana также имеется отдельный модуль cache. Для его подключения необходимо раскомментировать нужную строку в файле bootstrap.Php
- •После подключения модуля необходимо скопировать из папки с модулем конфигурационный файл и переместить его в папку config/ в конфигурационном файле cache.Php имеется несколько групп настроек.
- •Каждая группа настроек работает со своим драйвером для кэширования. В зависимости от выбранного типа настроек, закэшированные файлы будут храниться либо в памяти компьютера, либо в других файлах.
- •28. Многоуровневые комментарии. Алгоритм NestedSets. Модуль orm-mptt
- •29. Модальное окно на ajax
- •30. Парсинг
- •31. Отладка
- •32. Профилирование
- •33. Документация kohana, модуль Userguide
- •34. Модуль Codebench
- •36. Другие модули Kohana
- •37. Состояние проекта
- •38. Дополнительное конфигурирование
- •39. Уязвимость Kohana
- •Установка yii
- •2. Структура yii
- •3. Конфигурирование yii, файл config/main.Php
- •4. Маршрутизация
- •7.Подключение шаблонов
- •8. Полезное.
- •9. Модель. Работа с базой данных.
- •11. Валидация
- •1. Определение класса модели
- •2. Определение правил проверки
- •4. Стандартные правила валидации
- •12. Конструктор форм
- •13. Хелперы форм
- •14. Обработка изображений
- •15. Постраничная навигация и cActiveDataProvider
- •16. Виджеты
- •17. Создание виджета круговой диограммы
- •18. Виджет cMenu
- •19. Хлебные крошки. Виджет cBreadcrumbs
- •20. Виджет cDetailView
- •21. Виджет chml, хелперы html
- •22. Виджет cListView
- •23. Виджет cGridView, таблица администратора
- •25. Модули
- •26. Авторизация
- •27. Контроль доступа на основе ролей
- •V. Краткий обзор и сравнение фрэймворков yii и Kohana
- •VI. Система контроля версий
- •Синхронизация локальных файлов с репозиторием
- •Открытие проекта Mercurial в среде ide
- •Получение файлов из репозитория
- •Импорт файлов в репозиторий
- •Изменение файлов исходного кода
- •Просмотр изменений в редакторе исходного кода
- •Просмотр информации о состоянии файла
- •Метки и условные цвета
- •Ярлыки состояния файлов
- •Окно контроля версий
- •Сравнение редакций файлов
- •Внесение изменений в локальную рабочую копию
- •Переходы между различиями в сравниваемых файлах
- •Изменение критериев просмотра
- •Слияние редакций файлов
- •Фиксация исходных файлов в репозитории
- •Обновление локальных копий
- •Выполнение фиксации
- •Обновление проблем
- •Выгрузка локальных изменений в общий репозиторий
- •Клонирование репозитория Git из GitHub с использованием протокола ssh
- •VI. Обзор рынка
- •VII. Программа курса php для продвинутых
- •Обзор рынка.
- •Php для продвинутых
31. Отладка
В kohana есть специальный класс Debug со следующими методами:
Debug::dump($arr); - входящий параметр – массив либо объект, который показывает их структуру, работает аналогично стандартному var_dump().
Debug::vars($arr1, $arr2); - метод vars более интересен, т.к. может принимть несколько параметров. Также выводит структуру объектов либо массивов, но по умолчанию, заключает их в тэги <pre></pre>, что делает более читабельным и красивым формат вывода.
Debug::source(__FILE__,__LINE__); - показывает содержимое файла (т.е. php код) с нумерацией для каждой строки. С работой данного метода,вероятно, вы уже познакомились. Например, если попытаться вызвать несуществующую страницу, то на экране появится следующая ошибка, сгенерированная данным методом:
Debug::path(Kohana::find_file(‘classes’, ‘kohana’)) – данный метод предназначен для поиска файлов. Например, в этом примере будет искаться файл kohana.php в папке classes.
Debug::trace(); - возвращает последовательность формирования страницы в виде массива строк (поэтому для просмотра необходимо воспользоваться функцией print_r()). Отображает всю текущую трассировку файла.
32. Профилирование
Инструменты профилирования позволяют выводить время выполения экшнов, запросов и др. php-скриптов.
Обратимся к bootstrap.php и убедимся в том, что методы профайлинга включены.
Включение методов профайлинга. Листинг 32.1 |
/** * Initialize Kohana, setting the default options. * * The following options are available: *… * - boolean errors enable or disable error handlin TRUE * - boolean profile enable or disable internal profiling TRUE * - boolean caching enable or disable internal caching FALSE */ Kohana::init(array( 'base_url' => '/kohana/', 'index_file' => false, )); |
Как видно из подсказки, они включены по умолчанию.
Инструмент профилирования подключается из шаблона.
Включение инструмента профилирования в шаблоне. Листинг 32.2 |
<div> <?=View::factory('profiler/stats')?> </div> |
При обновлении страницы шаблона мы увидим общее время выполнения контроллера, минимальное, максимальное, среднее и общее время выполнения каждого запроса:
Кроме этого, если в файле настроек базы данных, у нас будет выставлено значение профайлинга TRUE,
Включение профилирования SQL-запросов. Листинг 32.3 |
return array ( 'default' => array ( 'type' => 'mysql', 'connection' => array( 'hostname' => 'localhost', 'database' => 'kohana', 'username' => 'root', 'password' => "", 'persistent' => FALSE, ), 'table_prefix' => '', 'charset' => 'utf8', 'caching' => FALSE, 'profiling' => TRUE, ), ); |
то мы можем анализировать информацию каждого запроса к базе данных:
И в конце мы увидим общую статистику по времени загрузки данной страницы:
Мы также можем использовать методы профайлинга в контроллерах. Делается это, если нам нужно определить время выполения какого-то участка кода.
Использование профайлинга в контроллере. Листинг 32.4 |
public function action_index() { $bench = Profiler::start('Index','Index'); // Получаем данные из модели $products = Model::factory('text')->all_text(); $content = View::factory('v_center', array( 'products' => $products, )); $this->template->block_center = array($content); Profiler::stop($bench); } |
Как видно из листинга, в метод start передается 2 параметра: первый – это имя группы, в котором мы хотим отобразить информацию об этом участке кода, второй – название данного профайлинга.
