Files
smarty/docs/ru/programmers/advanced-features/section-template-cache-handler-func.xml
freespace e799943aba Converted all line endings from CRLF to LF.
Sorry for such a big commit, but this should be done only once.
And please, don't kill me if I did a stupid thing :)
2004-11-25 23:26:13 +00:00

160 lines
4.7 KiB
XML
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<?xml version="1.0" encoding="windows-1251"?>
<!-- $Revision$ -->
<!-- EN-Revision: 1.3 Maintainer: freespace Status: ready -->
<sect1 id="section.template.cache.handler.func">
<title>Управление кэшированием</title>
<para>
Вместо стандартного механизма кэширования, использующего файлы,
вы можете использовать свои функции для чтения, записи и очистки кэшированных шаблонов.
</para>
<para>
Добавьте в ваше приложение функцию, которую Smarty сможет использовать для
управления кэшем. Укажите её имя в переменной класса
<link linkend="variable.cache.handler.func">$cache_handler_func</link>.
Теперь Smarty будет использовать её для операций с кэшированным содержимым.
Первый параметр вашей функции - действие, принимает значения
'read', 'write' или 'clear' (соответственно, 'прочитать', 'записать'
или 'очистить'). Вторым параметром передаётся объект smarty. Третьим - данные для
кэширования.
Третий параметр используется только при чтении и записи. При записи Smarty передаёт
через него кэшированный контент. При чтении предполагается, что через него
передаётся ссылка на переменную, в которую контент будет загружен.
При очистке значение третьего параметра не обрабатывается.
Четвёртый параметр - имя файла с шаблоном (используется при чтении/записи),
пятый - идентификатор кэша (опционально), шестой - идентификатор компиляции (опционально,
используется для построения разных кэшей для одного шаблона),
седьмой - срок годности кэша (опционально).
Примечание: последний параметр ($exp_time) добавлен в Smarty 2.6.0.
</para>
<example>
<title>Применение MySQL в качестве хранилища кэшированных данных</title>
<programlisting>
<![CDATA[
<?php
/*
пример использования:
include('Smarty.class.php');
include('mysql_cache_handler.php');
$smarty = new Smarty;
$smarty->cache_handler_func = 'mysql_cache_handler';
$smarty->display('index.tpl');
код для MySQL таблицы:
create database SMARTY_CACHE;
create table CACHE_PAGES(
CacheID char(32) PRIMARY KEY,
CacheContents MEDIUMTEXT NOT NULL
);
*/
function mysql_cache_handler($action, &$smarty_obj, &$cache_content, $tpl_file=null, $cache_id=null, $compile_id=null, $exp_time=null)
{
// параметры подключения к базе данных - хост, логин, пароль, название базы
$db_host = 'localhost';
$db_user = 'myuser';
$db_pass = 'mypass';
$db_name = 'SMARTY_CACHE';
// установите в true для использования gzip компрессии кэшированных данных
$use_gzip = false;
// создаём уникальный идентификатор кэша
$CacheID = md5($tpl_file.$cache_id.$compile_id);
if(! $link = mysql_pconnect($db_host, $db_user, $db_pass)) {
$smarty_obj->_trigger_error_msg("cache_handler: не могу подключиться к базе данных");
return false;
}
mysql_select_db($db_name);
switch ($action) {
case 'read':
// чтение кэша из базы
$results = mysql_query("select CacheContents from CACHE_PAGES where CacheID='$CacheID'");
if(!$results) {
$smarty_obj->_trigger_error_msg("ошибка кэша: неверный запрос.");
}
$row = mysql_fetch_array($results,MYSQL_ASSOC);
if($use_gzip && function_exists("gzuncompress")) {
$cache_content = gzuncompress($row["CacheContents"]);
} else {
$cache_content = $row["CacheContents"];
}
$return = $results;
break;
case 'write':
// сохранение кэша в базе
if($use_gzip && function_exists("gzcompress")) {
// сжимаем контент чтобы сэкономить место
$contents = gzcompress($cache_content);
} else {
$contents = $cache_content;
}
$results = mysql_query("replace into CACHE_PAGES values(
'$CacheID',
'".addslashes($contents)."')
");
if(!$results) {
$smarty_obj->_trigger_error_msg("ошибка кэша: неверный запрос.");
}
$return = $results;
break;
case 'clear':
// очистка кэша
if(empty($cache_id) && empty($compile_id) && empty($tpl_file)) {
// clear them all
$results = mysql_query("delete from CACHE_PAGES");
} else {
$results = mysql_query("delete from CACHE_PAGES where CacheID='$CacheID'");
}
if(!$results) {
$smarty_obj->_trigger_error_msg("ошибка кэша: неверный запрос.");
}
$return = $results;
break;
default:
// ошибка, указан неизвестный метод
$smarty_obj->_trigger_error_msg("ошибка кэша: неизвестный метод \"$action\"");
$return = false;
break;
}
mysql_close($link);
return $return;
}
?>
]]></programlisting>
</example>
</sect1>
<!-- Keep this comment at the end of the file
Local variables:
mode: sgml
sgml-omittag:t
sgml-shorttag:t
sgml-minimize-attributes:nil
sgml-always-quote-attributes:t
sgml-indent-step:1
sgml-indent-data:t
indent-tabs-mode:nil
sgml-parent-document:nil
sgml-default-dtd-file:"../../../../manual.ced"
sgml-exposed-tags:nil
sgml-local-catalogs:nil
sgml-local-ecat-files:nil
End:
vim600: syn=xml fen fdm=syntax fdl=2 si
vim: et tw=78 syn=sgml
vi: ts=1 sw=1
-->