欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

php设计模式之适配器模式

程序员文章站 2022-03-31 20:45:01
将各种截然不同的函数接口封装成统一的API。 PHP中的数据库操作有MySQL,MySQLi,PDO三种,可以用适配器模式统一成一致,使不同的数据库操作,统一成一样的API。类似的场景还有cache适配器,可以将memcache,redis,file,apc等不同的缓存函数,统一成一致。 首先定义一 ......

将各种截然不同的函数接口封装成统一的api。 
php中的数据库操作有mysql,mysqli,pdo三种,可以用适配器模式统一成一致,使不同的数据库操作,统一成一样的api。类似的场景还有cache适配器,可以将memcache,redis,file,apc等不同的缓存函数,统一成一致。 
首先定义一个接口(有几个方法,以及相应的参数)。然后,有几种不同的情况,就写几个类实现该接口。将完成相似功能的函数,统一成一致的方法。

创建接口imooc/database.php

在imooc/database文件创建 mysql.php mysqli.php  pdo.php

//接口 idatabase
<?php
namespace database;
interface idatabase
{
    function connect($host, $user, $passwd, $dbname);
    function query($sql);
    function close();
}
mysql
<?php
namespace imooc\database;
use imooc\idatabase;
class mysql implements idatabase
{
    protected $conn;
    function connect($host, $user, $passwd, $dbname)
    {
        $conn = mysql_connect($host, $user, $passwd);
        mysql_select_db($dbname, $conn);
        $this->conn = $conn;
    }

    function query($sql)
    {
        $res = mysql_query($sql, $this->conn);
        return $res;
    }

    function close()
    {
        mysql_close($this->conn);
    }
}

  

mysqli
<?php
namespace imooc\database;
use imooc\idatabase;
class mysqli implements idatabase
{
    protected $conn;

    function connect($host, $user, $passwd, $dbname)
    {
        $conn = mysqli_connect($host, $user, $passwd, $dbname);
        $this->conn = $conn;
    }

    function query($sql)
    {
        return mysqli_query($this->conn, $sql);
    }

    function close()
    {
        mysqli_close($this->conn);
    }
}

  

pdo
<?php
namespace imooc\database;
use imooc\idatabase;
class pdo implements idatabase
{
    protected $conn;
    function connect($host, $user, $passwd, $dbname)
    {
        $conn = new \pdo("mysql:host=$host;dbname=$dbname", $user, $passwd);
        $this->conn = $conn;
    }
function query($sql)
    {
        return $this->conn->query($sql);
    }

    function close()
    {
        unset($this->conn);
    }
}