- 浏览: 242065 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
thepastsee:
304572183股票交流 欢迎加入
实时股票 -
345161974:
很不错,我第一个接触的CSS卡片布局效果,多谢
css卡片效果
用文本作数据处理
作者:admin 浏览:215次 时间:2010-10-13 13:40
用文本作数据处理,阅读用文本作数据处理,作者:redfox邮件:ask4more@163.net主页:http://netnote.oso.com.cn 相信大家在网上申请的免费PHP空间,如果是初级用户,一般都是没得MySQL可供使用,那
作者:redfox 邮件:ask4more@163.net
主页:http://netnote.oso.com.cn
相信大家在网上申请的免费PHP空间,如果是初级用户,一般都是没得MySQL可供使用,那么我们解决数据处理的方法之一就是用文本文件了。但是用什么方法才可以最快最方便的处理文本数据呢?
按我的经验,本人认为,以下列文件结构为最优:
----------------------------------------------------------------------
文件扩展名:.php
<? die('ACCESS DENIED!');?>
email=ask4more@13.net & nickname=redfox & realname=阿鼎 & url=http://NetNote.oso.com.cn & ...
...
----------------------------------------------------------------------
也许大家都看出来了,以.php做扩展名,并且文件的第一行是<? die('ACCESS DENIED!');?>,这样就有效的阻止了对数据文件的非法访问。文件的第二行的格式都是: 变量名1=值1 & 变量名2=值2 & ...
提出所有的变量很简单,就是用函数 parse_str();
例如:
<?
$theline="email=ask4more@13.net&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:ask4more@13.net
因此,本文约定,数据文本结构为:
----------------------------------------
<? 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=ask4more@13.net&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();
}
?>
发表评论
-
phphphphphphph
2012-03-01 22:27 0回归回归lkjlkjlkjlkjlkjlkjlkj -
php_相对路径_转
2012-03-01 22:07 0<?php $str1 = "/home/i ... -
php_自定义排序 关联数组
2012-03-01 21:11 0<?php //用PHP设计一个函数,对学生英语考试得 ... -
php_讲义
2012-02-29 13:07 0ewrwerwer -
php 禁止危险的函数_转
2012-02-27 12:28 0阿酷影 一些需要禁用的PHP危险函数 ... -
转_phpcan't return a result set in the given context及参数解释
2012-02-13 23:49 1285关键就是两点 defin ... -
php_可以编的表格
2012-01-29 10:42 870虽 -
php_oa
2011-10-20 16:48 679dfsdfsfsf -
jquery_upload
2011-09-12 13:07 697http://fangyong2006.iteye.com/b ... -
php__表单处理
2011-08-21 17:04 839sdfadfadsf -
$_SESSION 无法跨页保存数据
2011-08-21 11:46 931今天可遇到问题 $_SESSION 无法跨页保存数据 原 ... -
php 下载地址
2011-08-13 14:51 781window http://windows.php.n ... -
订单号__14位_转
2011-06-27 23:45 907http://bbs.phpchina.com/thread- ... -
9个免费 php 库_转
2011-06-24 21:17 10329个强大免费的PHP库 & 20 你应该知道的PHP ... -
php_错误解决_sessioin
2011-06-01 16:29 1072写购物车时遇到问题, Fatal error ... -
php面试题_转
2011-05-27 01:25 795kjljk -
jquery_ajax_table_php
2011-05-27 01:04 709jljklkj -
php算法_王伟阳
2011-05-23 13:17 816232342 -
php简历
2011-05-18 00:39 1083kjlkjlkj -
黑夜路人转__
2011-05-13 21:41 797lklk
相关推荐
【标题】"DBXML.ZIP"是一个压缩包,其中包含了多个与XML和MySQL数据库相关的项目。这个工具的主要目的是将MySQL服务器上的数据库转换成XML格式,从而实现数据的灵活处理和跨平台交换。它利用了NetBeans作为开发平台...
### Zend_Db_Adapter:Zend Framework中的数据库抽象层 在深入探讨`Zend_Db_Adapter`之前,我们先简要回顾一下`Zend_Db`的作用。`Zend_Db`是Zend Framework中的一个组件,专门用于处理数据库交互。它提供了一套高级...
这个压缩包`class_db_browse.rar_class_php_dbgrid`包含了用于实现这一功能的核心文件`class_db_browse.php`。下面将详细介绍`Class DBGrid`的相关知识点。 1. **什么是Class DBGrid** `Class DBGrid`是一个PHP...
在PHP开发中,数据库操作是不可或缺的一部分,而DbClass是一个常用的PHP数据库操作类,它封装了常见的数据库查询、增删改查等操作,使得开发者能够更高效、安全地与数据库进行交互。DbClass通常会支持多种数据库系统...
$db = $mongo->selectDB('database_name'); ``` 3. 操作集合(相当于SQL中的表): ```php $collection = $db->selectCollection('collection_name'); ``` 4. 插入文档: ```php $document = array("name" =>...
2. 数据库操作:`$db = $mongo->selectDB('database_name')`选择或创建一个数据库。 3. 集合操作:`$collection = $db->selectCollection('collection_name')`选择或创建一个集合,相当于SQL中的表。 4. 插入数据...
DB类<?php header('Content-Type:text/html; charset=utf-8'); basename($_SERVER['PHP_SELF'])=='mysql.inc.php'&&header; ('Location:http://'.$_SERVER['HTTP_HOST']); //禁止直接访问本页 /** ※※※※※※※...
在本实例中,我们将深入探讨“Yaf框架”与“Zend_DB”的集成使用,创建一个简单的后台管理系统。Yaf(Yet Another Fast Framework)是腾讯推出的一款高性能、轻量级的PHP框架,它专注于提高Web应用的运行效率。而...
这是一个用php脚本语言写的数据管理,mysql数据库转换系统 v1.2,mysqlconvert是一款优秀的数据库转换及管理系统,无需专业的知识即可方便的将不同的数据库数据进行转换,access、mssql导入mysql,mysql数据库之间互转...
这个扩展是PHP早期版本中用于与MySQL数据库通信的库,它提供了一系列函数,如`mysql_connect()`用于建立数据库连接,`mysql_select_db()`用于选择要操作的数据库,`mysql_query()`用于执行SQL查询,以及`mysql_fetch...
### PHP开发中常用处理函数详解 #### 一、字符串处理函数 **1. implode()** - **功能**:将数组中的元素合并成一个字符串,中间可以用指定字符分隔。 - **参数**: - `string $glue`:用于连接各元素的粘合符。 ...
转到项目目录 cd laravel-video-chat 安装所有Composer依赖项 composer install 将.env.example复制到.env cp .env.example .env 为您的项目生成密钥 php artisan key:generate 更改为以下环境变量 DB_...
mssql_select_db("db_database06", $conn); // 选择要连接的SQL Server数据库 ``` #### 1.2 MySQL 连接配置 接着,我们需要连接到MySQL数据库。这可以通过`mysql_connect`函数完成: ```php $id = mysql_connect(...
- 应用程序连接DB2时,也需要配置相应的字符集,如Java的JDBC连接字符串中的`useUnicode=true&characterEncoding=GBK`,或PHP的`ibase_set_charset('GBK')`等。 4. **表和列的字符集** - 单独的表或列也可以设定...
克隆此存储库后,转到应用程序根文件夹并运行composer install $ composer install 编辑您的.env文件(如果不存在),只需从.env.example复制 APP_NAME="Lumen JWT" APP_ENV=local APP_KEY= APP_DEBUG=false APP_...
标题中的"getdata_userdb.rar"表明这是一个压缩文件,很可能包含了一个名为"getdata_userdb.pl"的Perl脚本。这个脚本的核心功能是处理网络数据,并与数据库交互,这从描述和标签中可以推断出来。"网络"标签暗示了...
转到项目目录 cd laravel-notification-example 安装所有作曲家依赖项 composer install 安装所有npm依赖项并进行编译 npm install && npm run dev 将.env.example复制到.env cp .env.example .env 为您的项目...
- `extension=php_db.dll`:数据库支持。 - `extension=php_dba.dll`:DBA抽象层支持。 - `extension=php_dbase.dll`:对dBase文件的支持。 - `extension=php_dbx.dll`:DBX驱动程序接口。 - `extension=...
- **`msql_selectdb`:** 选择一个数据库。 - **`mssql_affected_rows`:** 获取受上一个SQL语句影响的行数。 - **`mssql_close`:** 关闭MS SQL Server连接。 - **`mssql_connect`:** 连接到MS SQL Server。 - **`...