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

2018-09-08 01:01

阅读:497

  按我的经验,本人认为,以下列文件结构为最优:
----------------------------------------------------------------------
文件扩展名:.php
<?die(ACCESSDENIED!);?>
...
----------------------------------------------------------------------
也许大家都看出来了,以.php做扩展名,并且文件的第一行是<?die(ACCESSDENIED!);?>,这样就有效的阻止了对数据文件的非法访问。文件的第二行的格式都是:变量名1=值1&变量名2=值2&...
提出所有的变量很简单,就是用函数parse_str();
例如:
<?
$theline=email=ask4more@13.net&nickname=redfox&realname=阿鼎&url=
parse_str($theline);//分离出变量$email,$nickname,$realname,$url
echoIam$nickname,myrealnameis$realname<br>;
echowelcometovisitmywebsite:$url<br>;
echoemailmeat:$email;
?>
运行结果:
Iamredfox,myrealnameis阿鼎
welcometovisitmywebsite:
emailmeat:ask4more@13.net

因此,本文约定,数据文本结构为:
----------------------------------------
<?die(ACCESSDENIED!);?>
变量名1=值1&变量名2=值2&...

文件扩展名:.php
----------------------------------------

真正的数据从第二行开始。好了,用这样的文件结构就可以很容易的实现GuestBook,BBS,甚至是社区的数据处理了:)我的主页“网络便签”,就是这样实现的。
为了方便广大网友,我编了几个函数,下面将作出必要的解释。当然你可以随便的修改和挎贝,但你必须保证功能的完整性。请将下面的代码存为(当然取其它的名字也是一样的),在你要使用的文件的开始部分加入一行语句<?include(textfun.inc);?>,你就可以使用我为你编的函数了。
下面一共一个db对象,一个函数p2row();

-------------textfun.inc----------------
<?
classdb{
var$dbfile;
functioncreatedb($dbName){
$f=$dbName;
$this->$dbfile=$f;
$headInfo=<?die(ACCESSDENIED!);?>\n;
$fp=fopen($f,w);
fputs($fp,$headInfo);
fclose($fp);
chmod($f,0777);//修改文件的模式,在Unix下也可用
return(1);
}
functionopendb($f){
$this->$dbfile=$f;
if(file_exists($f)){
returntrue;
}else{
$this->createdb($f);
}
}
functioninsertline($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);
}
functionreadall($f){
if(file_exists($f)){
$this->$dbfile=$f;
$rows=file($f);
for($i=1;$i<count($rows);$i++){
$temp[]=$rows[$i];
}
return$temp;
}
}
//以倒序的方式读入所有的数据行
functionrevread($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;
}
}

functionclose(){
$this=$nothing;
}
}

//把段落文本格式化为一行文本,便于存储
functionp2row($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(stringfilename)
用法例:<?
include(textfun.inc);
$mydb=newdb;
$mydb->createdb(UserInfo.php);
?>
这个方法创建了一个文件UserInfo.php,首行是<?die(ACCESSDENIED!);?>

db->opendb(stringfilename)
用法例:<?
include(textfun.inc);
$mydb=newdb;
$mydb->opendb(UserInfo.php);
?>
这个方法以追加模式“打开”了数据文件UserInfo.php,如果这个文件不存在,则被创建。
因此,这个方法可以取代createdb()方法。(但千万别删了classdb{}里面的createdb()函数哦:P)

db->insertline(stringVarString)
用法例:<?
include(textfun.inc);
$theline=email=ask4more@13.net&nickname=redfox&realname=阿鼎&url=
parse_str($theline);//构造环境变量
$mydb=newdb;
$mydb->opendb(UserInfo.php);
$mydb->insertline(nicknamerealnameemailurl);
?>
db->insertline()可以将形如nicknamerealnameemailurl的字符串,分离出相应的环境变量,并以本文约定的形式存入文件。传入insertline()的参数,一定要用“”把环境变量名连成字符串,个数不限,但千万别在前面加$哦,嗯,就是要形如nicknamerealnameemailurl这样的字符串:~)

arraydb->readall(stringfilename)
用法例:<?
include(textfun.inc);
$mydb=newdb;
$allrec=$mydb->readall(UserInfo.php);
?>
readall()方法返回除首行(<?die(ACCESSDENIED!);?>)外所有数据的数组,每行对应于数组的一个元素。

arraydb->revread(stringfilename)
用法例:<?
include(textfun.inc);
$mydb=newdb;
$allrec=$mydb->revread(UserInfo.php);
?>
revread()方法以倒序方式读入除首行(<?die(ACCESSDENIED!);?>)外所有数据,返回数组。这对我们在编留言本等时候尤为有用。

voiddb->close()
关闭db对象。

好了,我们现在就用db对象编一个最简单的留言本。
---------guestbook.php------------
我的留言本<p>
<formname=form1action=<?echo$PHP_SELF;?>>
NickName:<inputtype=textname=nickname><br>
E-Mail:<inputtype=textname=email><br>
Homepage:<inputtype=textname=urlvalue=
Message:<textareaname=messagecols=30rows=12></textarea><p>
<inputtype=submitname=Submitvalue=提交>
</form>
<?
include(textfun.inc);
if($Submit){
$thetime=date(Y-m-dh:m:sA);
$message=p2row($message);
$mydb=newdb;
$mydb->opendb(msg.php);
$mydb->insertline(nicknameemailurlmessagethetime);

//以下读出所有的数据
$allrecs=$mydb->revread(msg.php);
while(list($key,$theline)=each($allrecs)){
parse_str($theline);
?>
<ahref=mailto:<?echo$email;?>><?echo$nickname;?></a><?echo$thetime;?><br>
URL:<ahref=<?echo$url;?>><?echo$url;?></a><br>
Message:<br><?echostripslashes($message);?><hrnoshadesize=1>
<?
}
$mydb->close();
}
?>
-----------------------------
好了,虽然这个留言本不是很美观,但主要是为了举例说明db对象的用法~:)
本文在WIN98+PWS+PHP4下调试通过!


评论


亲,登录后才可以留言!