接觸一個新東西,往往搭建最初始的環境最讓人捉急。
在使用PHP模板Smarty過程中,如果不涉及自定義目錄結構的話,按照下面的目錄組織就可以直接使用了(前提是需要閱讀以下用戶手冊)。
圖上的每個目錄都有了相應的說明,關于smarty的工作原理就是按照Smarty的語法規則編寫模本文件,然后PHP腳本提供對應的數據,二者通過Smarty模板引擎最終輸出可以展示的文件(包含格式+數據)。
如下圖是Smarty最基本的工作原理,當然Smarty還提供更多強大的功能。
接下來就是一個Hello Smarty的體驗了。
1.編一個提供數據的PHP文件(index.php)
<?phprequire('./smarty/Smarty.html' target='_blank'>class.php');$_smarty=newSmarty();$_smarty->assign('title','歡迎');$_smarty->assign('name','Smarty');$_smarty->display('index.tpl');?>
2.編一個用戶展示數據的模本文件index.tpl(注意模板文件要放置到templates文件夾中)
<!DOCTYPEhtml><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代碼如下:
<?phprequire('../smarty/Smarty.class.php');$_smarty=newSmarty();$_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找不到,其次打印出的模板目錄是:'. emplates'很顯然當前test目錄下并不存在template目錄,這個時候該怎么辦呢?
3.自定義目錄結構
實際開發中目錄結構自然不能因為某個框架或者組件變成死的,當然框架或組件的開發者一般都會提供最大限度的可擴展,可配置。
上面的問題產生的原因倒不是應為我們的test目錄下沒有templates目錄,而是我們在使用Smarty的時候完全采用了默認的配置,這樣做方便了使用,單不利于項目的組織和管理。
我們能夠做的就是將Smarty的自定義配置分離出來,單獨做一個文件,然后在使用到Smarty對象的地方直接引用即可。
3.1下面是一個簡單的分離示例(smarty.config.php):
<?php//SmartyPHPconfigurationdefine('REAL_PATH',dirname(__FILE__));require(REAL_PATH.'/smarty/Smarty.class.php');$_smarty=newSmarty();$_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:
<?phprequire('../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');
注:如通過瀏覽器訪問 http://localhost/smarty/smarty/Smarty.class.php; http://localhost/smarty/templates/index.tpl; 都是不安全的。
PHP編程鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。
新聞熱點
疑難解答