PHP模版页面静态化

来源:互联网 发布:阿里云业务经理的压力 编辑:程序博客网 时间:2024/06/07 03:42

<?php
header('Content-Type:text/html;charset=utf-8');//编码设置
/*
 *Powered by leeyea
 *2011-11-16

 

大概步骤: 

 一、建立数据库news_db
   news表字段:id、title、content、path(HTML文件路径)
  二、提交数据的表单页面add.html
      表单action到add.php
  三、创建一个HTML模版model.html
       <html>
    <body>
    新闻的标题:{title}
    新闻的内容:{content}
    </body>
    </html>
    模版说明:
         1.模版界面根据自己的思路设计(前台美工)
   2.预留出需要被替换的区域,用存放{title}和{content}
         2.大括号{title}和{content}里面的标记必须存在,方便后面php函数来替换 
*/

 

/************************************add.php 添加,数据处理页面*******************************/

//以下创建num_count.txt文本文档,其值自动计数
$txt="num_count.txt";//用来生成不同的文件名(数字)
if(!file_exists("$txt")){
fopen($txt,'w');//写入或创建的方式打开,如果此文档不存在,则自动创建test.txt文本文件
}
$fp=fopen($txt,'r');//如果存在,以只读的方式访问
$num=fgets($fp,20);//读取文档中20-1个字符数
$num=$num+1;//每次其值自动加1
fclose($fp);

$fp=fopen($txt,'w');
fwrite($fp,$num);//更新其值
fclose($fp);

//利用上面自动计数的值获得HTML静态路径path,并且生成的路径是自动增长的;
//如1.html、2.html…每增加一条新闻便自动加1
$houzui='.html';//网页格式后缀
$folder='newsfile/';//存放的文件夹名字
$path=$folder.$num.$houzui;//生成的文件名

//此处用sql语句把表单数据insert到数据表news中去
require_once('inc/conn.php');
$title=$_GET['title'];
$content=$_GET['content'];
$sql="insert into news (title,content,path)values('$title','$content','$path')";
$query=mysql_query($sql)or die('操作失败');
//以下是关键,把从表单获得的数据替换模版中的{title},{content}标记
$fp=fopen('model.html','r');
$str=fread($fp,filesize('model.html'));//读取模版中内容
$str=str_replace('{title}',$title,$str);//把表单来的变量替换到模版中的{title}
$str=str_replace('{content}',$content,$str);//把表单来的变量替换模版中的{content}
fclose($fp);

$page=fopen($path,'w');//写入方式促使其生成html页面,作为新闻标题链接的页面
fwrite($page,$str);//把之前模版里的内容写入生成的html页面
fclose($page);
/*---------------------------结束-----------------------------*/
//测试程序的运行
header("location:index.php");
//注:此页面不能刷新,否则会生成新的文件

 

/*******************************update.php更新数据************************************/

//接收传过来的文件路径作为数据库检索的条件

//先更新数据库
$sql="update news set title='$title',content='$content' where path='$path'";
$query=mysql_query($sql)or die('更新数据库记录失败');
//再打开更新对应的模版生成的html文件
$model=fopen('model.html','r');
$str=fread($model,filesize('model.html'));
$str=str_replace('{title}',$title,$str);
$str=str_replace('{content}',$content,$str);
fclose($model);
$page=fopen($path,'w');//打开待更新的页面
fwrite($page,$str);//写入新的数据
fclose($page);

 

 

/**************************************del.php删除数据************************************/

 //先删除数据库中的对应记录
 $sql1="delete from news where path='$path'";
 $query1=mysql_query($sql1)or die('操作数据库失败');
 mysql_close($conn);

//再删除物理文件
  if(file_exists($path)){
  unlink($path);
   echo '删除物理文件成功';
   }else{echo '<font color=#ff0000>要删除的物理文件不存在</font>';}
 }

 

 


/*---------------------------思路总结-----------------------------
设计模版,把需要被替换的内容用{}放到模版相应的位置
修改也是一样,先用update语句更新数据库(以传过来的$path作为关键字检索);然后重新赋值给模版,再次打开生成的页面,把模版内容给它即可;
删除,先delete表中要删除的内容,再用unlink($path)来删除html的物理文件即可;
*/
?>

原创粉丝点击