config.inc.php
view plaincopy to clipboardprint? Db.class.php
view plaincopy to clipboardprint?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; } } ?> 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?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()); } } } ?> 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?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,替换完毕赋值给变量 $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(”, $article[$item], $content); } return $content; } ?> 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,替换完毕赋值给变量 $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(”, $article[$item], $content); } return $content;}?> 运行截图(Windows 的 DOS 为例)
运行完毕截图:
运行2分钟左右就可以生成 9000多 html。
摘自 Lee.的专栏
【文章转自迪拜服务器 http://www.558idc.com/dibai.html处的文章,转载请说明出处】