若天明 发表于 2015-2-4 00:18:33

PHP网页设计本人下手做一个SQL注释器

第1步环境配置好了,你算了进了1小步了,那么第2步呢 就是调出第1个程序 一般都是用hello world,视频教程里面我都做了,hello world   本人下手做一个SQL注释器
在一些小型的使用中,完整没有需要利用大型数据库软件。本人做一个SQL注释器就可以用数据库的体例来办理了。
这个注释器,能注释经常使用的SQL号令。你可以自行添加其他功效。

<?php
class DB_text {
var $conn;
var $classname = "db_text";
var $database;
function on_create() {
}
function connect($database_name) {
    $this->database = $database_name;
    if(! file_exists($database_name)) {
      $this->conn = array();
      $this->_close();
    }
    $fp = fopen($this->database,"r");
    $this->conn = unserialize(fread($fp,filesize($this->database)));
    fclose($fp);
}
function &query($query) {
    if(eregi("select ",$query)) return $this->_select($query);
    if(eregi("insert ",$query)) return $this->_insert($query);
    if(eregi("delete ",$query)) return $this->_delete($query);
    if(eregi("update ",$query)) return $this->_update($query);
    return array();
}
function fetch_row(&$result) {
    if(list($key,$value) = each($result))
      return $value;
    return false;
}
function num_rows($result) {
    return count($result);
}

/**
   * query的帮助函数
   */
function _select($query) {
    if(eregi("(order by (.+))",$query,$regs)) {
      $order = $regs;
      $query = eregi_replace($regs,"",$query);
    }
    if(eregi("(group by (.+))",$query,$regs)) {
      $group = $regs;
      $query = eregi_replace($regs,"",$query);
    }
    eregi("select .* from (+) *(where +(.+))?",$query,$regs);
    if($regs != "") {
      $keys = $this->_where($regs,"\$this->conn[$regs]");
      while(list($key,$value) = each($keys)) {
      $rs[] = $this->conn[$regs][$value];
      }
    }else {
      $rs = $this->conn[$regs];
    }
    if($order) {
      sscanf($order,"%s %s",$key,$type);
      if(empty($type)) $type = "asc";
      $this->_sort($rs,$key,$type);
    }
    return $rs;
}
function _insert($query) {
    eregi("insert +into +(+) *(.+) *values? *(.+)",$query,$regs);
    eval("\$key=array$regs;");
    eval("\$value=array$regs;");
    for($i=0;$i<count($key);$i++)
      $rs[$key[$i]] = $value[$i];
    $this->conn[$regs][] = $rs;
    $this->_close();
}
function _update($query) {
    eregi("update +(+) +set *(,?.*=.*)+( +where +(.+))",$query,$regs);
    $regs = eregi_replace(",","=",$regs);
    $v = split("=",$regs);
    $keys = $this->_where($regs,"\$this->conn[$regs]");
    while(list($key,$value) = each($keys)) {
      for($i=0;$i<count($v);$i+=2)
      $this->conn[$regs][$value][$v[$i]] = eregi_replace("'","",$v[$i+1]);
    }
    $this->_close();
}
function _delete($query) {
    eregi("delete +from +(+) *(where +(.+))?",$query,$regs);
    $keys = $this->_where($regs,"\$this->conn[$regs]");
    while(list($key,$value) = each($keys)) {
      unset($this->conn[$regs][$value]);
    }
    reset($this->conn[$regs]);
    while(list($key,$value) = each($this->conn[$regs])) {
      $ch[] = $value;
    }
    $this->conn[$regs] = $ch;
    $this->_close();
}
function _where($search,$table) {
    $search = eregi_replace("\("," ( ",$search);
    $search = eregi_replace("\)"," ) ",$search);
    $search = eregi_replace("\+"," + ",$search);
    $search = eregi_replace("\*"," * ",$search);
    while(eregi("[^ ]([*/><!=-])",$search,$regs)) {
      $search = eregi_replace($regs," $regs ",$search);
    }
    while(eregi("([><!] +=)",$search,$regs)) {
      $search = eregi_replace($regs,eregi_replace(" ","",$regs),$search);
    }
    $search = eregi_replace(""," ",trim($search));
    $search = eregi_replace(" and "," && ",$search);
    $search = eregi_replace(" or "," || ",$search);
    $search = eregi_replace(" = "," == ",$search);
    $ar = split(" ",$search);
    eval("\$t=$table;");

    for($i=0;$i<count($ar);$i++) {
      if(isset($t[$ar[$i]]))
      $ar[$i] = "\$value[".$ar][$i]."]";
    }
    $expr = "\$expl=(".join(" ",$ar).");";
   
    while(list($key,$value) = each($t)) {
      eval($expr);
      if($expl)
      $keys[] = $key;
    }
    return $keys;
}
function _sort(&$ar,$key=0,$mode="desc") {
    global $cmp_key;
    $cmp_key = $key;
    if($mode == "asc")
      usort($ar,_cmp_asc);
    else
      usort($ar,_cmp_desc);
}
function _close() {
    $fp = fopen($this->database,"w");
    fwrite($fp,serialize($this->conn));
    fclose($fp);
}
}

/** 排序键
*/
$cmp_key = "";

/** 排序用任务函数(降序 由usort()挪用)
*/
function _cmp_desc($a,$b) {
global $cmp_key;
if ($a[$cmp_key] == $b[$cmp_key]) return 0;
return ($a[$cmp_key] > $b[$cmp_key]) ? -1 : 1;
}

/** 排序用任务函数(升序 由usort()挪用)
*/
function _cmp_asc($a,$b) {
global $cmp_key;
if ($a[$cmp_key] == $b[$cmp_key]) return 0;
return ($a[$cmp_key] > $b[$cmp_key]) ? 1 : -1;
}
?>

测试例:
<pre>
<?php
//require_once "db_text.php";

$conn = new DB_text;
$conn->connect("text1.txt");

$conn->query("insert into manage (id,title) values (10,'abcd')");
$conn->query("insert into manage (id,title) values (2,'43d')");
$conn->query("insert into manage (id,title) values (20,'tuu')");
$conn->query("update manage set id=101,test='a' where id=10");
//$conn->query("delete from manage where id='10'");
//$conn->query("delete from manage where id=10 or table='code'");


//$rt = $conn->query("select * from manage where id=101 or table='code' group by 1 order by 1 asc");
$rt = $conn->query("select * from manage group by 1 order by id desc");

print_r($rt);

?>
</pre>
exit来实现结束后面的PHP语句的执行,缩小调试范围,特别是数据库交互的程序,先输出个SQL语句看看,对了,再分析怎么会插入/删除不成功呢?这样对查错很有帮助。

仓酷云 发表于 2015-2-4 11:21:16

我要在声明一下:我是个菜鸟!!我对php这门优秀的语言也是知之甚少。但是我要在这里说一下php在网站开发中最常用的几个功能:

第二个灵魂 发表于 2015-2-9 22:20:45

最后介绍一个代码出错,但是老找不到错误方法,就是 go to wc (囧),出去换换气没准回来就找到错误啦。

变相怪杰 发表于 2015-2-28 00:46:17

当留言板完成的时候,下步可以把做1个单人的blog程序,做为目标,

分手快乐 发表于 2015-3-9 16:51:43

实践是检验自己会不会的真理。

深爱那片海 发表于 2015-3-17 00:09:11

首先声明:我是一个菜鸟,是一个初学者。学习了一段php后总是感觉自己没有提高,无奈。经过反思我认为我学习过程中存在很多问题,我改变了学习方法后自我感觉有了明显的进步。

谁可相欹 发表于 2015-3-18 03:06:45

首先声明:我是一个菜鸟,是一个初学者。学习了一段php后总是感觉自己没有提高,无奈。经过反思我认为我学习过程中存在很多问题,我改变了学习方法后自我感觉有了明显的进步。

蒙在股里 发表于 2015-3-19 18:40:24

先学习php和mysql,还有css(html语言很简单)我认为现在的效果比以前的方法好。

admin 发表于 2015-3-28 04:05:39

我要在声明一下:我是个菜鸟!!我对php这门优秀的语言也是知之甚少。但是我要在这里说一下php在网站开发中最常用的几个功能:

莫相离 发表于 2015-4-1 17:11:17

php是动态网站开发的优秀语言,在学习的时候万万不能冒进。在系统的学习前,我认为不应该只是追求实现某种效果,因为即使你复制他人的代码调试成功,实现了你所期望的效果,你也不了解其中的原理。

不帅 发表于 2015-4-4 08:11:43

学习php的目的往往是为了开发动态网站,phper就业的要求也涵盖了很多。我大致总结为:精通php和mysql

老尸 发表于 2015-4-6 02:09:41

先学习php和mysql,还有css(html语言很简单)我认为现在的效果比以前的方法好。

精灵巫婆 发表于 2015-4-11 16:35:13

我还是推荐用firefox ,配上firebug 插件调试js能省下不受时间。谷歌的浏览器最好也不少用,因为谷歌的大侠们实在是太天才啦,把一些原来的js代码加了一些特效。

飘灵儿 发表于 2015-4-16 16:11:45

本文当是我的笔记啦,遇到的问题随时填充

海妖 发表于 2015-4-16 22:20:37

Apache不是非得用80或者8080端口的,我刚开始安得时候就是80端口老占用,就用了个 81端口,结果照常,就是输localhost的时候,应该输入为 localhost:81

飘飘悠悠 发表于 2015-4-23 23:31:31

,熟悉html,能用div+css,还有javascript,优先考虑linux。我在开始学习的时候,就想把这些知识一起学习,我天真的认为同时学习能够互相呼应,因为知识是相通的。

透明 发表于 2015-5-1 10:08:11

真正的方向了,如果将来要去开发团队,你一定要学好smarty ,phplib这样的模板引擎,

因胸联盟 发表于 2015-5-5 06:02:10

当然这种网站的会员费就几十块钱。

若相依 发表于 2015-5-11 17:14:39

如果你可以写完像留言板这样的程序,那么你可以去一些别人的代码了,
页: [1]
查看完整版本: PHP网页设计本人下手做一个SQL注释器