在使用php模闆smarty過程中,如果不涉及自定義目錄結構的話,按照下面的目錄組織就可以直接使用了(前提是需要閱讀以下使用者手冊)。
圖上的每個目錄都有了相應的說明,關于smarty的工作原理就是按照smarty的文法規則編寫模本檔案,然後php腳本提供對應的資料,二者通過smarty模闆引擎最終輸出可以展示的檔案(包含格式+資料)。
如下圖是smarty最基本的工作原理,當然smarty還提供更多強大的功能。
接下來就是一個hello smarty的體驗了。
1.編一個提供資料的php檔案(index.php)
2.編一個使用者展示資料的模本檔案index.tpl(注意模闆檔案要放置到templates檔案夾中)
3.通路index.php
至此smarty就可以工作了,但是關于smarty的用法不是本文的重點,本文的重點是smarty的目錄結果配置。
為了說明smarty的目錄結構配置,先引入一個問題:目前的php檔案都在工程根目錄,實際應用中這樣并不可取,這時候我們建立一個demo1.php放置到test目錄下,看看會發生什麼情況。
1. ./test/demo1.php代碼如下:
注意:
模闆檔案不變
引入smarty.class.php檔案的路徑發生變化。
列印模闆目錄資訊(gettemplatedir())
2. 通路/test/demo1.php檔案看看結果:
首先問題出在模闆檔案index.tpl找不到,其次列印出的模闆目錄是:'.\templates\'很顯然目前test目錄下并不存在template目錄,這個時候該怎麼辦呢?
3.自定義目錄結構
實際開發中目錄結構自然不能因為某個架構或者元件變成死的,當然架構或元件的開發者一般都會提供最大限度的可擴充,可配置。
上面的問題産生的原因倒不是應為我們的test目錄下沒有templates目錄,而是我們在使用smarty的時候完全采用了預設的配置,這樣做友善了使用,單不利于項目的組織和管理。
我們能夠做的就是将smarty的自定義配置分離出來,單獨做一個檔案,然後在使用到smarty對象的地方直接引用即可。
3.1下面是一個簡單的分離示例(smarty.config.php):
3.2 将smarty.config.php放置到工程的根目錄,然後去掉$_smarty->testinstall()的注釋,通路smarty.config.php看看有什麼效果:
看到這麼多ok,就說明我們的smarty目錄結構配置成功了。
3.3接下來我們要使用smarty.config.php,在test目錄下建立demo2.php:
注意:
包含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中的配置即可,如下代碼行。