PHP中批量生成静态html(命令行下运行PHP)


Posted in PHP onApril 19, 2014

众所周知,大部分网站的新闻资讯或商品信息都是静态页面。这样做的好处主要是为了:1、加快访问速度,避免过多的操作数据库;2、SEO优化,便于搜索引擎收录。

本示例围绕 CMS 系统的静态页面方案出发,展示批量生成静态 html 功能。
注:本文程序只能在 Windows 的 DOS 或 Linux 下执行 PHP 命令来运行。
本示例主要有4个文件:config.inc.php(配置文件)、Db.class.php(数据库 PDO 类)、Model.class.php(PDO数据库操作类)、index.php(执行文件)
config.inc.php

<?php
header('Content-Type:text/html;Charset=utf-8');
date_default_timezone_set('PRC');
define('ROOT_PATH', dirname(__FILE__)); // 根目录
define('DB_DSN', 'mysql:host=localhost;dbname=article'); // MySQL 的 PDO dsn
define('DB_USER', 'root'); // 数据库用户名
define('DB_PWD', '1715544'); // 数据库密码(请您根据实际情况自行设定)
function __autoload($className) {
 require_once ROOT_PATH . '/includes/'. ucfirst($className) .'.class.php';
}
?>

Db.class.php

<?php
// 连接数据库
class Db {
 static public function getDB() {
  try {
   $pdo = new PDO(DB_DSN, DB_USER, DB_PWD);
   $pdo->setAttribute(PDO::ATTR_PERSISTENT, true); // 设置数据库连接为持久连接
   $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);  // 设置抛出错误
   $pdo->setAttribute(PDO::ATTR_ORACLE_NULLS, true);  // 设置当字符串为空转换为 SQL 的 NULL
   $pdo->query('SET NAMES utf8');  // 设置数据库编码
  } catch (PDOException $e) {
   exit('数据库连接错误,错误信息:'. $e->getMessage());
  }
  return $pdo;
 }
}
?>

Model.class.php

<?php
// 操作 SQL
class Model {
 /**
  * SQL 增删改操作,返回受影响的行数
  * @param string $sql
  * @return int
  */
 public function aud($sql) {
  try {
   $pdo = Db::getDB();
   $row = $pdo->exec($sql);
  } catch (PDOException $e) {
   exit($e->getMessage());
  }
  return $row;
 } /**
  * 返回全部数据,返回 PDOStatement 对象
  * @param string $sql
  * @return PDOStatement
  */
 public function getAll($sql) {
  try {
   $pdo = Db::getDB();
   $result = $pdo->query($sql);
   return $result;
  } catch (PDOException $e) {
   exit($e->getMessage());
  }
 }
}
?>

index.php

<?php 
require_once './config.inc.php';
$m = new Model();
$ids = $m->getAll("SELECT id FROM article ORDER BY id ASC");
foreach ($ids as $rowIdArr) {
 $idStr .= $rowIdArr['id'].',';
}
$idStr = rtrim($idStr, ','); // 所有文章的 ID 号集合
$idArr = explode(',', $idStr); // 分割成数组
// 下面的程序循环生成静态页面
foreach ($idArr as $articleId) {
 $re = $m->getAll("SELECT id,title,date,author,source,content FROM article WHERE id =". $articleId); // $re 为每篇文章的内容,注意:其类型为:PDOStatement
 $article = array(); // $article 为一个数组,保存每篇文章的title、date、author、content、source
 foreach ($re as $r) {
  $article = array(
     'title'=>$r['title'],
     'date'=>$r['date'],
     'author'=>$r['author'],
     'source'=>$r['source'],
     'content'=>$r['content']
    );
 }
 $articlePath = ROOT_PATH. '/article'; // $articlePath 为静态页面放置的目录
 if (!is_dir($articlePath)) mkdir($articlePath, 0777); // 检查目录是否存在,不存在则创建
 $fileName = ROOT_PATH . '/article/' . $articleId . '.html'; // $fileName 生成的静态文件名,格式:文章ID.html(主键ID不可能冲突)
 $articleTemPath = ROOT_PATH . '/templates/article.html'; // $articleTemPath 文章模板路径
 $articleContent = file_get_contents($articleTemPath); // 获取模板里面的内容
 // 对模板里面设置的变量进行替换。即比如:把模板里面的 <{title}> 替换成数据库里读取的 title,替换完毕赋值给变量 $articleContent
 $articleContent = getArticle(array_keys($article), $articleContent, $article);
 $resource = fopen($fileName, 'w');
 file_put_contents($fileName, $articleContent); // 写入 HTML 文件
}
/**
 * getArticle($arr, $content, $article) 对模板进行替换操作
 * @param array $arr 替换变量数组
 * @param string $content 模板内容
 * @param array $article 每篇文章内容数组,格式:array('title'=>xx, 'date'=>xx, 'author'=>xx, 'source'=>xx, 'content'=>xx);
 */
function getArticle($arr, $content, $article) {
 // 循环替换
 foreach ($arr as $item) {
  $content = str_replace('<{'. $item .'}>', $article[$item], $content);
 }
 return $content;
}
?>

 运行截图(Windows 的 DOS 为例) 
PHP中批量生成静态html(命令行下运行PHP)       
运行完毕截图: 

PHP中批量生成静态html(命令行下运行PHP)

运行2分钟左右就可以生成 9000多 html。

来自Lee.的专栏 转载注明出处!!!

PHP 相关文章推荐
PHPLog php 程序调试追踪工具
Sep 09 PHP
PHP 批量更新网页内容实现代码
Jan 05 PHP
php处理文件的小例子(解压缩,删除目录)
Feb 03 PHP
使用淘宝IP库获取用户ip地理位置
Oct 27 PHP
使用phpQuery采集网页的方法
Nov 13 PHP
PHP中构造函数和析构函数解析
Oct 10 PHP
一个经典实用的PHP图像处理类分享
Nov 18 PHP
PHP针对字符串开头和结尾的判断方法
Jul 11 PHP
PHP 配置后台登录以及模板引入
Jan 24 PHP
php PDO判断连接是否可用的实现方法
Apr 03 PHP
Yii框架实现图片上传的方法详解
May 20 PHP
PHP实现用户异地登录提醒功能的方法【基于thinkPHP框架】
Mar 15 PHP
PHP不用递归实现无限分级的例子分享
Apr 18 #PHP
利用php下载xls文件(自己动手写的)
Apr 18 #PHP
php生成随机字符串可指定纯数字、纯字母或者混合的
Apr 18 #PHP
从PHP的源码中深入了解stdClass类
Apr 18 #PHP
理解PHP中的stdClass类
Apr 18 #PHP
php使用imagick模块实现图片缩放、裁剪、压缩示例
Apr 17 #PHP
php实现的漂亮分页方法
Apr 17 #PHP
You might like
IIS环境下快速安装、配置和调试PHP5.2.0
2006/12/17 PHP
几个php应用技巧
2008/03/27 PHP
使用PHP求两个文件的相对路径
2013/06/20 PHP
PHP小技巧之函数重载
2014/06/02 PHP
php实现读取内存顺序号
2015/03/29 PHP
php获取图片信息的方法详解
2015/12/10 PHP
ThinkPHP中session函数详解
2016/09/14 PHP
PHP排序算法之归并排序(Merging Sort)实例详解
2018/04/21 PHP
php实现算术验证码功能
2018/12/05 PHP
PHP的PDO事务与自动提交
2019/01/24 PHP
谈谈基于iframe、FormData、FileReader三种无刷新上传文件的方法
2015/12/03 Javascript
微信小程序中单位rpx和rem的使用
2016/12/06 Javascript
Node.js数据库操作之连接MySQL数据库(一)
2017/03/04 Javascript
详解AngularJS 路由 resolve用法
2017/04/24 Javascript
vue2 自定义动态组件所遇到的问题
2017/06/08 Javascript
Node.js中 __dirname 的使用介绍
2017/06/19 Javascript
JavaScript标准对象_动力节点Java学院整理
2017/06/27 Javascript
使用JS编写的随机抽取号码的小程序
2017/08/11 Javascript
图文介绍Vue父组件向子组件传值
2018/02/17 Javascript
ES6之Proxy的get方法详解
2019/10/11 Javascript
用VsCode编辑TypeScript的实现方法
2020/05/07 Javascript
[43:24]2018DOTA2亚洲邀请赛3月29日 小组赛A组 LGD VS Liquid
2018/03/30 DOTA
python控制台英汉汉英电子词典
2020/04/23 Python
用python的requests第三方模块抓取王者荣耀所有英雄的皮肤实例
2017/12/14 Python
python实现图书管理系统
2018/03/12 Python
PyQt5 窗口切换与自定义对话框的实例
2019/06/20 Python
python3常用的数据清洗方法(小结)
2019/10/31 Python
Python 异步协程函数原理及实例详解
2019/11/13 Python
世界上最大的曲棍球商店:Pro Hockey Life
2017/10/30 全球购物
英国领先的运动营养品牌:Protein Dynamix
2018/01/02 全球购物
在c#中using和new这两个关键字有什么意义
2013/05/19 面试题
介绍一下linux的文件权限
2012/02/15 面试题
大学生职业生涯规划方案
2014/01/03 职场文书
《藏戏》教学反思
2014/02/11 职场文书
班主任高考寄语
2015/02/26 职场文书
2016年第十九届推普周活动总结
2016/04/06 职场文书