用文本作数据处理

作者:redfox 邮件:[email protected]
主页:http://netnote.oso.com.cn

相信大家在网上申请的免费PHP空间,如果是初级用户,一般都是没得MySQL可供使用,那么我们解决数据处理的方法之一就是用文本文件了。但是用什么方法才可以最快最方便的处理文本数据呢?
按我的经验,本人认为,以下列文件结构为最优:
----------------------------------------------------------------------
文件扩展名:.php

[email protected] & nickname=redfox & realname=阿鼎 & url=http://NetNote.oso.com.cn & ...
...
----------------------------------------------------------------------
也许大家都看出来了,以.php做扩展名,并且文件的第一行是

,这样就有效的阻止了对数据文件的非法访问。文件的第二行的格式都是: 变量名1=值1 & 变量名2=值2 & ...
提出所有的变量很简单,就是用函数 parse_str();
例如:

"; echo "welcome to visit my website:$url ```
``` "; 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] 因此,本文约定,数据文本结构为: \----------------------------------------

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

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

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

,你就可以使用我为你编的函数了。
下面一共一个db对象,一个函数p2row();

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

$dbfile=$f; $headInfo="

\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

 1<count($rows);$i++){ $temp;="" $temp[]="$rows[$i];" $this-="" function="" if(file_exists($f)){="" return="" revread($f){="" }="" 以倒序的方式读入所有的数据行="">$dbfile=$f;   
 2$rows=file($f);   
 3$d=count($rows);   
 4$j=$d-1;   
 5for($i=0;$i&lt;$d;$i++){   
 6if($i&lt;$j){   
 7$temprow=$rows[$i];   
 8$rows[$i]=$rows[$j];   
 9$rows[$j]=$temprow;   
10$j--;   
11}   
12}   
13for($i=0;$i<count($rows)-1;$i++){ $c=" " $t="nl2br(stripslashes(htmlspecialchars($t)));" $temp;="" $temp[]="$rows[$i];" $tempstr.="$c;" $tempstr;="" $this="$nothing;" ;="" ?="" close(){="" for($i="0;$i&lt;strlen($t);$i++){" function="" if(ord($c)="10)" p2row($t){="" return="" }="" 去掉首行="" 把段落文本格式化为一行文本,便于存储="">   
14----------------------------------   
15  
16db是我们自定义的本文数据对象,包括六个方法:createdb(),opendb(),insertline(),readall().revread(),close();   
17  
18db-&gt;createdb(string filename)   
19用法例:<?   
20include("textfun.inc");   
21$mydb=new db;   
22$mydb->createdb("UserInfo.php");   
23?&gt;   
24这个方法创建了一个文件UserInfo.php,首行是<? die('ACCESS DENIED!');?>   
25  
26db-&gt;opendb(string filename)   
27用法例:<?   
28include("textfun.inc");   
29$mydb=new db;   
30$mydb->opendb("UserInfo.php");   
31?&gt;   
32这个方法以追加模式“打开”了数据文件UserInfo.php,如果这个文件不存在,则被创建。   
33因此,这个方法可以取代createdb()方法。(但千万别删了class db{ }里面的createdb()函数哦:P)   
34  
35db-&gt;insertline(string VarString)   
36用法例:<?   
37include("textfun.inc");   
38$theline="[email protected]&nickname=redfox&realname=阿鼎&url=http://NetNote.oso.com.cn";   
39parse_str($theline);//构造环境变量   
40$mydb=new db;   
41$mydb->opendb("UserInfo.php");   
42$mydb-&gt;insertline("nickname|realname|email|url");   
43?&gt;   
44db-&gt;insertline()可以将形如"nickname|realname|email|url"的字符串,分离出相应的环境变量,并以本文约定的形式存入文件。 传入insertline()的参数,一定要用“|”把环境变量名连成字符串,个数不限,但千万别在前面加"$"哦,嗯,就是要形如"nickname|realname|email|url"这样的字符串 :~)   
45  
46array db-&gt;readall(string filename)   
47用法例:<?   
48include("textfun.inc");   
49$mydb=new db;   
50$allrec=$mydb->readall("UserInfo.php");   
51?&gt;   
52readall()方法返回除首行(<? die('ACCESS DENIED!');?>)外所有数据的数组,每行对应于数组的一个元素。   
53  
54array db-&gt;revread(string filename)   
55用法例:<?   
56include("textfun.inc");   
57$mydb=new db;   
58$allrec=$mydb->revread("UserInfo.php");   
59?&gt;   
60revread()方法以倒序方式读入除首行(<? die('ACCESS DENIED!');?>)外所有数据,返回数组。这对我们在编留言本等时候尤为有用。   
61  
62void db-&gt;close()   
63关闭db对象。   
64  
65好了,我们现在就用db对象编一个最简单的留言本。   
66---------guestbook.php------------   
67我的留言本<p>
68<form $php_self;?="" action="&lt;?" echo="" name="form1">&gt;   
69NickName:<input name="nickname" type="text"/><br/>   
70E-Mail:<input name="email" type="text"/><br/>   
71Homepage:<input name="url" type="text" value="http://"/><br/>   
72Message:<textarea cols="30" name="message" rows="12"></textarea><p>
73<input name="Submit" type="submit" value="提交"/>
74</p></form>
75<?   
76include("textfun.inc");   
77if($Submit){   
78$thetime=date("Y-m-d hⓜ️s A");   
79$message=p2row($message);   
80$mydb=new db;   
81$mydb->opendb("msg.php");   
82$mydb-&gt;insertline("nickname|email|url|message|thetime");   
83  
84//以下读出所有的数据   
85$allrecs=$mydb-&gt;revread("msg.php");   
86while(list($key,$theline)=each($allrecs)){   
87parse_str($theline);   
88?&gt;   
89<a href="mailto:&lt;?echo $email;?&gt;"><?echo $nickname;?></a><?echo $thetime;?><br/>   
90URL:<a href="&lt;?echo $url;?&gt;"><?echo $url;?></a><br/>   
91Message:<br/><?echo stripslashes($message);?><hr noshade="" size="1"/>
92<?   
93}   
94$mydb->close();   
95}   
96?&gt;   
97-----------------------------   
98好了,虽然这个留言本不是很美观,但主要是为了举例说明db对象的用法~:)   
99本文在WIN98+PWS+PHP4下调试通过!</p></count($rows)-1;$i++){></count($rows);$i++){>
Published At
Categories with Web编程
Tagged with
comments powered by Disqus