php中用文本文件做数据库的实现方法

  按我的经验,本人认为,以下列文件结构为最优:

  ----------------------------------------------------------------------

  文件扩展名:.php

  <? die('ACCESS DENIED!');?>

  [email protected] & nickname=redfox & realname=阿鼎 & url=http://NetNote.oso.com.cn & ...

  ...

  ----------------------------------------------------------------------

  也许大家都看出来了,以.php做扩展名,并且文件的第一行是<? die('ACCESS DENIED!');?>,这样就有效的阻止了对数据文件的非法访问。文件的第二行的格式都是:  变量名1=值1 & 变量名2=值2 & ...

  提出所有的变量很简单,就是用函数 parse_str();

  例如:

  <?

  $theline="[email protected]&nickname=redfox&realname=阿鼎&url=http://NetNote.oso.com.cn";

  parse_str($theline);//分离出变量$email,$nickname,$realname,$url

  echo "I am $nickname,my real name is $realname<br>";

  echo "welcome to visit my website:$url<br>";

  echo "email me at:$email";

  ?>

  运行结果:

  I am redfox,my real name is 阿鼎

  welcome to visit my website:http://NetNote.oso.com.cn

  email me at:[email protected]

  因此,本文约定,数据文本结构为:

  ----------------------------------------

  <? die('ACCESS DENIED!');?>

  变量名1=值1 & 变量名2=值2 & ...

  文件扩展名: .php

  ----------------------------------------

  真正的数据从第二行开始。好了,用这样的文件结构就可以很容易的实现GuestBook,BBS,甚至是社区的数据处理了:)我的主页“网络便签” http://netnote.oso.com.cn ,就是这样实现的。

  为了方便广大网友,我编了几个函数,下面将作出必要的解释。当然你可以随便的修改和挎贝,但你必须保证功能的完整性。请将下面的代码存为 textfun.inc (当然取其它的名字也是一样的),在你要使用的文件的开始部分加入一行语句<?include("textfun.inc");?>,你就可以使用我为你编的函数了。

  下面一共一个db对象,一个函数p2row();

  -------------textfun.inc----------------

  <?

  class db{

  var $dbfile;

  function createdb($dbName){

  $f=$dbName;

  $this->$dbfile=$f;

  $headInfo="<?die('ACCESS DENIED!');?>\n";

  $fp=fopen($f,"w");

  fputs($fp,$headInfo);

  fclose($fp);

  chmod($f,0777);//修改文件的模式,在Unix下也可用

  return(1);

  }

  function opendb($f){

  $this->$dbfile=$f;

  if(file_exists($f)){

  return true;

  }else{

  $this->createdb($f);

  }

  }

  function insertline($info){

  $fields=explode("|",$info);

  while(list($key,$val)=each($fields)){

  $therow.="$val=\$".$val."&";

  $var1.="\$".$val.",";

  }

  $var1.='$tail';

  eval("global $var1;"); //为了取得环境变量

  eval("\$therow=\"$therow\";");

  $fp=fopen($this->$dbfile,"a");

  fputs($fp,"$therow\n");

  fclose($fp);

  }

  function readall($f){

  if(file_exists($f)){

  $this->$dbfile=$f;

  $rows=file($f);

  for($i=1;$i<count($rows);$i++){

  $temp[]=$rows[$i];

  }

  return $temp;

  }

  }

  //以倒序的方式读入所有的数据行

  function revread($f){

  if(file_exists($f)){

  $this->$dbfile=$f;

  $rows=file($f);

  $d=count($rows);

  $j=$d-1;

  for($i=0;$i<$d;$i++){

  if($i<$j){

  $temprow=$rows[$i];

  $rows[$i]=$rows[$j];

  $rows[$j]=$temprow;

  $j--;

  }

  }

  for($i=0;$i<count($rows)-1;$i++){  //去掉首行

  $temp[]=$rows[$i];

  }

  return $temp;

  }

  }

  function close(){

  $this=$nothing;

  }

  }

  //把段落文本格式化为一行文本,便于存储

  function p2row($t){

  $t=nl2br(stripslashes(htmlspecialchars($t)));

  for($i=0;$i<strlen($t);$i++){

  $c=substr($t,$i,1);

  if(ord($c)==10) $c=" ";

  $tempstr.=$c;

  }

  return $tempstr;

  }

  ?>

  ----------------------------------

  db是我们自定义的本文数据对象,包括六个方法:createdb(),opendb(),insertline(),readall().revread(),close();

  db->createdb(string filename)

  用法例:<?

  include("textfun.inc");

  $mydb=new db;

  $mydb->createdb("UserInfo.php");

  ?>

  这个方法创建了一个文件UserInfo.php,首行是<? die('ACCESS DENIED!');?>

  db->opendb(string filename)

  用法例:<?

  include("textfun.inc");

  $mydb=new db;

  $mydb->opendb("UserInfo.php");

  ?>

  这个方法以追加模式“打开”了数据文件UserInfo.php,如果这个文件不存在,则被创建。

  因此,这个方法可以取代createdb()方法。(但千万别删了class db{  }里面的createdb()函数哦:P)

  db->insertline(string VarString)

  用法例:<?

  include("textfun.inc");

  $theline="[email protected]&nickname=redfox&realname=阿鼎&url=http://NetNote.oso.com.cn";

  parse_str($theline);//构造环境变量

  $mydb=new db;

  $mydb->opendb("UserInfo.php");

  $mydb->insertline("nickname|realname|email|url");

  ?>

  db->insertline()可以将形如"nickname|realname|email|url"的字符串,分离出相应的环境变量,并以本文约定的形式存入文件。 传入insertline()的参数,一定要用“|”把环境变量名连成字符串,个数不限,但千万别在前面加"$"哦,嗯,就是要形如"nickname|realname|email|url"这样的字符串  :~)

  array db->readall(string filename)

  用法例:<?

  include("textfun.inc");

  $mydb=new db;

  $allrec=$mydb->readall("UserInfo.php");

  ?>

  readall()方法返回除首行(<? die('ACCESS DENIED!');?>)外所有数据的数组,每行对应于数组的一个元素。

  array db->revread(string filename)

  用法例:<?

  include("textfun.inc");

  $mydb=new db;

  $allrec=$mydb->revread("UserInfo.php");

  ?>

  revread()方法以倒序方式读入除首行(<? die('ACCESS DENIED!');?>)外所有数据,返回数组。这对我们在编留言本等时候尤为有用。

  void db->close()

  关闭db对象。

  好了,我们现在就用db对象编一个最简单的留言本。

  ---------guestbook.php------------

  我的留言本<p>

  <form name=form1 action=<? echo $PHP_SELF;?>>

  NickName:<input type=text name=nickname><br>

  E-Mail:<input type=text name=email><br>

  Homepage:<input type=text name=url value="http://"><br>

  Message:<textarea name=message cols=30 rows=12></textarea><p>

  <input type=submit name=Submit value=提交>

  </form>

  <?

  include("textfun.inc");

  if($Submit){

  $thetime=date("Y-m-d h:m:s A");

  $message=p2row($message);

  $mydb=new db;

  $mydb->opendb("msg.php");

  $mydb->insertline("nickname|email|url|message|thetime");

  //以下读出所有的数据

  $allrecs=$mydb->revread("msg.php");

  while(list($key,$theline)=each($allrecs)){

  parse_str($theline);

  ?>

  <a href="mailto:<?echo $email;?>"><?echo $nickname;?></a><?echo $thetime;?><br>

  URL:<a href="<?echo $url;?>"><?echo $url;?></a><br>

  Message:<br><?echo stripslashes($message);?><hr noshade size=1>

  <?

  }

  $mydb->close();

  }

  ?>

  -----------------------------

  好了,虽然这个留言本不是很美观,但主要是为了举例说明db对象的用法~:)

  本文在WIN98+PWS+PHP4下调试通过!