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 5.3.0 安装分析心得
Aug 07 PHP
php var_export与var_dump 输出的不同
Aug 09 PHP
PHP连接局域网MYSQL数据库的简单实例
Aug 26 PHP
国产PHP开发框架myqee新手快速入门教程
Jul 14 PHP
PHP使用Pthread实现的多线程操作实例
Nov 14 PHP
php+jQuery+Ajax实现点赞效果的方法(附源码下载)
Jul 21 PHP
php redis实现文章发布系统(用户投票系统)
Mar 04 PHP
Yii 2.0中场景的使用教程
Jun 02 PHP
浅析PHP数据导出知识点
Feb 17 PHP
PHP基于swoole多进程操作示例
Aug 12 PHP
如何解决PHP获取不到SESSION信息之一般情况
Oct 10 PHP
如何理解PHP核心特性命名空间
May 28 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实现利用phpexcel导出数据
2013/08/24 PHP
Laravel中前端js上传图片到七牛云的示例代码
2017/09/04 PHP
JavaScript获取GridView中用户点击控件的行号,列号
2009/04/14 Javascript
15 个 JavaScript Web UI 库
2010/05/19 Javascript
js过滤HTML标签以及空格的思路及代码
2013/05/24 Javascript
js 本地预览的简单实现方法
2014/02/18 Javascript
AngularJS基础 ng-keypress 指令简单示例
2016/08/02 Javascript
微信小程序实现手势滑动效果
2019/08/26 Javascript
Vue页面切换和a链接的本质区别详解
2019/11/12 Javascript
[57:55]完美世界DOTA2联赛PWL S3 Magma vs Phoenix 第二场 12.12
2020/12/16 DOTA
python 基础学习第二弹 类属性和实例属性
2012/08/27 Python
Python 2.7.x 和 3.x 版本的重要区别小结
2014/11/28 Python
Python操作Access数据库基本步骤分析
2016/09/19 Python
详解Python之数据序列化(json、pickle、shelve)
2017/03/30 Python
关于python pyqt5安装失败问题的解决方法
2017/08/08 Python
Python 2.x如何设置命令执行的超时时间实例
2017/10/19 Python
python 使用poster模块进行http方式的文件传输到服务器的方法
2019/01/15 Python
Python 中包/模块的 `import` 操作代码
2019/04/22 Python
Django项目使用CircleCI的方法示例
2019/07/14 Python
python 发送json数据操作实例分析
2019/10/15 Python
python多项式拟合之np.polyfit 和 np.polyld详解
2020/02/18 Python
Python 日期与时间转换的方法
2020/08/01 Python
python爬取代理IP并进行有效的IP测试实现
2020/10/09 Python
python基于socket模拟实现ssh远程执行命令
2020/12/05 Python
Python tkinter之ComboBox(下拉框)的使用简介
2021/02/05 Python
html5指南-7.geolocation结合google maps开发一个小的应用
2013/01/07 HTML / CSS
入学生会自荐书范文
2014/02/05 职场文书
上课玩手机检讨书
2014/02/08 职场文书
安全生产汇报材料
2014/02/17 职场文书
中文专业求职信
2014/06/20 职场文书
公司收款委托书范本
2014/09/20 职场文书
店长岗位职责
2015/02/11 职场文书
2015年社区流动人口工作总结
2015/05/12 职场文书
交通安全教育主题班会
2015/08/12 职场文书
php字符串倒叙
2021/04/01 PHP
React配置子路由的实现
2021/06/03 Javascript