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 和 MySQL 时区的一点总结
Mar 26 PHP
php 获取mysql数据库信息代码
Mar 12 PHP
PHP+MySQL 制作简单的留言本
Nov 02 PHP
php使用date和strtotime函数输出指定日期的方法
Nov 14 PHP
Thinkphp搭建包括JS多语言的多语言项目实现方法
Nov 24 PHP
WIFI万能钥匙密码查询接口实例
Sep 28 PHP
PHP信号量基本用法实例详解
Feb 12 PHP
CI映射(加载)数据到view层的方法
Mar 28 PHP
php字符串的替换,分割和连接方法
May 23 PHP
PHP中SERIALIZE和JSON的序列化与反序列化操作区别分析
Oct 11 PHP
php设计模式之单例模式用法经典示例分析
Sep 20 PHP
laravel 多图上传及图片的存储例子
Oct 14 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
Optimizer与Debugger兼容性问题的解决方法
2008/12/01 PHP
php实现图片上传并利用ImageMagick生成缩略图
2016/03/14 PHP
laravel 解决路由除了根目录其他都404的问题
2019/10/18 PHP
Laravel 微信小程序后端搭建步骤详解
2019/11/26 PHP
基于jquery的一行代码轻松实现拖动效果
2010/12/28 Javascript
JQuery拖拽元素改变大小尺寸实现代码
2012/12/10 Javascript
JavaScript实现DIV层拖动及动态增加新层的方法
2015/05/12 Javascript
Javascript显示和隐藏ul列表的方法
2015/07/15 Javascript
JS使用正则表达式除去字符串中重复字符的方法
2015/11/05 Javascript
BootStrap Table 分页后重新搜索问题的解决办法
2016/08/08 Javascript
原生js实现吸顶效果
2017/03/13 Javascript
vue.js的手脚架vue-cli项目搭建的步骤
2017/08/30 Javascript
JS运动特效之链式运动分析
2018/01/24 Javascript
用ES6写全屏滚动插件的示例代码
2018/05/02 Javascript
angular6.x中ngTemplateOutlet指令的使用示例
2018/08/09 Javascript
js+css3实现简单时钟特效
2020/09/13 Javascript
Python 列表list使用介绍
2014/11/30 Python
Python中统计函数运行耗时的方法
2015/05/05 Python
在Python中操作列表之List.append()方法的使用
2015/05/20 Python
django批量导入xml数据
2016/10/16 Python
Python数据分析之获取双色球历史信息的方法示例
2018/02/03 Python
详解Python计算机视觉 图像扭曲(仿射扭曲)
2019/03/27 Python
Python+OpenCV采集本地摄像头的视频
2019/04/25 Python
TensorFlow tf.nn.softmax_cross_entropy_with_logits的用法
2020/04/19 Python
为什么说python适合写爬虫
2020/06/11 Python
ProForm英国站点:健身房和健身器材网上商店
2019/06/05 全球购物
员工安全责任书范本
2014/07/24 职场文书
生物工程专业求职信
2014/09/03 职场文书
教师群众路线教育实践活动学习笔记
2014/11/05 职场文书
预备党员转正材料
2014/12/19 职场文书
颐和园英文导游词
2015/01/30 职场文书
民事诉讼代理词
2015/05/25 职场文书
《秋思》教学反思
2016/02/23 职场文书
文明和谐家庭事迹材料(2016精选版)
2016/02/29 职场文书
python 爬取哔哩哔哩up主信息和投稿视频
2021/06/07 Python
Pygame Event事件模块的详细示例
2021/11/17 Python