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

PHP生成HTML靜態頁面,phphtml靜態頁面

編輯:關於PHP編程

PHP生成HTML靜態頁面,phphtml靜態頁面


功能:

從PHP生成HTML靜態頁面並存儲到以年份和月份為名稱創建的目錄。
讀取全部數據批量生成,全部生成後彈出提示。
可指定批次生成數量,建議不超過800,否則執行速度會有問題。

 為jbxue.com網站功能而開發,代碼為本人原創,生成速度一般。 

(出於眾所周知的原因,涉及到數據庫的數據字段名稱做了改動,並且為了代碼明晰去掉了參數過濾的部分) 

 說明:原動態地址為 moban.php?id=1 ,生成後地址為 html/200808/sell_1.html 。page.php為分頁程序,本博客中有發布。 

頁面使用方式,將本代碼保存為make.php,使用方法為浏覽器訪問 make.php?t=數量&pg=頁面;例如 make.php?t=300&pg=2,即每次生成300條數據,從數據列表第2頁開始生成,即跳過前面300條。如果不加任何參數,直接訪問make.php,則默認每次生成200條,從第一頁開始生成。

例子:

  1. <?php   
  2. if($_GET[pg]==''){   
  3. $aa=1;   
  4. }else{   
  5. $aa=$_GET[pg];   
  6. }   
  7. include("admin/conn.php");   
  8. require_once("page.php");   
  9. $result=mysql_query("select * from 2carsell ");   
  10. $totle=mysql_num_rows($result);   
  11. $pagelist = $_GET[t];   
  12. if($_GET[t]==''){   
  13. $pagelist='200';   
  14. }else{   
  15. $pagelist=$_GET[t];   
  16. }   
  17. $pager = new Pager($totle,$pagelist);   
  18. $datastat=" 共 <b>".$pager->countall."</b> 條,每次生成 <b>".$pager->countlist."</b> 條,共需生成 <b>".$pager->page."</b> 次";//數據統計   
  19. $bb=$pager->page;   
  20. $pagenav=$pager->backstr.$pager->thestr.$pager->nextstr;   
  21. $limitFrom = $pagelist*($pager->pg-1);   
  22. $result=mysql_query("select * from 2carsell ORDER BY id DESC limit $limitFrom,$pagelist");   
  23. ?>   
  24. <center><div ><b>第 <font color=red><?echo $aa?></font > 次頁面生成中..<? echo $datastat?></b></div><br>   
  25. <?   
  26. //php生成靜態頁面  
  27. // www.jbxue.com  
  28. print "<center><textarea name=textarea class=textarea style='width:520px;height:455px'>";   
  29. while($datauser=mysql_fetch_array($result)){   
  30.   
  31. $iid=$datauser[id];   
  32. $html = file_get_contents("/moban.php?id=".$iid."");   
  33. $sql="select * from 2carsell where id=$iid";   
  34. $data=mysql_fetch_array(mysql_query($sql));   
  35. $path=date("Ym",$data[PutDate]);   
  36. $testdir="html/".$path;   
  37. if(file_exists ($testdir)):   
  38. else:   
  39. mkdir ($testdir, 0777);   
  40. echo "目錄".$testdir."創建成功!<br>";   
  41. endif;   
  42.   
  43. $filename = "html/$path/sell_$iid.html";   
  44.   
  45. // 使用寫入模式打開$filename   
  46. if (!$handle = fopen($filename, 'w')) {   
  47. print "不能打開文件 $filename";   
  48. exit;   
  49. }   
  50.   
  51. if (is_writable($filename)) {   
  52.   
  53. // 將$html寫入到我們打開的文件中。   
  54. if (!fwrite($handle, $html)) {   
  55. print "不能寫入到文件 $filename";   
  56. exit;   
  57. }   
  58.   
  59. print "文件 $filename 更新成功!\n\r";   
  60.   
  61. fclose($handle);   
  62.   
  63. } else {   
  64. print "文件 $filename 不可寫";   
  65. }   
  66. ?>   
  67. <? }?>   
  68. </textarea>   
  69. <br><br>   
  70. <div ><? echo $datastat."  "?></div><br><br>   
  71. <?   
  72. $aa=$aa+1;   
  73. if($aa>$bb){   
  74. echo '<font color=blue>恭喜,所有頁面生成完畢!</font>';   
  75. echo "<script>alert('所有文檔生成/更新完畢!')</script>";   
  76. }else{   
  77. echo "<Script> window.location='make.php?t=$pagelist&pg=$aa'; </script>";   
  78. }   
  79. ?>  
 

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