当前位置: 首页 > news >正文

android源码下载网站/南宁推广公司

android源码下载网站,南宁推广公司,网站美工培训机构,安卓开发工具包从PHP生成HTML静态页面并存储到以年份和月份为名称创建的目录。读取全部数据批量生成,全部生成后弹出提示。可指定批次生成数量,建议不超过800,否则执行速度会有问题。(出于众所周知的原因,涉及到数据库的数据字段名称做了改动&am…

从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条,从第一页开始生成。

完整实例:

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=" 共 ".$pager->countall." 条,每次生成 ".$pager->countlist." 条,共需生成 ".$pager->page." 次";//数据统计

$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");

?>

<?echo $aa?> 次页面生成中.. echo $datastat?>

//php生成静态页面

print "

";

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."创建成功!
";

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 不可写";

}

?>

}?>

echo $datastat." "?>

$aa=$aa+1;

if($aa>$bb){

echo '恭喜,所有页面生成完毕!';

echo "";

}else{

echo "";

}

?>

看完实例,我们接着来分析分析

一般来说 用php转换输出html页面有两种办法 引用大虾的文章如下:

第一种:利用模板。目前PHP的模板可以说是很多了,有功能强大的smarty,还有简单易用的smarttemplate等。它们每一种模板,都有一个获取输出内容的函数。我们生成静态页面的方法,就是利用了这个函数。用这个方法的优点是,代码比较清晰,可读性好。

这里我用smarty做例子,说明如何生成静态页:

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(),道理一样的。

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数据的一个简单例子

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."
";

if($name)

echo $xml_data."
";

}

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);

?>

http://www.lbrq.cn/news/1602559.html

相关文章:

  • 火车头wordpress自动排版/网站推广和网站优化
  • wordpress做导语/seo搜索引擎优化技术教程
  • 网站不用了怎么办/电商运营公司简介
  • 网站建设工作经历/百度帐号登录个人中心
  • 专业做网站公司怎么样/关键词文案生成器
  • lol网站怎么做/网站软文代写
  • phpbb wordpress/seo初级入门教程
  • 网站备案域名怎么买/深圳seo网络推广
  • 郴州做网站的/危机舆情公关公司
  • 做网站学什么软件/汽车推广软文
  • 彩票开奖网站开发/深圳网络营销模式
  • 北京市建设网站/免费推广的平台
  • 做网站需要学些什么条件/绍兴seo优化
  • 六安网站建设找哪家/友情链接平台站长资源
  • 淘宝做的代码能在其他网站用吗/网站的seo是什么意思
  • 好看的网站建设/长春网站优化流程
  • b2b2c网站开发/伟哥seo博客
  • 子网站怎么建设/关键词查询
  • 个人工商户做网站备案/莆田网站建设优化
  • 网站建设 价格/网络推广如何收费
  • 个人网站可以做音乐下载网/合肥网站推广助理
  • 网站下载文件怎么做/百度搜索网
  • 专做定制旅游网站有哪些/微信广告平台
  • 建设局网站首页/整站seo定制
  • 网站开发项目经理职责/百度教育小程序
  • 智慧旅游网站开发与设计/排名优化百度
  • 贵港网站建设公司/seo网页优化服务
  • 怎么看一个网站做得好不好/百度客服电话是多少
  • 网站建设新闻资讯/安卓优化大师官网下载
  • 如何整理网站/软文推广代表平台
  • Kafka 是什么?
  • Ubuntu22.4部署大模型前置安装
  • Python-初学openCV——图像预处理(六)
  • Codeforces Round 1039 (Div. 2) A-C
  • 自建rustdesk服务器过程记录
  • 前端图片懒加载的深度指南:从理论到实战