ThinkPHP5中如何实现模板完全静态化

简介: 模板完全静态化,也就是通过模板完全生成纯静态的网页,相比动态页面和伪静态页面更安全更利于SEO访问更快。相比前二者各有利弊吧,现在稍微对这三种形式的优缺点对比一下,以及在ThinkPHP5项目中实现完全静态化的基本过程。

模板完全静态化,也就是通过模板完全生成纯静态的网页,相比动态页面和伪静态页面更安全更利于SEO访问更快。相比前二者各有利弊吧,现在稍微对这三种形式的优缺点对比一下,以及在ThinkPHP5项目中实现完全静态化的基本过程。


对比


1. 动态与真静态


页面静态化与动态页的对比,静态没有了SQL和一些后端脚本运行,安全稳定,访问速度快,对SEO友好(网上也有说现在的搜索引擎已经对动态网页的抓取没什么压力了),但是搜索引擎再强大,静态的URL也比动态的后面带问号冒号什么的要好看,不对SEO友好对普通浏览用户者也是友好(好看第一)。但是生成静态页面的弊端,也就是如果一个博客网站,随着文章内容的增多,那生成的页面也不断增多,就算一个html就30几Kb,数量多的情况下也挺耗存储空间,网上也有说频繁生成静态页面化,容易让硬盘出现坏道。这个我的看法是不好测试可以忽略,因为现在多数是使用云服务器或云虚拟主机,那些都不是物理硬件,就算太过碎片导致硬盘损坏,网站也能正常访问的,因为那是云服务器。

 

2. 真静态与伪静态


这二者的对比看起来像是正统之争,因为大家都知道伪静态还是动态页,只是Apache通过URL重写规则让其变成了像静态网页的样子。主要也是让自己对SEO友好,但是相比真静态多了Apache的步骤,所以也就比较耗费一些服务器的资源。而真静态的缺点上面也说了,在项目中的选择看需求,各有利弊,北桥苏的使用主要是自己网站有时要优化一下速度所以就做了模板静态化,以下是操作过程。

 

实现思路


1. 根据模块控制器自动递归创建目录。

2. file_exists判断生成的静态页是否存在

3. 或判断过期与否,存在重定向到静态网页

4. file_put_contents(file,file,content)函数生成页面。

 

编码


1. 目录的创建

/*
 * 递归创建目录
 * @param string $dir 文件目录路径
 * @return boolean 创建结果
 * **/
function mkdirs($dir)
{
    if(!is_dir($dir))
    {
        if(!mkdirs(dirname($dir))){
            return false;
        }
        if(!mkdir($dir,0777)){
            return false;
        }
    }
    return true;
}

 

2. 在基类中初始化需创建的目录

protected $staticHtmlDir = "";              //静态模板生成目录
protected $staticHtmlFile = "";             //静态文件
protected function _initialize() {
      parent::_initialize();
      $this->staticHtmlDir = "html".DS.$this->request->controller().DS;
//……………………………………………………………………

 

3. 基类中的生成前与生成后的方法。

//判断是否存在静态
public function beforeBuild($param) {
        //生成静态
        //$baseDir = "html".DS.$this->request->controller().DS;
        if(is_array($param)) {
            $param = implode("_",$param);
        }
        $this->staticHtmlFile = $this->staticHtmlDir.$this->request->action().($param?$param:'').'.html';
        if(mkdirs($this->staticHtmlDir)) {
            if(file_exists($this->staticHtmlFile) && filectime($this->staticHtmlFile)>=time()-60*60*24*5) {                  //静态文件存在
                $this->redirect('/'.$this->staticHtmlFile);
            }
        }
    }
//开始生成静态文件
public function afterBuild($html) {
        if(!empty($this->staticHtmlFile) && !empty($html)) {
            if(file_exists($this->staticHtmlFile)) {
                unlinnk($this->staticHtmlFile);
            }
            if(file_put_contents($this->staticHtmlFile,$html)) {
                $this->redirect('/'.$this->staticHtmlFile);
            }
        }
    }

 

4. 视图控制器中的使用。


ThinkPHP5中fetch方法返回给file_put_contents函数作为content就可以生成一个完整的静态页面了。




目录
打赏
0
1
1
0
41
分享
相关文章
如何优化前端网页加载速度:最佳实践与技巧
本文探讨了如何通过优化前端网页加载速度来提升用户体验和网站性能。从资源压缩和合并、减少HTTP请求、优化图片、使用CDN加速、采用异步加载和延迟加载等方面介绍了一系列最佳实践和技巧,帮助开发者更好地优化前端性能,提升网页加载速度。
基于ssm+vue.js+uniapp小程序的《数据库系统原理》课程平台附带文章和源代码设计说明文档ppt
基于ssm+vue.js+uniapp小程序的《数据库系统原理》课程平台附带文章和源代码设计说明文档ppt
68 1
基于springboot+vue.js的秒杀系统附带文章和源代码设计说明文档ppt
基于springboot+vue.js的秒杀系统附带文章和源代码设计说明文档ppt
63 1
基于小程序的个人行政复议在线预约系统+springboot+vue.js附带文章和源代码设计说明文档ppt
基于小程序的个人行政复议在线预约系统+springboot+vue.js附带文章和源代码设计说明文档ppt
56 0
[笔记]微信小程序开发《三》框架基础:小程序生命周期、全局配置、页面配置。
[笔记]微信小程序开发《三》框架基础:小程序生命周期、全局配置、页面配置。
|
10月前
404动态页面源码
404动态页面源码
88 0
404动态页面源码
微信小程序发布动态页面模板
微信小程序发布动态页面模板
230 0
前端静态页面基本开发思路(二)
由于第一篇的反响不错,所以今天抽空写写前端静态页面基本开发思路(二) 第一篇开发思路直通车→前端静态页面基本开发思路(一) 现在的静态页面的设计基本上都涉及到了轮播图,而且一般都是顶部菜单栏过了就是轮播图的区域,比如小米官网,京东官网等,所以今天我们就从轮播图的实现开始讲
156 2
前端静态页面基本开发思路(二)
前端静态页面基本开发思路(一)
有不少刚入门前端的同学经常问我前端布局的问题,总是跟我说在面对学校布置的作业或者想自己搭建博客的时候不知道怎么下手,不知道怎么去写静态的页面,每当我解决了一个又一个同学的问题的时候,又有新的同学来问,故思来想去,还是出一篇博客来讲一下怎么去开发前端静态页面,开发的基本思路是什么
264 2
前端静态页面基本开发思路(一)
前端静态服务踩坑实践
随着前端项目的增大,越来越多时候会把动静态资源进行分离部署,对于分离部署时常常涉及到代理转发的问题,专网项目主要使用 `nginx + docker + k8s` 的部署方式,本文主要分享一些相关项目的实践过程的踩坑历程及回顾思考。
121 0