PHP 之模板模式

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介:

我们可能会遇到这种情况,为了实现一些业务逻辑,我们会对同一个对象来回重建进行业务处理


比如说做试卷,老师除了一套试卷,学生们拿到试卷只有两个地方不一样,填写的答案和名字


这样的话,整体的算法骨架是一定的,你只需要固定出来一套题就可以,子类去修改其中一两部


应用情境:数据库中间层的抽象类


上代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
<?php
 
//模板设计模式创建了一个实施一组方法的抽象对象,子类通常将这个对象作为模板用于自己的设计。
//一般会用于数据库抽象类。
abstract  class  dbbaseInit{
     /**
      * 抽象数据库链接
      * @param  string $host sql服务器
      * @param  string $user 数据库用户名
      * @param  string $password 数据库登录密码
      * @param  string $database 数据库
      * @param  string $charset 编码
      * @param  string $pconnect 是否持久链接
      */ 
 
     abstract  protected  function  connect( $host , $user , $password , $database , $charset = 'utf-8' , $pconnect =0);
     /**
      * 抽象数据库执行语句
      * @param  string $sql SQL语句
      * @return obj
      */ 
 
     abstract  protected  function  query( $sql );
     /**
      * 抽象数据库-结果集中的行数
      * @param $result 结果集
      * @return array
      */ 
 
     abstract  protected  function  result( $result , $num =1);
 
     /**
      * 抽象数据库-从结果集中取得一行作为关联数组
      * @param $result 结果集
      * @return array
      */ 
     //这个方法没用过(不是数字索引而是字段)
     abstract  protected  function  fetch_assoc( $result );
 
      /**
      * 抽象数据库-从结果集中取得列信息并作为对象返回
      * @param  $result 结果集
      * @return array
      */
 
      abstract  protected  function  fetch_fields( $result );
 
       /**
      * 抽象数据库-前一次操作影响的记录数
      * @return int
      */ 
       //这个也没有用过
       abstract  protected  function  affected_rows();
 
      /**
      * 抽象数据库-结果集中的行数
      * @param $result 结果集
      * @return int
      */ 
 
       abstract  protected  function  num_rows( $result );
 
      /**
      * 抽象数据库-结果集中的字段数量
      * @param $result 结果集
      * @return int
      */ 
 
      abstract  protected  function  num_fields( $result );
 
      /**
      * 抽象数据库-获取上一INSERT的ID值
      * @return Int
      */ 
 
      abstract  protected  function  insert_id();
 
      /**
      * 抽象数据库-释放结果内存
      * @param obj $result 需要释放的对象
      */ 
 
      abstract  protected  function  free_result( $result );
 
      /**
      * 抽象数据库链接关闭
      * @param  string $sql SQL语句
      * @return obj
      */
 
      abstract  protected  function  close();
 
      /**
      * 错误信息
      * @return string
      */ 
      abstract  protected  function  error();
 
}
 
//这是具体的某个数据库,比如MySQL,oracle
class  mysqliInit  extends  dbbaseInit{
     public  $link_id ;
     //重写模型中的连接类
     public  function  connect( $host , $user , $password , $database , $charset = 'utf8' ,pconnect=0){
         $link_id  = ( $pconnect ==0)?mysqli_connect( $host , $user , $password ):mysqli_pconnect( $host , $user , $password );
 
         if (! $link_id die ( 'mysql connect error!' );
         mysql_query( $link_id , 'set names' . $charset );
         if (!mysqli_select_db( $link_id , $database ))  die ( 'database is not exist' );
 
         return  $link_id ;
     }
 
     public  function  query( $sql ){
         return  mysqli_query( $this ->link_id, $sql );
     }
 
     public  function  result( $result , $num =1){
         return  mysqli_result( $result , $num );
     }
 
     public  function  fetch_assoc( $result ){
         return  mysqli_fetch_assoc( $result );
     }
 
     public  function  fetch_fields( $result ){
         return  mysqli_num_fields( $result );
     }
 
     public  function  free_result( $result ){
         return  mysqli_free_result( $result );
     }
 
     public  function  insert_id(){
         return  mysqli_insert_id( $this ->link_id);
     }
 
     public  function  affected_rows() { 
         return  mysqli_affected_rows( $this ->link_id); 
     }
 
     public  function  close(){
         if ( $this ->link_id!==null)  $mysqli_close ( $this ->link_id);
         $this ->link_id = null;
         return  true;
     }
 
     public  function  error(){
         return  mysqli_error( $this ->link_id);
     }
}
?>



有点累了,设计模式常用的先学到这里,后续的以后再说,


愿法界众生,皆得安乐

本文转自 jackdongting 51CTO博客,原文链接:http://blog.51cto.com/10725691/1954849


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
9天前
|
中间件 PHP 开发者
深入理解PHP中的中间件模式
【8月更文挑战第29天】本文旨在通过探讨PHP中间件模式的实现,帮助读者掌握如何构建可扩展且易于维护的应用。文章不仅解释了中间件概念,还提供了代码示例,并分析了其优势和应用场景。阅读本文后,你将能够更有效地使用中间件来优化你的PHP项目结构。
|
7天前
|
设计模式 JavaScript 中间件
探索PHP中的中间件模式
【8月更文挑战第31天】本文将带你领略PHP编程世界中的“交通枢纽”——中间件模式。我们将从中间件的概念出发,逐步深入到如何在PHP项目中实现并应用这一设计模式。通过实际代码示例,你将学会如何构建自己的中间件,以及如何利用它们来简化项目结构、增强代码可读性和可维护性。准备好了吗?让我们一起走进PHP中间件的世界,解锁更多可能!
|
6天前
|
设计模式 前端开发 PHP
PHP中实现简易的MVC模式
【8月更文挑战第31天】 本文将引导你了解如何在PHP中应用MVC(Model-View-Controller)架构模式,通过一个简单的例子展示其实现过程。我们将从基础的概念出发,逐步深入到代码实践,最终让你能够自己动手构建一个简易的MVC框架。文章不仅提供理论知识,还包含具体的代码示例,帮助你更好地理解并运用MVC模式。
|
7天前
|
设计模式 缓存 中间件
深入理解PHP中的中间件模式
【8月更文挑战第31天】 在PHP开发中,中间件模式是一种优雅的架构设计,它允许开发者以非侵入式的方式扩展应用程序的功能。本文将通过一个简单的示例,展示如何在PHP中实现和使用中间件,以及这种模式如何提高代码的可维护性和可测试性。
|
7天前
|
设计模式 中间件 测试技术
深入理解PHP中的中间件模式
【8月更文挑战第31天】 在软件开发的海洋里,设计模式犹如灯塔指引着开发者的方向。本文将带你驶向一个特别的岛屿——PHP中间件模式,探索它如何简化代码、增强可读性与可维护性。我们将通过实际编码示例,展示如何在PHP中实现中间件模式,并讨论其对项目架构的影响。准备好了吗?让我们启航吧!
|
7天前
|
设计模式 中间件 PHP
深入理解PHP中的中间件模式
【8月更文挑战第31天】本文旨在通过深入浅出的方式,向读者展示如何在PHP中实现和利用中间件模式来增强代码的可维护性和扩展性。文章将介绍中间件模式的基本概念、核心价值以及如何将其应用于PHP项目。我们将从一个简单的例子出发,逐步构建起一个灵活且强大的中间件系统。无论你是PHP新手还是资深开发者,这篇文章都将为你提供新的视角和实用工具,让你的项目更加健壮和易于管理。
|
9天前
|
设计模式 中间件 PHP
探索PHP中的中间件模式
【8月更文挑战第29天】在软件开发的广阔天地中,设计模式犹如建筑的蓝图,为代码的结构与交互提供了指导。本文将深入探讨PHP语言中实现中间件模式的方法,旨在通过实际代码示例,揭示这一模式如何优化项目结构、提高代码可维护性与扩展性。文章不仅阐述中间件模式的概念和重要性,还将展示如何在PHP项目中有效应用该模式,帮助开发者构建更加灵活且易于管理的应用。
|
10天前
|
存储 中间件 PHP
Python编程入门:从零到一的代码实践深入理解 PHP 中的中间件模式
【8月更文挑战第28天】本文旨在通过浅显易懂的方式,向初学者介绍Python编程的基础知识,并结合具体代码示例,带领读者一步步实现从零基础到能够独立编写简单程序的转变。文章将围绕Python语言的核心概念进行讲解,并通过实例展示如何应用这些概念解决实际问题。无论你是编程新手还是希望扩展技能的专业人士,这篇文章都将为你打开编程世界的大门。 【8月更文挑战第28天】在PHP的世界中,设计模式是构建可维护和可扩展软件的重要工具。本文将通过浅显易懂的语言和生动的比喻,带领读者深入理解中间件模式如何在PHP应用中发挥魔力,实现请求处理的高效管理。我们将一步步揭开中间件的神秘面纱,从它的定义、工作原理到
|
1月前
|
设计模式 中间件 PHP
探索PHP中的中间件模式
【8月更文挑战第4天】在现代Web开发中,设计模式的应用对于代码的可读性、可维护性和扩展性至关重要。本文将通过实例探讨PHP中如何实现和使用中间件模式,旨在为开发者提供一种灵活处理HTTP请求和响应的方法。我们将从中间件的基本概念入手,逐步深入到实际的代码实现,并讨论其在项目中的应用场景。
|
14天前
|
安全 中间件 PHP
深入理解PHP中的中间件模式
【8月更文挑战第24天】在PHP开发中,中间件模式是一种优雅地处理HTTP请求和响应的架构设计。本文将通过浅显易懂的语言解释中间件的概念、作用以及如何在实际应用中实现。我们将一起探索如何通过中间件增强代码的可读性、可维护性和扩展性,同时确保安全性和性能的最优化。文章还将讨论如何结合PHP框架使用中间件,以简化复杂的应用逻辑和提高开发效率。
下一篇
DDNS