天天看點

PHP使用Smarty模闆目錄結構配置

在使用php模闆smarty過程中,如果不涉及自定義目錄結構的話,按照下面的目錄組織就可以直接使用了(前提是需要閱讀以下使用者手冊)。

PHP使用Smarty模闆目錄結構配置

     圖上的每個目錄都有了相應的說明,關于smarty的工作原理就是按照smarty的文法規則編寫模本檔案,然後php腳本提供對應的資料,二者通過smarty模闆引擎最終輸出可以展示的檔案(包含格式+資料)。

    如下圖是smarty最基本的工作原理,當然smarty還提供更多強大的功能。

PHP使用Smarty模闆目錄結構配置

 接下來就是一個hello smarty的體驗了。

     1.編一個提供資料的php檔案(index.php)

     2.編一個使用者展示資料的模本檔案index.tpl(注意模闆檔案要放置到templates檔案夾中)

   3.通路index.php

PHP使用Smarty模闆目錄結構配置

     至此smarty就可以工作了,但是關于smarty的用法不是本文的重點,本文的重點是smarty的目錄結果配置。

     為了說明smarty的目錄結構配置,先引入一個問題:目前的php檔案都在工程根目錄,實際應用中這樣并不可取,這時候我們建立一個demo1.php放置到test目錄下,看看會發生什麼情況。

 1.  ./test/demo1.php代碼如下:

     注意:

           模闆檔案不變

           引入smarty.class.php檔案的路徑發生變化。

           列印模闆目錄資訊(gettemplatedir())

 2. 通路/test/demo1.php檔案看看結果:

PHP使用Smarty模闆目錄結構配置

     首先問題出在模闆檔案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看看有什麼效果:

PHP使用Smarty模闆目錄結構配置

   看到這麼多ok,就說明我們的smarty目錄結構配置成功了。

   3.3接下來我們要使用smarty.config.php,在test目錄下建立demo2.php:

    注意:

           包含smarty.config.php的路徑

   3.4 接下來通路tset/demo2.php看看什麼效果:

PHP使用Smarty模闆目錄結構配置

    看到這個結果和我們最開始的結果是一緻的,這樣我們就可以在項目中使用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的目錄結果如下圖:

PHP使用Smarty模闆目錄結構配置

  然後修改一下smarty.config.php中的配置即可,如下代碼行。