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 相关文章推荐
一个没有MYSQL数据库支持的简易留言本的编写
Oct 09 PHP
如何利用PHP执行.SQL文件
Jul 05 PHP
php正则匹配html中带class的div并选取其中内容的方法
Jan 13 PHP
php递归实现无限分类的方法
Jul 28 PHP
使用PHP+AJAX让WordPress动态加载文章的教程
Dec 11 PHP
详解PHP中cookie和session的区别及cookie和session用法小结
Jun 12 PHP
PHP数组编码gbk与utf8互相转换的两种方法
Sep 01 PHP
利用php操作memcache缓存的基础方法示例
Aug 02 PHP
ThinkPHP框架获取最后一次执行SQL语句及变量调试简单操作示例
Jun 13 PHP
PHP调用全国天气预报数据接口查询天气示例
Feb 20 PHP
原生PHP实现导出csv格式Excel文件的方法示例【附源码下载】
Mar 07 PHP
PHP基于面向对象封装的分页类示例
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
php 编写安全的代码时容易犯的错误小结
2010/05/20 PHP
php实现在限定区域里自动调整字体大小的类实例
2015/04/02 PHP
PHP的APC模块实现上传进度条
2015/10/27 PHP
总结一些js自定义的函数
2006/08/05 Javascript
javascript 弹出层组件(升级版)
2011/05/12 Javascript
javascript中setTimeout的问题解决方法
2014/05/08 Javascript
24款热门实用的jQuery插件推荐
2014/12/24 Javascript
JavaScript多线程详解
2015/08/12 Javascript
javascript点击按钮实现隐藏显示切换效果
2016/02/03 Javascript
jQuery实现三级菜单的代码
2016/05/09 Javascript
jQuery Easy UI中根据第一个下拉框选中的值设置第二个下拉框是否可以编辑
2016/11/29 Javascript
vue脚手架中配置Sass的方法
2018/01/04 Javascript
JS常见DOM节点操作示例【创建 ,插入,删除,复制,查找】
2018/05/14 Javascript
vue代码分割的实现(codesplit)
2018/11/13 Javascript
微信小程序实现文字无限轮播效果
2018/12/28 Javascript
javascript实现简易数码时钟
2020/03/30 Javascript
关于angular 8.1使用过程中的一些记录
2020/11/25 Javascript
python通过ffmgep从视频中抽帧的方法
2018/12/05 Python
对python修改xml文件的节点值方法详解
2018/12/24 Python
python 中如何获取列表的索引
2019/07/02 Python
python实现最大子序和(分治+动态规划)
2019/07/05 Python
Python csv模块使用方法代码实例
2019/08/29 Python
Django中使用MySQL5.5的教程
2019/12/18 Python
python同义词替换的实现(jieba分词)
2020/01/21 Python
关于Keras Dense层整理
2020/05/21 Python
如何理解Python中包的引入
2020/05/29 Python
如何使用Cython对python代码进行加密
2020/07/08 Python
基于python实现图片转字符画代码实例
2020/09/04 Python
CSS3毛玻璃效果(blur)有白边问题的解决方法
2016/11/15 HTML / CSS
Sneaker Studio匈牙利:购买运动鞋
2018/03/26 全球购物
快餐公司创业计划书
2014/04/29 职场文书
警察群众路线对照检查材料思想汇报
2014/10/01 职场文书
毕业生银行实习自我鉴定
2014/10/14 职场文书
Mysql Innodb存储引擎之索引与算法
2022/02/15 MySQL
MySQL 分区表中分区键为什么必须是主键的一部分
2022/03/17 MySQL
处理canvas绘制图片模糊问题
2022/05/11 Javascript