<?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的物理文件即可;
*/
?>