1. Smarty キャッシュを有効にして使用します
smarty のキャッシュを有効にするには、smarty 設定パラメータで caching を true に設定し、cache_dir を指定するだけです。同時に、cache_lefetime パラメータを設定してキャッシュの有効期間 (秒単位) を指定します。同じページに対して複数の異なるキャッシュを生成したい場合は、次のように 2 番目のパラメーターcache_id を追加して表示または取得できます:
コードは次のとおりです: $smarty->display('index.tpl',$my_cache_id);
この機能を使用すると、さまざまな $_GET を異なる方法でキャッシュできます。
2. Smarty キャッシュをクリアします
通常、Smarty キャッシュをクリアするにはいくつかの方法があります:
コードは次のとおりです:
clear_all_cache();//すべてのキャッシュをクリアします
clear_cache('index.tpl');//指定されたテンプレートindex.tplのキャッシュをクリアします
clear_cache('index.tpl',cache_id);//指定された ID を持つ指定されたテンプレートのキャッシュをクリアします
3. グローバルキャッシュ
グローバルキャッシュとは、ウェブサイト全体のすべてのページに対してキャッシュページを生成することです。グローバルキャッシュを設定するには、まず Smarty 設定ファイルを操作し、キャッシュを有効にし、キャッシュファイルのディレクトリを指定し、キャッシュの生存時間を設定する必要があります。 設定パラメータは次のとおりです。
コードは次のとおりです:$smarty->cache_dir='./cache/' //キャッシュファイルを保存するフォルダーを設定します
;
$smarty->caching=1;//キャッシュを有効にする 0、FALSE はオフを意味し、TRUE はオンを意味します$smarty->cache_lifetime=3600//単位は秒(-1を入力すると期限切れになりません)
次に、特定の php ページに移動して、それに対応する特定のキャッシュ ファイルの名前を設定する必要があります。php ページでは次のように記述できます。
コードは次のとおりです: $smarty->display('list2.html',md5($_SERVER['REQUEST_URI']));// 現在のページの URL (? 以降のすべてのパラメータを含む) を md5 で暗号化します。そしてキャッシュファイル名を設定します
注意すべき点は次のとおりです:
コードをコピーします。コードは次のとおりです:
$smarty->display('対応するテンプレートファイル名', 'キャッシュファイル名の補足部分') このメソッド。
第二引数は省略します。記述しない場合、キャッシュファイル名はテンプレートファイル名を暗号化したものになります。しかし、これには次のようなより難しい問題が発生します:
コードは次のとおりです:
http://www.jb51.net/article.php?id=5
http://www.jb51.net/article.php?id=7
これら 2 つの URL は異なるコンテンツに対応していますが、生成されたキャッシュ ファイル名は記事の暗号化の結果です。これにより、ユーザーは異なるコンテンツをクエリすることになりますが、同じキャッシュ ファイルにアクセスすることになります。したがって、アクセス URL (? 以降のすべてのパラメータを含む) を暗号化するためのより信頼性の高い方法である md5 を追加することをお勧めします。
4. 部分キャッシュ
部分キャッシュとは、ウェブサイト上のすべてのファイルではなく、一部のファイルを指定してキャッシュ ファイルを生成することを意味します。部分キャッシュの本質は、実際には部分非キャッシュです。つまり、どのファイルをキャッシュするかを指定するのではなく、キャッシュしない特定のファイルを指定することです。ここで、3 つのファイルがあると仮定します:
コードは次のとおりです:
http://www.jb51.net/index.php //キャッシュが必要です
http://www.jb51.net/cate.php //キャッシュが必要です
http://www.jb51.net/article.php //キャッシュは必要ありません
最初の 2 つのファイルの php ファイルに $smarty->display('対応するテンプレート ファイル名', 'キャッシュ ファイル名の補足部分') という文を記述する必要があります。
ただし、3 番目のファイルでは、キャッシュが必要ないことを明確に示す必要があります。その具体的な方法は、指定されたテンプレートを表示する前に次のコードを記述することです。
コードは次のとおりです:
$smarty->clear_cache('対応するテンプレートファイル名');//実際には$smarty->display('対応するテンプレートファイル名')の前後に記述できます
もちろん $smarty->display('対応するテンプレート ファイル名') を記述する必要があるため、キャッシュを生成したくないので、2 番目のパラメーターは必要ありません。
注: $smarty->clear_cache() と $smarty->display() のパラメータは一貫して記述する必要があります
5. 部分キャッシュ
部分キャッシュとは、同じページ内の特定のローカルな場所を指定してキャッシュを生成することです。実際には、どの部分がキャッシュを生成するかは指定されていませんが、どの部分がキャッシュを生成しないかは指定されていません(これは部分キャッシュの動作概念に似ています)。まずは次の例を見てみましょう:
article.php ファイルの一部は次のとおりです:
コードは次のとおりです:
$time=time();
$smarty->assign('time',$lanmuarr);
関数 insert_timeget(){
戻り時間();
}
$smarty->display('article.html');
テンプレートファイルarticle.htmlの対応するコードは次のとおりです:
コードは次のとおりです:
<ボディ>
{$time}
{insert name='timeget'}
ボディ>
上記の例の説明は次のとおりです: PHP では、カスタム補助名を持つ insert_ (アンダースコアに注意) という名前のカスタム関数を定義するだけでよく、返される値を assign() メソッドで渡す必要はありません。 . {insert name='customSupplementary name'} を使用してテンプレート ページ内で直接呼び出されると、キャッシュの影響を受けず、リアルタイムで更新されます。
もう 1 つの追加事項は、Smarty キャッシュを使用するだけでは十分ではないと思われる場合は、カスタム キャッシュを使用することもできます。
ここでは、次のようなカスタム関数を使用してキャッシュを処理するように、cache_handler_func を設定する必要があります。
コードは次のとおりです:
$smarty->cache_handler_func="myCache";
関数 myCache($action,&$smarty_obj,&$cache_content,$tpl_file=null,$cache_id=null,$compile_id=null){
スイッチ($アクション){
case "read"://キャッシュコンテンツの読み取り
case "write"://ライトキャッシュ
ケース「クリア」://クリア
}
}