- •Оглавление
- •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 для продвинутых
14. Обработка изображений
Для того, чтобы форма могла отдавать файлы на сервер, элемент form должен содержать атрибут enctype
-
Добавление атрибута enctype к форме. Листинг 14.1
<? $form=$this->beginWidget('CActiveForm', array(
'id'=>'contact-form',
'enableClientValidation'=>true,
'htmlOptions' => array(
'enctype'=>'multipart/form-data',
)
)); ?>
Предположим, имеется элемент формы file:
-
Элемент формы file. Листинг 14.2
<input type="file" id="Candidats_picture" name="Candidats[picture]">
Необходимо поместить файл в нужную дирректориию и сделать соответствующую запись в таблице базы данных.
Для извлечения файлов можно воспользоваться классом CuploadedFile и статичным метом getInstance.
-
Часть экшна, отвечающая за обработку формы. Листинг 14.3
$model = new Candidats;
if (Yii::app()->request->getPost('Candidats')) {
$model->attributes = Yii::app()->request->getPost('Candidats');
$file = CUploadedFile::getInstance($model, 'picture');
$uploaded = false;
if($model->validate()){
$uploaded = $file->saveAs($_SERVER['DOCUMENT_ROOT']. '/'.Yii::app()->createUrl('/').'/images/'.$file->getName());
}
$model->picture = $file->getName();
if (!$model->save()) {
$model->getErrors();
}
}
Таким образом файл из формы обзора попадает в папку images, которая находится в корневой дирректории сайта.
Кроме того, имя файла добавляется в базу данных, в таблицу candidats через модель $model.
Валидация для загружаемого файла
Чтобы разрешить добавлять только файлы отвечающие заданным параметрам, можно в модели прописать правила.
-
Валидация загружаемых файлов в модели. Листинг 14.4
class Item extends CActiveRecord {
public $image;
// другие свойства
public function rules(){
return array(
//устанавливаем правила для файла, позволяющие загружать
// только картинки!
array('image', 'file', 'types'=>'jpg, gif, png'),
);
}
}
Кроме элемента массива types можно использовать элементы allowEmpty (можно ли не загружать файл), maxSize (разрешенный вес файла в байтах) и tooLarge (текстовое сообщение, если файл превышает допустимый размер):
-
Валидация загружаемых файлов в модели. Листинг 14.5
array('picture', 'file', 'types'=>'jpg, gif, png', 'allowEmpty'=>true,'maxSize'=>Yii::app()->params['bannersFilesUploadSize'], 'tooLarge'=>'Слишком большой файл.',),
Вернемся к экшну.
Если экшн перед сохранением данных обрабатывает ошибки:
-
Обработка ошибок перед сохранением данных. Листинг 14.6
if (!$model->save()) {
$model->getErrors();
}
То, если файл не соответсвует заданным параметрам, браузер сообщит об ошибке.
Удаление файлов
Перед удалением записи из таблицы базы данных, необходимо удалить сам файл.
-
Обработка ошибок перед сохранением данных. Листинг 14.7
$model=$this->loadModel($id);
if($model->picture){
$dir = $_SERVER['DOCUMENT_ROOT'].'/'.Yii::app()->createUrl('/').'/images/';
$pic = $dir.$model->picture;
@unlink($pic);
}
$this->loadModel($id)->delete();
