PHP使用Smarty模板目录结构配置

简介: 在使用PHP模板Smarty过程中,如果不涉及自定义目录结构的话,按照下面的目录组织就可以直接使用了(前提是需要阅读以下用户手册)。          图上的每个目录都有了相应的说明,关于smarty的工作原理就是按照Smarty的语法规则编写模本文件,然后PHP脚本提供对应的数据,二者通过Smarty模板引擎最终输出可以展示的文件(包含格式+数据)。     如下图

在使用PHP模板Smarty过程中,如果不涉及自定义目录结构的话,按照下面的目录组织就可以直接使用了(前提是需要阅读以下用户手册)。

   wKioL1OMNQeQeUcgAAGJpK_02do084.jpg

     图上的每个目录都有了相应的说明,关于smarty的工作原理就是按照Smarty的语法规则编写模本文件,然后PHP脚本提供对应的数据,二者通过Smarty模板引擎最终输出可以展示的文件(包含格式+数据)。

    如下图是Smarty最基本的工作原理,当然Smarty还提供更多强大的功能。

   wKiom1OMOJ-CLDHIAACq1mv7UDI156.jpg


 接下来就是一个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

 wKiom1OMOVey5LFaAACCD4TfCtg495.jpg

     至此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文件看看结果:

    wKiom1OMPITS_UqHAAHm5KXCuns295.jpg

     首先问题出在模板文件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看看有什么效果:

wKiom1OMP5WhBOl_AAJ4G9N3YV4522.jpg

   看到这么多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看看什么效果:

  wKiom1OMQK6wTutFAACrtNUSs7I724.jpg

    看到这个结果和我们最开始的结果是一致的,这样我们就可以在项目中使用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的目录结果如下图:

   wKiom1OMRuizQokQAAA5v8HYgJ4822.jpg

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

define('REAL_PATH', 'D:\smarty3.7');

   注:如通过浏览器访问  http://localhost/smarty/smarty/Smarty.class.php; http://localhost/smarty/templates/index.tpl; 都是不安全的。原文地址:  http://aiilive.blog.51cto.com/1925756/1421211

目录
相关文章
|
JavaScript 前端开发 PHP
PHP - Laravel 视图模板(blade.php) @ 原始形态输出(Vue 与 PHP 混编)
PHP - Laravel 视图模板(blade.php) @ 原始形态输出(Vue 与 PHP 混编)
206 0
|
3月前
|
前端开发 PHP
php学习笔记-php文件表单上传-day06
本文介绍了PHP文件上传处理流程、预定义变量`$_FILES`的使用、文件上传状态代码以及文件上传实现函数。同时,通过一个文件上传的小例子,演示了文件上传表单的创建、文件上传表单处理的PHP页面编写以及运行测试输出。
php学习笔记-php文件表单上传-day06
|
6月前
|
PHP 开发者 UED
PHP中的自动加载器实现与最佳实践
在PHP开发中,合理利用自动加载器可以提高代码的可维护性和可扩展性。本文将介绍PHP中自动加载器的实现原理和最佳实践,帮助开发者更好地利用这一特性。
62 2
|
PHP
PHP 文件加载简单使用
PHP 文件加载简单使用
72 0
|
JavaScript 前端开发 PHP
PHP - Laravel 视图模板(blade.php)导入JS、Css、素材文件并使用
PHP - Laravel 视图模板(blade.php)导入JS、Css、素材文件并使用
624 0
|
PHP
PHP - Laravel 视图模板(blade.php)中使用函数
PHP - Laravel 视图模板(blade.php)中使用函数
126 0
|
PHP
PHP - Laravel 视图模板(blade.php) 模板引入与使用,及模板使用页面参数
PHP - Laravel 视图模板(blade.php) 模板引入与使用,及模板使用页面参数
308 0
|
PHP
PHP - Laravel 视图模板(blade.php) if 语句
PHP - Laravel 视图模板(blade.php) if 语句
132 0
|
PHP
PHP - Laravel 视图模板(blade.php) 循环便利
PHP - Laravel 视图模板(blade.php) 循环便利
171 0
thinkphp5.0 build.php自动创建模块目录和文件
thinkphp5.0 build.php自动创建模块目录和文件
83 0