388
人物
PHP使用Smarty模板目錄結構配置
在使用PHP模板Smarty過程中,如果不涉及自定義目錄結構的話,按照下麵的目錄組織就可以直接使用了(前提是需要閱讀以下用戶手冊)。
圖上的每個目錄都有了相應的說明,關於smarty的工作原理就是按照Smarty的語法規則編寫模本文件,然後PHP腳本提供對應的數據,二者通過Smarty模板引擎最終輸出可以展示的文件(包含格式+數據)。
如下圖是Smarty最基本的工作原理,當然Smarty還提供更多強大的功能。
接下來就是一個Hello Smarty的體驗了。
1.編一個提供數據的PHP文件(index.php)
<?php require('./smarty/Smarty.class.php'); $_smarty=new Smarty(); $_smarty->assign('title', '歡迎'); $_smarty->assign('name', 'Smarty'); $_smarty->display('index.tpl'); ?>
2.編一個用戶展示數據的模本文件index.tpl(注意模板文件要放置到templates文件夾中)
<!DOCTYPE html> <html> <head> <title>{$title}</title> </head> <body> <h3>Hello, {$name}</h3> </body> </html>
3.訪問index.php
至此Smarty就可以工作了,但是關於Smarty的用法不是本文的重點,本文的重點是Smarty的目錄結果配置。
為了說明Smarty的目錄結構配置,先引入一個問題:目前的php文件都在工程根目錄,實際應用中這樣並不可取,這時候我們新建一個demo1.php放置到test目錄下,看看會發生什麼情況。
1. ./test/demo1.php代碼如下:
<?php require('../smarty/Smarty.class.php'); $_smarty=new Smarty(); $_smarty->assign('title', '歡迎'); $_smarty->assign('name', 'Smarty'); var_dump($_smarty->getTemplateDir()); $_smarty->display('index.tpl'); ?>
注意:
模板文件不變
引入Smarty.class.php文件的路徑發生變化。
打印模板目錄信息(getTemplateDir())
2. 訪問/test/demo1.php文件看看結果:
首先問題出在模板文件index.tpl找不到,其次打印出的模板目錄是:'.\templates\'很顯然當前test目錄下並不存在template目錄,這個時候該怎麼辦呢?
3.自定義目錄結構
實際開發中目錄結構自然不能因為某個框架或者組件變成死的,當然框架或組件的開發者一般都會提供最大限度的可擴展,可配置。
上麵的問題產生的原因倒不是應為我們的test目錄下沒有templates目錄,而是我們在使用Smarty的時候完全采用了默認的配置,這樣做方便了使用,單不利於項目的組織和管理。
我們能夠做的就是將Smarty的自定義配置分離出來,單獨做一個文件,然後在使用到Smarty對象的地方直接引用即可。
3.1下麵是一個簡單的分離示例(smarty.config.php):
<?php //Smarty PHP configuration define('REAL_PATH', dirname(__FILE__)); require(REAL_PATH.'/smarty/Smarty.class.php'); $_smarty=new Smarty(); $_smarty->setCacheDir(REAL_PATH.'/cache'); $_smarty->setConfigDir(REAL_PATH.'/configs'); $_smarty->setPluginsDir(REAL_PATH.'/plugins'); $_smarty->setTemplateDir(REAL_PATH.'/templates'); $_smarty->setCompileDir(REAL_PATH.'/templates_c'); //添加Smarty自帶的插件庫 $_smarty->addPluginsDir(REAL_PATH.'/smarty/plugins'); //檢測Smarty目錄結構配置是否有效 // $_smarty->testInstall(); ?>
3.2 將smarty.config.php放置到工程的根目錄,然後去掉$_smarty->testInstall()的注釋,訪問smarty.config.php看看有什麼效果:
看到這麼多Ok,就說明我們的Smarty目錄結構配置成功了。
3.3接下來我們要使用smarty.config.php,在test目錄下創建demo2.php:
<?php require('../smarty.config.php'); // global $_smarty; $_smarty->assign('title', '歡迎'); $_smarty->assign('name', 'Smarty'); $_smarty->display('index.tpl'); ?>
注意:
包含smarty.config.php的路徑
3.4 接下來訪問tset/demo2.php看看什麼效果:
看到這個結果和我們最開始的結果是一致的,這樣我們就可以在項目中使用Smarty的時候不用關心Smarty的要求的目錄結果是什麼樣子的了,當然並非一點都不關心,這個時候我們隻需要維護smarty.config.php中的配置。
4.smarty.config.php配置的一點延伸
從3.1中smarty.config.php的配置代碼中看,我們引入Smarty.class.php類的時候使用的絕對路徑,這樣做就可以保證項目中任何通過引入smarty.config.php文件來使用Smarty類能夠正常加載。
做到這一步之後,接下來為了防止通過瀏覽器直接訪問Smarty庫以及它的依賴目錄(cache, template, plugins, configs, templates_c),我們需要做點安全方麵的工作,這個時候隻需要吧Smarty庫和它的依賴目錄至於服務器文檔根目錄之外, 然後修改smart.config.php文件中的配置即可。
smarty3.7的目錄結果如下圖:
然後修改一下smarty.config.php中的配置即可,如下代碼行。
define('REAL_PATH', 'D:\smarty3.7');
注:如通過瀏覽器訪問 https://localhost/smarty/smarty/Smarty.class.php; https://localhost/smarty/templates/index.tpl; 都是不安全的。原文地址: https://aiilive.blog.51cto.com/1925756/1421211
最後更新:2017-04-03 08:26:26