PHP-smarty引起的白屏故障

php中文网
发布: 2016-07-29 08:57:12
原创
1345人浏览过

今天遇到了一个比较大而且棘手的问题——更新了smarty的模板之后,页面白屏了,然而在预发布环境下测试的时候,并没有发现这个情况!最后,找到了原因,竟然是与smarty的模板编译原理有关。

编写一个简单的smarty页面,运行之后查看模板的编译目录,找到对应的编译文件。

<?php /*%%SmartyHeaderCode:1631756d543241d8d77-45493985%%*/if(!defined('SMARTY_DIR')) exit('no direct access allowed');
$_valid = $_smarty_tpl->decodeProperties(array (
  'file_dependency' => 
  array (
    '177dfb3e2809e44a1ff3a49d04e73219944e3fef' => 
    array (
      0 => 'tpl\test.htm',
      1 => 1458725943,         #注意到这个值1458725943为2016/3/23 17:39:03
      2 => 'file',
    ),
.........
  'has_nocache_code' => false,
),false); /*/%%SmartyHeaderCode%%*/?>
登录后复制
如果我将这个值调整到未来的时间(2016/3/23 23:16:5),并修改模板文件会发生什么?可以看到即使我们修改了模板,页面也是没有变化的,也就是说,smarty模板并没有重新编译。那么,1458725943这个时间表示什么意思呢?这个时间,是模板文件的修改时间。总结来说,如果你更新的模板文件的修改时间比覆盖前的模板的修改时间要早,那么smarty不会重新编译(开发环境系统时间不正确就会导致这个问题)。

但是,出问题的smarty模板是同一个开发者开发的,而且也能确认新版本的模板文件的修改时间正确,却导致了白屏。后来,也终于查出了原因——由于文件上传过程中,修文件的修改时间为服务器的当前时间,导致了smarty编译了不完整的模板文件,导致了白屏。当模板文件上传完成之后,该文件的修改时间变成真实的修改时间,此时smarty就不会再编译了。

之前上传smarty模板一直没遇到这个问题,但是并发量高的服务器上,问题出现的概率也会提高。

解决方案:

白瓜面试
白瓜面试

白瓜面试 - AI面试助手,辅助笔试面试神器

白瓜面试 40
查看详情 白瓜面试

立即学习PHP免费学习笔记(深入)”;

更新模板文件后,需要清空smarty的编译目录。

以上就介绍了PHP-smarty引起的白屏故障,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号