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 相关文章推荐
PHP分页显示制作详细讲解
Dec 05 PHP
PHP中的float类型使用说明
Jul 27 PHP
深入理解用mysql_fetch_row()以数组的形式返回查询结果
Jun 05 PHP
解析PHP中一些可能会被忽略的问题
Jun 21 PHP
php时间戳转换的示例
Mar 31 PHP
windows7下安装php的php-ssh2扩展教程
Jul 04 PHP
PHP对象相互引用的内存溢出实例分析
Aug 28 PHP
ThinkPHP模板循环输出Volist标签用法实例详解
Mar 23 PHP
php微信公众号开发模式详解
Nov 28 PHP
动态表单验证的操作方法和TP框架里面的ajax表单验证
Jul 19 PHP
PHP实现数组和对象的相互转换操作示例
Mar 20 PHP
PHP进阶学习之依赖注入与Ioc容器详解
Jun 19 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
PHP ignore_user_abort函数详细介绍和使用实例
2014/07/15 PHP
php编写批量生成不重复的卡号密码代码
2015/05/14 PHP
PHP实现二叉树的深度优先与广度优先遍历方法
2015/09/28 PHP
详解使用php调用微信接口上传永久素材
2017/04/11 PHP
点击弹出层外区域关闭弹出层jquery特效示例
2013/08/25 Javascript
JavaScript+html5 canvas实现本地截图教程
2020/04/16 Javascript
js判断复选框是否选中及选中个数的实现代码
2016/05/30 Javascript
jQuery事件详解
2017/02/23 Javascript
jQuery dateRangePicker插件使用方法详解
2017/07/28 jQuery
微信小程序冒泡事件及其阻止方法实例分析
2018/12/06 Javascript
详解微信小程序实现跑马灯效果(附完整代码)
2019/04/29 Javascript
react实现antd线上主题动态切换功能
2019/08/12 Javascript
微信小程序按顺序同步执行的两种方式
2019/12/20 Javascript
微信小程序实现简单的select下拉框
2020/11/23 Javascript
python 随机数生成的代码的详细分析
2011/05/15 Python
简单介绍Python中的round()方法
2015/05/15 Python
python实现批量监控网站
2016/09/09 Python
python如何重载模块实例解析
2018/01/25 Python
Python图像处理之简单画板实现方法示例
2018/08/30 Python
pandas对dataFrame中某一个列的数据进行处理的方法
2019/07/08 Python
Python全局锁中如何合理运用多线程(多进程)
2019/11/06 Python
使用 Python 合并多个格式一致的 Excel 文件(推荐)
2019/12/09 Python
canvas之自定义头像功能实现代码示例
2017/09/29 HTML / CSS
使用Html5中的cavas画一面国旗
2019/09/25 HTML / CSS
澳大利亚波西米亚风情网上商店:Czarina
2019/03/18 全球购物
四好少年事迹材料
2014/01/12 职场文书
人力资源部门的主要职能
2014/02/22 职场文书
财务简历的自我评价
2014/03/05 职场文书
2014年公务员思想汇报范文:全心全意为人民服务
2014/03/06 职场文书
十八届三中全会感言
2014/03/10 职场文书
邓小平文选读书笔记
2015/06/29 职场文书
文案策划岗位个人自我评价(范文)
2019/08/08 职场文书
Nginx配置SSL证书出错解决方案
2021/03/31 Servers
MySQL七种JOIN类型小结
2021/10/24 MySQL
Python Flask搭建yolov3目标检测系统详解流程
2021/11/07 Python
mysql幻读详解实例以及解决办法
2022/06/16 MySQL