设为首页 收藏本站
查看: 906|回复: 0

[经验分享] 简单的php写入数据库类

[复制链接]

尚未签到

发表于 2015-8-26 13:25:41 | 显示全部楼层 |阅读模式
  
 不知道原创要写到随笔里。
  All right ,第一篇博文。
  有三个类:
      1 . 过滤输入(轻量级的)  
                      class input_filter
                            负责将参数,如$_GET,$_POST 这些过滤
                            返回值类型为 数组,用作 made_sql 类的参数
      2 . 转换成SQL语句
                      class  made_sql  
                             参数的类型为数组和表名(字符串),数组的键名为表的列名,值为插入值  
                             返回值类型为 字符串 ,用作 mysql ->query方法 的参数
      3 . 数据库查询
                     class  mysql
                              用到了单列模式,用静态方法来获取对象,具体参看 instanceof操作符的作用
  




1   class input_filter
2   {
3   
4        private $input_all; // 要过滤的数组
5        private $rustle;     // 过滤后的结果
6        
7       //构造函数 参数可以是$_GET or $_POST 这些
8       public function __construct($input_C)
9       {
10           if(is_array($input_C))
11                $this->input_all = $input_C ;
12           else
13                echo 'Parameter is not valid';
14           
15           //初始化,不然后面第一次合并数组PHP不知道这是什么类型      
16           $this->rustle = array();  
17       }
18        
19       private function filter_arr()  // 主函数
20       {
21           
22           foreach ($this->input_all as  $key_input => $val_input)
23           {
24               //如果键名不是字符串,那么返回错误信息
25               // for key
26               if(!is_string($key_input))  // error
27                  {
28                    echo 'This key is not string';
29                    return false;
30                  }
31               // The # is mysql Note .  
32               $key_one = str_replace('#','',$key_input);
33               $key = htmlspecialchars($key_one,ENT_QUOTES,'UTF-8');
34               
35               // 我没找 # 的HTML转义符,所以用空代替
37               $val_one = str_replace('#','',$val_input);
38               // 这个函数只转化 < > ' "  ,还有个类似函数会转义所有符号
39               $val = htmlspecialchars($val_one,ENT_QUOTES,'UTF-8');
40               
41               // merger      
42               $rustle_one = array($key=>$val);
43               //合并数组
44               $this->rustle = array_merge($this->rustle,$rustle_one);
45           }
46           
47       }
48      
49       //这个函数有点多余,留下以后扩展用
50       public function get_filter_rustle()
51       {
52           $this->filter_arr();
53           return  $this->rustle ;
54       }
55
56   }
  
   调用方法:            



  $filter = new filter_input($_GET) ; // or $_POST
  $input_data = $filter->get_filter();
  
    转换成SQL语句:  



1   class madesql
2   {
3       private $Cnow_ary;   // type array  传入的参数
4       private $Cname_str;
5      
6       private $insert_sql;  //最终的sql语句  string type
7      
8      
9
10
11      
12       public function  __construct($Cary,$Cname)
13       {
14          //检查传入参数类型是否为数组
15          if (! is_array($Cary))  
16              return false;
17          else
18              $this->Cnow_ary = $Cary;  // 写入的值
19        
20          $this->Cname_str = $Cname;  // 数据库表名称
21         
25       }
26      
27       private function setSql()  // 主函数 ,生产SQL语句
28       {
29            $cols_sql = '';
              $vals_sql = ''             // 初始化变量
30            foreach ( $this->Cnow_ary as  $key_ary => $val_ary )
31            {
32                $cols_sql = $cols_sql.','.$key_ary; //列名组合
33                $vals_sql = $vals_sql.', \''.$val_ary.'\'' ; //值 组合
34            }
35             // 因为前面foreach的算法有点问题,第一个字符是逗号
36             // 所以用sunstr_replace()删除 ,自第一位起(0),只替换一个字符(1)   
37             $cols_sql = substr_replace($cols_sql,'',0,1);   
38             $vals_sql = substr_replace($vals_sql,'',0,1);
39              
40             $this->insert_sql =
41             'INSERT INTO '.$this->Cname_str.' ( '
42                                .$cols_sql.' ) VALUES ( '.$vals_sql.' )'; // 语句成型
43       }
44       //扩展用
45       public function getSql()
46       {
47           $this->setSql();
48           return $this->insert_sql;
49       }
50      
51    }
  
      3 . 数据库查询
   数据库查询类是参照书上的单列模式(用静态方法获取对象,这样在一个脚本里只有一个数据库查询类的实例)
  我想单例模式用于这个类还是有点用的



1   class mysql
2    {
3        private $connect;
4        static  $objectMysql; // 存放对象
5        
6        private function  __construct()  
7        {   
8           // 创建对象的时候这个构造函数会被调用,用来初始化
9           $connect = mysql_connect('db address','password','dbname');
10           $this->db = mysql_select_db('db',$connect);   
11        }
12
13        public static function Mysql_object()
14        {   
15            //instanceof 操作符用于检查对象是否属于某个类或者接口的实例。我说的不是很规范...
16           //如果$objectMysql不是mysql(self)的实例,那么就创建一个
17            if(! self::$objectMysql instanceof self)
18                 self::$objectMysql = new mysql();
19
20            //这时候的$objectMysql就已经是一个对象
21            return self::$objectMysql;   
22        }
23        public function query($sql)
24        {
25            return mysql_query($sql,$this->db);
26        }
27  
28   }

  
  All right ,归纳一下使用方法
  



1   $filter = new input_filter($_GET) ; // or $_POST
2   $input_data = $filter->get_filter_rustle();
3   
4   $madeSql = new madesql($input_data,'tableName');
5   $sql = $madeSql->getSql();
6
7   $mysql = mysql::Mysql_object() ;
8   if( $mysql->query($sql) )
9       echo 'Ok';
10   else
11       echo 'failure';
  
  只需要这几行调用代码即可以完成写入数据库的操作
     
  另外再说一下构造函数的私有公有问题,书上的mysql单例模式中构造函数是声明为了private ,而没有单例模式的类如此则会产生编译错误,即 PHP 不能创建一个对象 ,查了下。
         原因在于创建对象往往在类外面进行,这样就产生了无法访问构造函数的问题。 而单列模式是在自身类中创建对象,因此访问private方法没有限制。
          原先以为单例模式只是防止创建相同的对象,现在看来单例模式可以将构造函数封装起来,确实提高了安全性
     
    filter_input类 的结果可以直接用作 madesql类 的参数的 前提是 :
          表单的name必须和数据库的列名相同,否则你就白看这么多
          O(&cap;_&cap;)O哈哈~
  

     大意了有几处错误都是

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-104500-1-1.html 上篇帖子: PHP Session原理 下篇帖子: php header 函数详解
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表