首页 > 作文

php设计模式之适配器模式

更新时间:2023-04-07 12:24:42 阅读: 评论:0

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

创建接口imooc/databa.php

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

//接口 idataba<?phpnamespace databa;interface idataba{    function connect($host, $ur, $passwd, $dbname);    function query($sql);    function clo();}
mysql<?phpnamespace imooc\databa;u imooc\idataba;class mysql implements idataba{    protected $conn;    function connect($host, $ur, $passwd, $dbname)    {        $conn = mysql_connect($host, $ur, $passwd);        mysql_lect_db($dbname, $conn);        $this->conn = $conn;    }    function query($sql)    {        $res = mysql_query($sql, $this->conn);        return $res;    }    function clo()    {        mysql_clo($this->conn);    }}

  

mysqli<?phpnamespace imooc\databa;u imooc\idataba;class mysqli implements idataba剪纸英文{    protected $结尾摘抄conn;    function connect($host, $ur, $passwd, $dbname)    {        $conn = mysqli_connect($host, $ur, $passwd, $dbname);        $this->conn = $conn;    }    function query($sql)    {        return mysqli_query($this->conn, $sql);    }    function clo()    {        mysqli_clo($this->conn);    }}

  

pdo<?php钢铁是怎样炼成的电视剧namespace imooc\databa;u imooc\idataba;class pdo implements idataba{    protected $conn;    function connect($host, $ur, $passwd, $dbname)    {        $conn = new \pdo("mysql:host=$host;dbname=$dbname", $ur, $passwd);        $this->conn = $conn;    }function query($s象限角的取值范围ql)    {        return $this->conn->query($sql);    }    function clo()    {        unt($this->conn);    }}

  

本文发布于:2023-04-07 12:24:41,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/cca1bcd5a163579e4ee6f1ac8b9b04cc.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:php设计模式之适配器模式.doc

本文 PDF 下载地址:php设计模式之适配器模式.pdf

下一篇:返回列表
标签:接口   一成   函数   几个
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图