php页面静态化技术;学习笔记
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>demo</title> </head>
<body>
<p style="color: #ff9000;">%demo%</p>
</body>
</html>
这是需要替换的页面
PHP页面的静态化很有必要,尤其是在CMS系统中,一些内容一旦生成,基本上不会有变化,这时如果用html将页面静态化,无疑会减少服务其解析PHP页面的负担。以下是看书学来的PHP静态化技术,记录之以备不时之需。
无论是利用框架还是简单的脚本,原理基本一致:就是利用PHP进行文件操作,替换html模板中的动态元素,不仅能提高用户的访问速度还能让php与html分离,使代码更具有维护性。
用到的文件操作函数:
fopen() -------------------- 打开一个文件 函数有两个参数: 1.打开文件的路径和文件名 2.打开文件所用的模式(字符串形式) 这里用到了r 和 w r代表只读 w代表只写
feof() -------------------- 读取文件直到文件末尾 这个函数会在读取到文件的末尾返回true 那么就可以用while知道何时读完文件;函数有一个参数,1.打开的文件指针
fwiter() -------------------- 写入文件内容,函数有三个参数:1.写入的文件名称 2.写入的内容 3.(可选) 写入的最大字符数
fclose() ------------------------ 关闭文件;一般做完所有操作后必须关闭文件;
注意事项: 需要注意文件的路径;以及读取文件所需要的权限 ;
php代码:
<?php
header("Content-type:text/html,charset=utf-8");
/******php静态化*******/
class textHtml{
public function fwriteHtml($r){
/*php页面静态化技术
*$r [array];
*route=>生成文件名称及路径
*html=>需要读取的静态资源
*stsyem=>要替换的标签
*content=>标签替换的内容
* */ $cfill = fopen($r["html"],"r");//读取的文件名
$cfillnew = fopen($r["route"],"w");
while(!feof($cfill)){
$row = fgets($cfill); $res = str_replace($r["stsyem"],$r["content"],$row); //替换内容
fwrite($cfillnew,$res);//写入html文件
}
/*关闭文件*/
fclose($cfill);
fclose($cfillnew);
}
} $f = new textHtml;
$fillname = microtime().".html";
$content = "这是一个页面静态化技术";
$r["route"] = $fillname;
$r["html"] = "index.html";
$r["stsyem"] = "%demo%";
$r["content"] = $content; $f->fwriteHtml($r);
?>
最后得到的结果:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>全国城市三级联动</title> </head>
<body>
<p style="color: #ff9000;">这是一个页面静态化技术</p>
</body>
</html>
利用php静态化技术可以更好的实现网页功能 ; 在创建文章或者一些不经常改变内容中都可以用到;
php页面静态化技术;学习笔记的更多相关文章
- 页面静态化技术Freemarker技术的介绍及使用实例.
		
一.FreeMarker简介 1.动态网页和静态网页差异 在进入主题之前我先介绍一下什么是动态网页,动态网页是指跟静态网页相对应的一种网页编程技术.静态网页,随着HTML代码的生成,页面的内容和显示效 ...
 - java秒杀系列(2)- 页面静态化技术
		
前言 通过代码片段分别介绍服务端渲染.客户端渲染.对象缓存三种方式的写法. 代码片段仅供参考,具体实现需要根据业务场景自行适配,但思想都是一样. 一.服务端渲染方式 1.接口返回html页面的设置 @ ...
 - 高性能Java Web 页面静态化技术(原创)
		
package com.yancms.util; import java.io.*; import org.apache.commons.httpclient.*; import org.apache ...
 - 高性能Java Web 页面静态化技术
		
package com.yancms.util; import java.io.*; import org.apache.commons.httpclient.*; import org.apache ...
 - Freemarker 页面静态化技术使用入门案例
		
在访问 新闻.活动.商品 详情页面时, 路径可以是 xx[id].html, 服务器端根据请求 id, 动态生成 html 网页,下次访问数据时,无需再查询数据,直接将 html 静态页面返回.这样一 ...
 - Freemarker页面静态化技术,activemq监听页面变动
		
初步理解: 架构优化: 静态页面的访问速度优于从缓存获取数据的动态页面的访问速度: Freemarker: 导包 模板:hello.ftl <!DOCTYPE html> <html ...
 - Thymeleaf页面静态化技术
		
Teymeleaf的使用 案例一:springboot搭建Thymeleaf 1.导入依赖 2.新建html页面模板 3.新建前端控制层Controller 4.新建启动类 1.导入依赖 <?x ...
 - Django框架开发web网站的网页优化—页面静态化
		
网站优化-页面静态化 1)概念 提前将页面所用到的数据从数据库查询出来,然后生成一个静态页面,之后用户来访问的时候,直接返回静态页面. 举例:首页静态化:获取首页用到的数据表中的数据,生成静态首页in ...
 - 大型网站提速关键技术(页面静态化,memcached,MySql优化)(三)
		
页面静态化的技术实现有两种方式 使用PHP自己的缓存机制 先说明一下OB缓存的机制. ob1.php 代码:说明的ob的各个用法->项目中 ☞ 如何打开ob缓存 ① 配置php.ini ...
 
随机推荐
- OstrichNet 简易统计信息收集工具
			
Ostrich 是twitter用于监控服务器性能的一个scala库,项目地址https://github.com/twitter/ostrich, 主要功能是收集.展示统计信息, 同时也提供了关闭服 ...
 - ASP.Net请求处理机制初步探索之旅 - Part 2 核心
			
开篇:上一篇我们了解了一个请求从客户端发出到服务端接收并转到ASP.Net处理入口的过程,这篇我们开始探索ASP.Net的核心处理部分,借助强大的反编译工具,我们会看到几个熟悉又陌生的名词(类):Ht ...
 - .Net组件程序设计之对象生命周期
			
.Net组件程序设计之对象生命周期 .NET 垃圾回收 IDisposable() Using语句 .NET 垃圾回收 是CLR管理着垃圾回收器,垃圾回收器监控着托管堆,而我们使用的对象以及系统启动是 ...
 - CLR via C# 学习计划
			
本书是学习c#的人必读书,计划今年完成,读透. 书是在亚马逊买的,虽然有点小贵,但是为了情怀,咬咬牙买了. 需要学习的: CLR基础 (CH1-CH3) 设计类型 (CH4-CH13) 基本类型 (C ...
 - jdbc在mysql下一次执行多条sql脚本
			
默认连接mysql的时候一次只能执行一条sql.要批量执行sql需要在jdbcUrl中增加“allowMultiQueries=true”参数,完整jdbcUrl如下: jdbc:mysql://l ...
 - springboot之HelloWorld
			
简介 为了简化开发Spring的复杂度,Spring提供了SpringBoot可以快速开发一个应用,这里就简单介绍下SpringBoot如何快速开发一个J2EE应用 HelloWorld 首先在gra ...
 - AngularJs之二
			
今天先讲一个angularJs的表单绑定实例: <div ng-app="myApp" ng-controller="formCtrl"> < ...
 - @OutputCache 详解-文章目录
			
OutputCache概念学习 OutputCache属性详解(一)一Duration.VaryByParam OutputCache属性详解(二)一 Location OutputCache属性详解 ...
 - xcode常见错误处理
			
问题:xcode 7编译错误:bitcode is not supported on versions of iOS prior to 6.0 解决:Build Options | Enable Bi ...
 - 深入理解DOM事件机制系列第一篇——事件流
			
× 目录 [1]历史 [2]事件冒泡 [3]事件捕获[4]事件流 前面的话 javascript操作CSS称为脚本化CSS,而javascript与HTML的交互是通过事件实现的.事件就是文档或浏览器 ...