ホームページ バックエンド開発 PHPチュートリアル PHP バッチ生成静的 html_PHP チュートリアル

PHP バッチ生成静的 html_PHP チュートリアル

Jul 13, 2016 pm 05:48 PM
html php 情報 商品 バッチ ニュース 生成する ネット 情報 静的 ページ

ご存知のとおり、ほとんどの Web サイトのニュース情報や製品情報は静的なページです。これを行うことの主な利点は次のとおりです。 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


plaincopy をクリップボードに表示print? 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'); // データベースパスワード (実際の状況に応じて設定してください)
関数 __autoload($className) {
require_once ROOT_PATH . ucfirst($className)
; }
?>
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'); // データベースパスワード (実際の状況に応じて設定してください)
関数 __autoload($className) {
require_once ROOT_PATH . '/includes/'.ucfirst($className) .'.class.php';
}
?>
DB.class.php

plaincopy をクリップボードに表示print? // データベースに接続します
クラス DB {
静的パブリック関数 getDB() {
{
をお試しください $pdo = 新しい PDO(DB_DSN, DB_USER, DB_PWD); $pdo->setAttribute(PDO::ATTR_PERSISTENT, true); // データベース接続を永続接続に設定します
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION) // セットアップでエラーがスローされます
$ PDO-& GT; Setattribute (PDO :: Attr_Ooracle_nulls, TRUE); // 文字列を空の SQL に変換します
$pdo->query('SET NAMES utf8') // データベースのエンコーディングを設定します
} catch (PDOException $e) {
exit( 'データベース接続エラー、エラーメッセージ:'。$ e-> getmessage()); }
$pdo を返します
}
}
?>
// データベースに接続します
クラス DB {
静的パブリック関数 getDB() {
試してみてください{
$pdo = 新しい 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') // データベースのエンコーディングを設定します
} キャッチ (PDOException $e) {
exit('データベース接続エラー、エラー メッセージ:'. $e->getMessage());
}
$pdo を返します;
}
}
?>
Model.class.php


plaincopy をクリップボードに表示print? // SQL を操作します
クラスモデル {
    /**
* SQL の追加、削除、変更操作では、影響を受ける行の数を返します
* @param 文字列 $sql
* @return int
​​*/
    パブリック関数 aud($sql) {
        {
を試してください             $pdo = Db::getDB(); 
            $row = $pdo->exec($sql); 
        } catch (PDOException $e) {
            exit($e->getMessage()); 
        }
        $row を返します。 
    }
     
    /**
* すべてのデータを返し、PDOStatement オブジェクトを返します
* @param 文字列 $sql
* @return PDOStatement
​​*/
    パブリック関数 getAll($sql) {
        {
を試してください             $pdo = Db::getDB(); 
            $result = $pdo->query($sql); 
            $result を返します。 
        } catch (PDOException $e) {
            exit($e->getMessage()); 
        }
    }
}
?> 
// SQL を操作します
クラスモデル{
 /**
* SQL の追加、削除、変更操作では、影響を受ける行の数を返します
* @param 文字列 $sql
* @return int
​*/
 パブリック関数 aud($sql) {
  試してみてください{
   $pdo = Db::getDB();
   $row = $pdo->exec($sql);
  } キャッチ (PDOException $e) {
   exit($e->getMessage());
  }
  $row を返します;
 }
 
 /**
* すべてのデータを返し、PDOStatement オブジェクトを返します
* @param 文字列 $sql
* @return PDOStatement
​*/
 パブリック関数 getAll($sql) {
  試してみてください{
   $pdo = Db::getDB();
   $result = $pdo->query($sql);
   $result を返します;
  } キャッチ (PDOException $e) {
   exit($e->getMessage());
  }
 }
}
?>
        インデックス.php


plaincopy をクリップボードに表示print? require_once './config.inc.php'; $m = 新しいモデル
; $ids = $m->getAll("ID ASC 順に記事から ID を選択"); 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 FROMarticle WHERE id =". $articleId); // $re は各記事のコンテンツです。 注: そのタイプは次のとおりです。 :PDOステートメント
$article = array(); // $article は各記事のタイトル、日付、著者、内容、ソースを保存する配列です
foreach ($re として $r) {
$article = array(
'タイトル'=>$r['タイトル']、
「日付」=>$r[「日付」]、
‘著者’=>$r['著者'],
‘ソース’=>$r['ソース'],
「コンテンツ」=>$r['コンテンツ']
); }
$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}> をデータベースから読み取ったタイトルに置き換え、その値を変数 $articleContent に割り当てます
; $articleContent = getArticle(array_keys($article), $articleContent, $article); $resource = fopen($fileName, 'w'); File_put_contents($fileName, $articleContent) // HTML ファイルを書き込みます
}

/**
* getArticle($arr, $content, $article) はテンプレートを置き換えます
* @param 配列 $arr 置換変数配列
* @param string $content テンプレートのコンテンツ
* @param array $article 各記事のコンテンツの配列、形式: array('title'=>xx, 'date'=>xx, 'author'=>xx, 'source'=>xx, 'コンテンツ '=>xx);
​*/
関数 getArticle($arr, $content, $article) {
// ループ置換
foreach ($arr as $item) {
$content = str_replace('<{'. $item .'}>', $article[$item], $content); }
$content を返します。 }
?>
require_once './config.inc.php';
$m = 新しいモデル();
$ids = $m->getAll("記事から ID を選択 ID ASC で注文");
foreach ($ids as $rowIdArr) {
$idStr .= $rowIdArr['id'].',';
}
$idStr = rtrim($idStr, ',') // 全記事のID番号の集合
; $idArr =explode(',', $idStr) // 配列に分割します
; //次のプログラムはループして静的ページを生成します
foreach ($idArr として $articleId) {
$re = $m->getAll("SELECT id,title,date,author,source,content FROMarticle WHERE id =". $articleId); // $re は各記事のコンテンツです。 注: そのタイプは次のとおりです。 :PDOステートメント
$article = array(); // $article は各記事のタイトル、日付、著者、内容、ソースを保存する配列です
foreach ($re として $r) {
$article = 配列(
'タイトル'=>$r['タイトル'],
'日付'=>$r['日付'],
'著者'=>$r['著者'],
'ソース'=>$r['ソース'],
'コンテンツ'=>$r['コンテンツ']
);
}
$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}> をデータベースから読み取ったタイトルに置き換え、その値を変数 $articleContent
; $articleContent = getArticle(array_keys($article), $articleContent, $article);
$resource = fopen($fileName, 'w');
file_put_contents($fileName, $articleContent) //HTML ファイルを書き込みます
}

/**

* getArticle($arr, $content, $article) はテンプレートを置き換えます
* @param 配列 $arr 置換変数配列
* @param string $content テンプレートのコンテンツ
* @param array $article 各記事のコンテンツの配列、形式: array('title'=>xx, 'date'=>xx, 'author'=>xx, 'source'=>xx, 'コンテンツ '=>xx);
​*/
function getArticle($arr, $content, $article) {
// ループの置き換え
foreach ($arr as $item) {
$content = str_replace('<{'. $item .'}>', $article[$item], $content);
}
$content を返します;
}
?>
​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​(Windows DOS を例として)

実行後のスクリーンショット:


9,000 を超える HTML を生成するには約 2 分かかります。

Lee.さんのコラムより抜粋



http://www.bkjia.com/PHPjc/478451.htmlwww.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/478451.html技術記事ご存知のとおり、ほとんどの Web サイト上のニュース情報や製品情報のほとんどは静的なページです。これを行う主な利点は次のとおりです。 1. アクセスを高速化し、過剰なデータベース操作を回避します。 2. S...
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Dec 24, 2024 pm 04:42 PM

PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

CakePHP の日付と時刻 CakePHP の日付と時刻 Sep 10, 2024 pm 05:27 PM

Cakephp4 で日付と時刻を操作するには、利用可能な FrozenTime クラスを利用します。

CakePHP について話し合う CakePHP について話し合う Sep 10, 2024 pm 05:28 PM

CakePHP は、PHP 用のオープンソース フレームワークです。これは、アプリケーションの開発、展開、保守をより簡単にすることを目的としています。 CakePHP は、強力かつ理解しやすい MVC のようなアーキテクチャに基づいています。モデル、ビュー、コントローラー

CakePHP ファイルのアップロード CakePHP ファイルのアップロード Sep 10, 2024 pm 05:27 PM

ファイルのアップロードを行うには、フォーム ヘルパーを使用します。ここではファイルアップロードの例を示します。

CakePHP バリデータの作成 CakePHP バリデータの作成 Sep 10, 2024 pm 05:26 PM

Validator は、コントローラーに次の 2 行を追加することで作成できます。

PHP 開発用に Visual Studio Code (VS Code) をセットアップする方法 PHP 開発用に Visual Studio Code (VS Code) をセットアップする方法 Dec 20, 2024 am 11:31 AM

Visual Studio Code (VS Code とも呼ばれる) は、すべての主要なオペレーティング システムで利用できる無料のソース コード エディター (統合開発環境 (IDE)) です。 多くのプログラミング言語の拡張機能の大規模なコレクションを備えた VS Code は、

CakePHP クイックガイド CakePHP クイックガイド Sep 10, 2024 pm 05:27 PM

CakePHP はオープンソースの MVC フレームワークです。これにより、アプリケーションの開発、展開、保守がはるかに簡単になります。 CakePHP には、最も一般的なタスクの過負荷を軽減するためのライブラリが多数あります。

PHPでHTML/XMLを解析および処理するにはどうすればよいですか? PHPでHTML/XMLを解析および処理するにはどうすればよいですか? Feb 07, 2025 am 11:57 AM

このチュートリアルでは、PHPを使用してXMLドキュメントを効率的に処理する方法を示しています。 XML(拡張可能なマークアップ言語)は、人間の読みやすさとマシン解析の両方に合わせて設計された多用途のテキストベースのマークアップ言語です。一般的にデータストレージに使用されます

See all articles