- PVSM.RU - https://www.pvsm.ru -
Вышел кандидат в релизы PHP фреймворка Yii 1.1.14. Забрать можно с GitHub [1].
Исправлены более 80 ошибок, добавлено более 60 небольших улучшений и новых возможностей. Появился новый класс
CPasswordHelper, который предоставляет надёжный метод хранения и проверки хешей паролей. Также добавлен CRedisCache,
с помощью которого можно использовать Redis для хранений кеша. Yii может быть установлен как
пакет Composer [2]. Полный список изменений дан
в changelog [3].
Значительную часть изменений сделали члены сообщества: creocoder [4], tom--, paystey, Ragazzo, antoncpu, Yiivgeny и другие,
за что им огромное спасибо.
Так как это кандидат в релизы (RC), не стоит использовать его на боевых серверах. Стабильный релиз 1.1.14 будет достпен в
течение нескольких недель, а пока мы будем очень признательны, если вы проверите RC и
сообщите нам об ошибках [5]. Заранее спасибо.
Ну а теперь рассмотрим главные улучшения.
CPasswordHelperCPasswordHelper предоставляет надёжный метод хранения и проверки хешей паролей. Использовать его очень просто:
// генерируем хеш, который затем будет сохранён в БД. $password приходит из формы регистрации
$hash = CPasswordHelper::hashPassword($password);
// $hash — это то, что мы сохраняли в БД, $password приходит из формы логина
if (CPasswordHelper::verifyPassword($password, $hash)
// всё хорошо
else
// неправильный пароль
CDbCommandBuilder::createMultipleInsertCommand()При помощи CDbCommandBuilder::createMultipleInsertCommand() стало возможным вставить несколько записей за один запрос:
$builder=Yii::app()->db->schema->commandBuilder;
$command=$builder->createMultipleInsertCommand('tbl_post', array(
array('title' => 'record 1', 'text' => 'text1'),
array('title' => 'record 2', 'text' => 'text2'),
));
$command->execute();
CRedisCacheТеперь приложение можно сконфигурировать для хранения кеша в Redis. Делается через `protected/config/main.php`:
array(
// ...
'components'=>array(
'cache'=>array(
'class'=>'CRedisCache',
'hostname'=>'localhost',
'port'=>6379,
'database'=>0,
),
),
)
Yii теперь можно установить через Composer [2]. Для этого необходимо добавить
следующее в composer.json.
"yiisoft/yii": "dev-master"
Если вам необходимо отлогинить пользователя через определённое время вне зависимости от его активности, сделать это
можно так:
// ...
'components'=>array(
'user'=>array(
// ...
'absoluteAuthTimeout' => 60*60*24;
),
),
)
При использовании CHttpRequest::sendFile Yii теперь верно отвечает на RANGE запросы, то есть конечный пользователь
получает большую скорость при скачивании в несколько потоков.
through с BELONGS_TOОпция «through» теперь может использоваться с CActiveRecord::BELONGS_TO. Подробнее об этом
написано в полном руководстве [6].
CLogFilter::$logVars теперь принимает массив массивов, в котором можно указать, что именно логировать из $GLOBALS:
'components'=>array(
'log'=>array(
'class'=>'CLogRouter',
'routes'=>array(
array(
'class'=>'system.logging.CWebLogRoute',
'filter'=>array(
'class'=>'system.logging.CLogFilter',
'logVars'=>array(
'_COOKIE', // старый синтаксис, < 1.1.14
array('_SERVER','REMOTE_ADDR'), // новый синтаксис, >= 1.1.14
array('_SERVER','HTTP_USER_AGENT'), // новый синтаксис, >= 1.1.14
),
),
),
),
),
),
Приведённая выше конфигурация даст в логе следующее:
$_COOKIE=array (
'__utma' => '111872281.473431406.1366046648.1366046648.1366046648.1',
'__utmz' => '111872281.1366046648.1.1.utmcsr=(direct)|utmccn=(direct)|utmcmd=(none)',
'cartVisible' => '1',
'96ab4aec0c2977c9b793d4ba009eb3ce' => '...',
'PHPSESSID' => 'vb8pk7obs3q2lc7bl8ield7si7',
)
$_SERVER.REMOTE_ADDR='::1'
$_SERVER.HTTP_USER_AGENT='Mozilla/5.0 (Windows NT 6.1; WOW64; rv:22.0) Gecko/20100101 Firefox/22.0'
CLocalizedFormatterНовый класс CLocalizedFormatter позволяет форматировать значения в соответствии с текущей локалью:
'components'=>array(
'format'=>array(
'class'=>'system.utils.CLocalizedFormatter',
'locale'=>'en_US',
),
'germanFormat'=>array(
'class'=>'system.utils.CLocalizedFormatter',
'locale'=>'de_DE',
),
'russianFormat'=>array(
'class'=>'system.utils.CLocalizedFormatter',
'locale'=>'ru_RU',
),
),
echo Yii::app()->format->formatDatetime(time()) . "n";
echo Yii::app()->germanFormat->formatDatetime(time()) . "n";
echo Yii::app()->russianFormat->formatDatetime(time()) . "n";
// Jul 7, 2013 9:34:56 PM
// 07.07.2013 21:34:56
// 07.07.2013, 21:34:56
Gii теперь может использовать комментарии к полям таблицы в качестве названий полей генерируемой модели. К примеру,
если таблицу создать следующим образом:
CREATE TABLE `tbl_user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`first_name` varchar(100) NOT NULL COMMENT 'Имя:',
`last_name` varchar(100) NOT NULL COMMENT 'Nachname:',
`title` varchar(50) NOT NULL COMMENT 'Title (e.g. Mr., Mrs., etc.):',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1;
То сгенерированный метод attributeLabels будет следующим (если выбрать «Use Column Comments as Attribute Labels» в Gii):
/**
* @return array customized attribute labels (name=>label)
*/
public function attributeLabels()
{
return array(
'id' => 'ID',
'first_name' => 'Имя:',
'last_name' => 'Nachname:',
'title' => 'Title (e.g. Mr., Mrs., etc.):',
);
}
CSecurityManagerВ CSecurityManager добавлены:
* CSecurityManager::generateSessionRandomBlock(): генерирует случайную последовательность байт на основе текущей сессии
пользователя.
* CSecurityManager::generatePseudoRandomBlock(): улучшенная альтернатива mt_rand().
* CSecurityManager::generateRandomBytes(): генерирует случайные бинарные данные. Криптостойкость задаётся вторым
аргументом. Стоит отметить, что генерация довольно медленная.
* CSecurityManager::generateRandomString(): генерирует случайную строку. Криптостойкость задаётся вторым аргументом.
Стоит отметить, что генерация довольно медленная.
Автор: SamDark
Источник [7]
Сайт-источник PVSM.RU: https://www.pvsm.ru
Путь до страницы источника: https://www.pvsm.ru/framework/38666
Ссылки в тексте:
[1] GitHub: https://github.com/yiisoft/yii/releases/tag/1.1.14-rc
[2] пакет Composer: https://packagist.org/packages/yiisoft/yii
[3] changelog: https://raw.github.com/yiisoft/yii/1.1.14-rc/CHANGELOG
[4] creocoder: http://habrahabr.ru/users/creocoder/
[5] сообщите нам об ошибках: https://github.com/yiisoft/yii/issues
[6] написано в полном руководстве: http://www.yiiframework.com/doc/guide/1.1/ru/database.arr#relational-query-with-through
[7] Источник: http://habrahabr.ru/post/186596/
Нажмите здесь для печати.