从PHP生成HTML静态页面并存储到以年份和月份为名称创建的目录。
读取全部数据批量生成,全部生成后弹出提示。
可指定批次生成数量,建议不超过800,否则执行速度会有问题。
(出于众所周知的原因,涉及到数据库的数据字段名称做了改动,并且为了代码明晰去掉了参数过滤的部分)
说明:原动态地址为 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
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
|
<?php if ( $_GET [pg]== '' ){ $aa =1; } else { $aa = $_GET [pg]; } include ( "admin/conn.php" ); require_once ( "page.php" ); $result =mysql_query( "select * from 2carsell " ); $totle =mysql_num_rows( $result ); $pagelist = $_GET [t]; if ( $_GET [t]== '' ){ $pagelist = '200' ; } else { $pagelist = $_GET [t]; } $pager = new Pager( $totle , $pagelist ); $datastat = " 共 <b>" . $pager ->countall. "</b> 条,每次生成 <b>" . $pager ->countlist. "</b> 条,共需生成 <b>" . $pager ->page. "</b> 次" ; //数据统计 $bb = $pager ->page; $pagenav = $pager ->backstr. $pager ->thestr. $pager ->nextstr; $limitFrom = $pagelist *( $pager ->pg-1); $result =mysql_query( "select * from 2carsell ORDER BY id DESC limit $limitFrom,$pagelist" ); ?> <center><div style= "font-size:14px;" ><b>第 <font color=red><? echo $aa ?></font > 次页面生成中..<? echo $datastat ?></b></div><br> <? //php生成静态页面 print "<center><textarea name=textarea class=textarea style='width:520px;height:455px'>" ; while ( $datauser =mysql_fetch_array( $result )){ $iid = $datauser [id]; $html = file_get_contents ( "/moban.php?id=" . $iid . "" ); $sql = "select * from 2carsell where id=$iid" ; $data =mysql_fetch_array(mysql_query( $sql )); $path = date ( "Ym" , $data [PutDate]); $testdir = "html/" . $path ; if ( file_exists ( $testdir )): else : mkdir ( $testdir , 0777); echo "目录" . $testdir . "创建成功!<br>" ; endif ; $filename = "html/$path/sell_$iid.html" ; // 使用写入模式打开$filename if (! $handle = fopen ( $filename , 'w' )) { print "不能打开文件 $filename" ; exit ; } if ( is_writable ( $filename )) { // 将$html写入到我们打开的文件中。 if (!fwrite( $handle , $html )) { print "不能写入到文件 $filename" ; exit ; } print "文件 $filename 更新成功!\n\r" ; fclose( $handle ); } else { print "文件 $filename 不可写" ; } ?> <? }?> </textarea> <br><br> <div style= "font-size=12px" ><? echo $datastat . " " ?></div><br><br> <? $aa = $aa +1; if ( $aa > $bb ){ echo '<font color=blue>恭喜,所有页面生成完毕!</font>' ; echo "<script>alert('所有文档生成/更新完毕!')</script>" ; } else { echo "<Script> window.location='make.php?t=$pagelist&pg=$aa'; </script>" ; } ?> |
看完实例,我们接着来分析分析
一般来说 用php转换输出html页面有两种办法 引用大虾的文章如下:
第一种:利用模板。目前PHP的模板可以说是很多了,有功能强大的smarty,还有简单易用的smarttemplate等。它们每一种模板,都有一个获取输出内容的函数。我们生成静态页面的方法,就是利用了这个函数。用这个方法的优点是,代码比较清晰,可读性好。
这里我用smarty做例子,说明如何生成静态页:
1
2
3
4
5
6
7
8
9
10
|
<?php require ( "smarty/Smarty.class.php" ); $t = new Smarty; $t ->assign( "title" , "Hello World!" ); $content = $t ->fetch( "templates/index.htm" ); //这里的 fetch() 就是获取输出内容的函数,现在$content变量里面,就是要显示的内容了 $fp = fopen ( "archives/2005/05/19/0001.html" , "w" ); fwrite( $fp , $content ); fclose( $fp ); ?> |
第二种方法:利用ob系列的函数。这里用到的函数主要是 ob_start(), ob_end_flush(), ob_get_content(),其中ob_start()是打开浏览器缓冲区的意思,打开缓冲后,所有来自PHP程序的非文件头信息均不会发送,而是保存在内部缓冲区,直到你使用了ob_end_flush().而这里最重要的一个函数,就是ob_get_contents(),这个函数的作用是获取缓冲区的内容,相当于上面的那个fetch(),道理一样的。
1
2
3
4
5
6
7
8
|
<?php ob_start(); echo "Hello World!" ; $content = ob_get_contents(); //取得php页面输出的全部内容 $fp = fopen ( "archives/2005/05/19/0001.html" , "w" ); fwrite( $fp , $content ); fclose( $fp ); ?> |
我选用的第2种方法 也就是用ob系列的函数
我刚开始看这个的时候有点不太明白 后来才知道ob是output buffering的意思 也就是输出缓存
当你准备输出的时候 所有的数据都保存在ob里面 服务器解析完php以后 把所有要输出到客户端的html代码都存放在ob里面 如果我们要输出html静态页面 只要把缓存取出来写入一个html页面即可
所以原理其实是很简单的
这里用到了几个函数 由于我初学php 很多函数我还不了解 所以这里也说明一下 希望可以帮助大家
ob_start():开始“捕捉”缓存 也就是从这里开始 打开浏览器的缓存
ob_end_flush():关闭浏览器缓存
ob_get_content():读取缓存内容
fopen(”文件路径”,”打开模式”)打开文件 这个函数的打开模式有好几种 下面介绍几种主要的模式:
“r” 只读方式打开,将文件指针指向文件头。
“r+” 读写方式打开,将文件指针指向文件头。
“w” 写入方式打开,将文件指针指向文件头并将文件大小截为零。如果文件不存在则尝试创建之。
“w+” 读写方式打开,将文件指针指向文件头并将文件大小截为零。如果文件不存在则尝试创建之。
fwrite(”文件名称”,”写入内容”) 写入文件
fclose() 关闭文件
由于我要转换的html文件非常多 可能有几百个 所以这里不能静态指定fopen的路径 大家可以设置一个路径变量 里面可以保存用户传来的id等信息 方便进行html文件命名 下面是我结合上次php读取xml数据的一个简单例子
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
<?php ob_start(); //打开浏览器缓存 //下面是读取xml数据 $parser = xml_parser_create(); //创建一个parser编辑器 xml_set_element_handler( $parser , "startElement" , "endElement" ); //设立标签触发时的相应函数 这里分别为startElement和endElenment xml_set_character_data_handler( $parser , "characterData" ); //设立数据读取时的相应函数 $xml_file = "1.xml" ; //指定所要读取的xml文件,可以是url $filehandler = fopen ( $xml_file , "r" ); //打开文件 while ( $data = fread ( $filehandler , 4096)) { xml_parse( $parser , $data , feof ( $filehandler )); } //每次取出4096个字节进行处理 fclose( $filehandler ); xml_parser_free( $parser ); //关闭和释放parser解析器 $name =false; $position =false; function startElement( $parser_instance , $element_name , $attrs ) //起始标签事件的函数 { global $name , $position ; if ( $element_name == "NAME" ) { $name =true; $position =false; echo "名字:" ; } if ( $element_name == "POSITION" ) { $name =false; $position =true; echo "职位:" ; } } function characterData( $parser_instance , $xml_data ) //读取数据时的函数 { global $name , $position ; if ( $position ) echo $xml_data . "<br />" ; if ( $name ) echo $xml_data . "<br />" ; } function endElement( $parser_instance , $element_name ) //结束标签事件的函数 { global $name , $position ; $name =false; $position =false; } //xml数据读取完毕 $htmlname = $id . ".html" ; //$id可以自己定义 这里代表用户传来的id $htmlpath = "archives/" . $htmlname ; //设置路径变量 $content = ob_get_contents(); //取得php页面输出的全部内容 $fp = fopen ( $htmlpath , "w" ); fwrite( $fp , $content ); fclose( $fp ); ?> |