> 백엔드 개발 > PHP 튜토리얼 > Smarty 템플릿 엔진이 캐시하는 방법에 대한 자세한 설명

Smarty 템플릿 엔진이 캐시하는 방법에 대한 자세한 설명

*文
풀어 주다: 2023-03-18 20:58:01
원래의
1508명이 탐색했습니다.

이 글에서는 주로 Smarty 템플릿 엔진 캐싱 메커니즘을 소개하고, Smarty 템플릿 엔진 캐싱 메커니즘의 원리를 예제 형식으로 분석하고, 활성화 및 사용 방법과 관련 주의 사항을 참고할 수 있습니다. 그것이 모두에게 도움이 되기를 바랍니다.

자세한 내용은 다음과 같습니다.

먼저 스마트 캐싱과 컴파일에 대해 이야기해 보겠습니다. 이 두 가지 개념은 기본적으로 컴파일이 활성화되어 있지만 캐싱 메커니즘은 수동으로 활성화해야 합니다. 아직 php파일이라 실행되는 시점에 아직 컴파일이 되어있는 상태인데, 데이터베이스가 관련되어 있다면 여전히 데이터베이스에 접근해야 하기 때문에 오버헤드가 적지 않으니 이를 해결하기 위해서는 스마트한 캐싱이 필요합니다!

1. 글로벌 캐시를 켜세요

$smarty->cache_dir = "/caches/"; //缓存目录
$smarty->caching = true; //开启缓存,为flase的时侯缓存无效
$smarty->cache_lifetime = 3600; //缓存时间
로그인 후 복사

2. 한 페이지에 여러 캐시를 사용하세요

예를 들어 기사 템플릿 페이지는 여러 페이지에 캐시됩니다. display() 메소드에서 두 번째 매개변수를 설정하고 고유 식별자를 지정하기만 하면 구현이 간단합니다. 다음 PHP 코드:

$smarty->display('index.tpl',$_GET["article_id"]);
로그인 후 복사

위와 같이 기사 ID의 두 번째 매개변수를 통해 기사 페이지를 캐시합니다.

3. 캐싱 비용 절감

즉, 캐시된 페이지는 데이터베이스에서 처리할 필요가 없으며 is_cached() 메서드를 통해 판단할 수 있습니다!

if(!$smarty->is_cached('index.tpl')){
 //调用数据库
}
$smarty->display('index.tpl');
로그인 후 복사

4. 캐시 지우기

일반적으로 개발 과정에서는 캐시 시간 동안 출력 결과가 변하지 않기 때문에 캐시를 켜지 않지만, 응용 과정 중에 캐시를 켜면 웹 성능이 크게 향상됩니다. .캐시를 지우는 방법은 다음과 같습니다:

clear_all_cache();//清除所有缓存
clear_cache('index.tpl');//清除index.tpl的缓存
clear_cache('index.tpl',cache_id);//清除指定id的缓存
로그인 후 복사

5. 로컬 캐싱 끄기

페이지의 일부가 캐시되고 다른 부분은 캐시할 필요가 없는 경우 다음과 같이 할 수 있습니다. 사용자의 로그인 이름을 표시하려면 캐시를 꺼야 합니다. Smarty는 다음 세 가지 솔루션을 제공합니다. 방법:

(1) 삽입 템플릿의 일부를 캐시되지 않도록 사용

삽입 태그에서 사용할 처리 기능을 정의합니다. 함수 이름 형식은 다음과 같습니다. insert_xx (array $params, object &$smarty) 여기서 xx는 insert의 이름입니다. 즉, 정의한 함수가 insert_abc인 경우 템플릿에서 사용되는 방법은 {insert name입니다. =abc}

매개변수는 $params

를 통해 전달됩니다. 삽입 플러그인으로도 만들 수 있으며 파일 이름은 insert.xx .php, 함수 이름은 smarty_insert_aa($params, & $smarty), xx 정의는 위와 같습니다

(2) $smarty->register_block($params, &$smarty)는 전체 페이지의 특정 블록이 캐시되는 것을 방지합니다

블록 정의:

smarty_block_name($params,$content, &$smarty){return $content;} 
//name表示区域名
로그인 후 복사

블록 등록:

$smarty->register_block(name, smarty_block_name, false);
//第三参数false表示该区域不被缓存
로그인 후 복사

템플릿 작성:

{name}内容 {/name}
로그인 후 복사

블록 플러그인 작성:

1단계: 플러그인 기능 정의: block.cacheless.php 및 스마트에 넣기 플러그인 디렉토리의 내용

block.cacheless.php는 다음과 같습니다.

<?php
function smarty_block_cacheless($param, $content, &$smarty) {
return $content;
}
?>
로그인 후 복사

2단계: 프로그램 및 템플릿 작성

샘플 프로그램: testCacheLess.php

<?php
include(Smarty.class.php);
$smarty = new Smarty;
$smarty->caching=true;
$smarty->cache_lifetime = 6;
$smarty->display(cache.tpl);
?>
로그인 후 복사

사용된 템플릿: 캐시.tpl

已经缓存的:{$smarty.now}<br>
{cacheless}
没有缓存的:{$smarty.now}
{/cacheless}
로그인 후 복사

이제 실행 잠시 후, 두 줄의 콘텐츠가 모두 캐시되었습니다

3단계: Smarty_Compiler.class.php 다시 작성(참고: 이 파일은 매우 중요합니다. 필요한 경우 복원하려면 먼저 백업하세요)

찾기:

코드 복사코드는 다음과 같습니다.

$this->_plugins[block][$tag_command] = array($plugin_func, null, null, null, true);

수정 :

if($tag_command == cacheless) $this->_plugins[block][$tag_command] = array($plugin_func, null, null, null, false);
else $this->_plugins[block][$tag_command] = array($plugin_func, null, null, null, true);
로그인 후 복사

원문의 마지막 매개변수를 false로 직접 변경할 수도 있습니다. 이는 기본 캐시를 끄는 것을 의미합니다.

(3) 플러그인이 캐시에서 출력되는 것을 방지하려면 Register_function을 사용하세요.

index.tpl:

<p>{current_time}{/p}
index.php:
function smarty_function_current_time($params, &$smarty){
  return date("Y-m-d H:m:s");
}
$smarty=new smarty();
$smarty->caching = true;
$smarty->register_function(&#39;current_time&#39;,&#39;smarty_function_current_time&#39;,false);
if(!$smarty->is_cached()){
  .......
}
$smarty->display(&#39;index.tpl&#39;);
로그인 후 복사

참고:

함수를 정의합니다. 함수 이름 형식은 다음과 같습니다. smarty_type_name($params, &$smarty )
type은 함수입니다.

name은 사용자 정의 라벨 이름입니다. 여기서는 {current_time}입니다.

두 매개변수는 필수이며 함수에서 사용되지 않더라도 작성해야 합니다. 두 매개변수의 기능은 위와 동일합니다.

관련 권장 사항:

Yii2 캐시를 사용한 간단한 분석

PHP 프레임워크 구축을 위한 템플릿 엔진 예제 구축

PHP의 똑똑한 템플릿 연산자는 무엇인가요? 연산자를 어떻게 사용하나요?

위 내용은 Smarty 템플릿 엔진이 캐시하는 방법에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿