程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> PHP 批量生成靜態html

PHP 批量生成靜態html

編輯:關於PHP編程

眾所周知,大部分網站的新聞資訊或商品信息都是靜態頁面。這樣做的好處主要是為了: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


view plaincopy to clipboardprint?<?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'; 

?> 
<?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


view plaincopy to clipboardprint?<?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; 
    } 

?> 
<?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


view plaincopy to clipboardprint?<?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()); 
        } 
    } 

?> 
<?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


view plaincopy to clipboardprint?<?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; 

?> 
<?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 為例)\

運行完畢截圖:
\

 運行2分鐘左右就可以生成 9000多 html。

摘自 Lee.的專欄

 


  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved