PHP单例模式数据库连接类与页面静态化实现方法


Posted in PHP onMarch 20, 2019

本文实例讲述了PHP单例模式数据库连接类与页面静态化实现方法。分享给大家供大家参考,具体如下:

数据库test中数据表account内容

PHP单例模式数据库连接类与页面静态化实现方法

单例模式的数据库连接类

db.php

<?php
//单例模式的数据库连接
class DB {
  //存储实例的静态成员变量
  static public $_instance;
  //数据库连接静态变量
  static public $_connectSource;
  //连接数据库配置,由于前几天学习了PDO,这里就使用PDO
  private $_dbConfig = array(
    'host' => 'localhost',
    'user' = > 'root',
    'password' => '',
    'database' => 'test'
  );
  //禁止外部实例化
  private function __construct() {
  }
  //实例化
  public static function getInstance() {
    if(self::$_instance instanceof self) {
      return self::$_instance;
    }
    self::$_instance = new self();
    return self::$_instance;
  }
  //数据库连接
  public function connect() {
    //如果不存在数据库连接就创建一个
    if(!self::$_connectSource) {
      try {
        $dsn = 'mysql:host='.$this->_dbConfig['host'].';dbname='.$this->_dbConfig['database'];
        $username = $this->_dbConfig['user'];
        $password = $this->_dbConfig['password'];
        self::$_connectSource = new PDO($dsn, $username, $password);
      }catch(PDOException $e) {
        echo $e->getMessage();
      }
    }
    return self::$_connectSource;
  }
}
?>

PHP实现页面静态化的例子

其实原理很简单,这里用到了几个函数,ob_start()ob_get_contents()file_put_contents()ob_start()是开启缓冲区的意思,ob_get_contents()是得到缓冲区内容的意思,file_put_contents()是把内容放到一个文件里的意思,如果不理解缓冲区的意思,可以自行百度一下,我理解的缓冲区就是,当我们要在PHP中输出一些数据显示出来时,会先经过缓冲区,而我们可以从缓冲区中得到这些内容。所以实现纯静态页面的方法就是,获取缓冲区中的内容放到一个静态文件中,并在入口中根据需求设置访问动态文件还是静态文件,这种方法一般用于数据不经常变化的动态页面中。下面就来具体的实现这个功能。

static.php

<?php
//1.使用刚才写的数据库连接类连接数据库
//2.把获取到的数据填充到模板文件中
//3.把页面转化为静态文件
//如果我们本地有这个静态文件并且这个文件生成的时间小于5分钟那么就去访问这个静态文件,filemtime()用来获取文件的最后修改时间
if(is_file('./static.shtml') && (time() - filemtime('./static.shtml')) < 300) {
  //这里很简单,直接把静态文件拿过来
  require_once('./static.shtml');
}else {
//如果不存在这个静态文件,或者这个静态文件的最后修改时间距离现在已经超过了5分钟,那么就访问动态获取数据的模板,然后更新static.shtml文件的内容
  //连接数据库
  header('Content-Type:text/html;charset=utf-8');
  require_once('./db.php');
  $connect = DB::getInstance()->connect();
  //执行查询操作
  $sql = 'select * from account';
  $res = $connect->query($sql);
  //开启缓冲区
  ob_start();
  //ob_get_clean()这个函数可以获取缓冲区的内容并清空,一会我会测试一下ob_get_clean()和ob_get_contents()的
  require_once('./static_show.php');
  //把缓冲区的内容写入到静态文件
  file_put_contents('./static.shtml', ob_get_contents());
}
?>

动态展示模板文件static_show.php

<?php
  foreach($res as $row) {
    echo '名字:'.$row['name'].'<br/>';
    echo '钱包:'.$row['money'].'<br/>';
    echo '<hr/>';
  }
?>

当我们访问static.php的时候,因为没有static.shtml,所以会先执行else的操作,展示在static_show.php并生成static.shtml文件

PHP单例模式数据库连接类与页面静态化实现方法

如果这时候我把数据库修改了,zjp的money改为800,然后再访问static.php会展示什么样的内容呢,没错,zjp的钱包还是600,为什么呢,因为它执行了if中的内容,直接显示了static.shtml,我们可以看一下static.shtml是什么样的:

PHP单例模式数据库连接类与页面静态化实现方法

如果5分钟过后再访问staitc.php呢,会显示什么呢,没错!zjp的钱包就变成800了,并且static.shtml的内容会更新为zjp的钱包是800。

测试ob_get_clean()和ob_get_contents()

测试方法很简单:

<?php
$test = 'Hello World!';
//开启缓冲区
ob_start();
//测试ob_get_contents()
echo $test;
echo ob_get_contents();
//输出结果:Hello World!Hello World!
//测试ob_get_clean()
echo $test;
echo ob_get_clean();
//输出结果:Hello World!
echo $test;
ob_get_clean();
//输出结果:
?>

这样就可以很清楚的看出来了,当我们使用了ob_get_clean()的时候,输出语句并不会输出任何值,因为ob_get_clean()会获取缓冲区中的内容并将缓冲区清空。所以当我们echo test的时候并没有得到test的时候并没有得到test的值,echo ob_get_clean()的时候却能够获取到值。而当我们使用ob_get_contents()的时候缓冲区中的内容并没有被清空。

实际上,ob_get_clean()函数相当于执行了,ob_get_contents()ob_end_clean()

希望本文所述对大家PHP程序设计有所帮助。

PHP 相关文章推荐
PHP的面试题集
Nov 19 PHP
通过PHP的内置函数,通过DES算法对数据加密和解密
Jun 21 PHP
PHP对象递归引用造成内存泄漏分析
Aug 28 PHP
php中文字符串截取方法实例总结
Sep 30 PHP
thinkphp判断访客为手机端或PC端的方法
Nov 24 PHP
php中动态变量用法实例
Jun 10 PHP
一个简单至极的PHP缓存类代码
Oct 23 PHP
PHP检测用户是否关闭浏览器的方法
Feb 14 PHP
php数组分页实现方法
Apr 30 PHP
php加密解密字符串示例
Oct 13 PHP
PHP调用API接口实现天气查询功能的示例
Sep 21 PHP
PHP 7.4中使用预加载的方法详解
Jul 08 PHP
PHP实现的策略模式示例
Mar 20 #PHP
PHP实现数组和对象的相互转换操作示例
Mar 20 #PHP
Laravel5.4框架使用socialite实现github登录的方法
Mar 20 #PHP
PHP工厂模式的日常使用
Mar 20 #PHP
PHP函数积累总结
Mar 19 #PHP
PHP与Perl之间知识点区别整理
Mar 19 #PHP
PHP后台备份MySQL数据库的源码实例
Mar 18 #PHP
You might like
php下尝试使用GraphicsMagick的缩略图功能
2011/01/01 PHP
PHP简洁函数小结
2011/08/12 PHP
PHP用mysql_insert_id()函数获得刚插入数据或当前发布文章的ID
2016/11/25 PHP
php str_getcsv把字符串解析为数组的实现方法
2017/04/05 PHP
关于火狐(firefox)及ie下event获取的两种方法
2012/12/27 Javascript
js操作CheckBoxList实现全选/反选(在客服端完成)
2013/02/02 Javascript
jquery $.each()使用探讨
2013/09/23 Javascript
Javascript中常见的校验如域名、手机、邮箱等等
2014/01/02 Javascript
浅析JS中document对象的一些重要属性
2014/03/06 Javascript
jQuery中的insertBefore(),insertAfter(),after(),before()区别介绍
2016/09/01 Javascript
jQuery焦点图左右转换效果
2016/12/12 Javascript
js实现图片左右滚动效果
2017/02/27 Javascript
js字符串与Unicode编码互相转换
2017/05/17 Javascript
vue2.0 自定义组件的方法(vue组件的封装)
2018/06/05 Javascript
Bootstrap 模态框自定义点击和关闭事件详解
2018/08/10 Javascript
Vue实现table上下移动功能示例
2019/02/21 Javascript
vue项目中使用多选框的实例代码
2020/07/22 Javascript
jquery插件实现轮播图效果
2020/10/19 jQuery
[45:18]完美世界DOTA2联赛循环赛 PXG vs IO 第二场 11.06
2020/11/09 DOTA
简单的编程0基础下Python入门指引
2015/04/01 Python
Python编程实现控制cmd命令行显示颜色的方法示例
2017/08/14 Python
Python中的二维数组实例(list与numpy.array)
2018/04/13 Python
对python mayavi三维绘图的实现详解
2019/01/08 Python
python opencv摄像头的简单应用
2019/06/06 Python
Python的numpy库下的几个小函数的用法(小结)
2019/07/12 Python
在Ubuntu 20.04中安装Pycharm 2020.1的图文教程
2020/04/30 Python
Python中的__init__作用是什么
2020/06/09 Python
python正则表达式 匹配反斜杠的操作方法
2020/08/07 Python
TensorFlow2.0使用keras训练模型的实现
2021/02/20 Python
canvas使用注意点总结
2013/07/19 HTML / CSS
如果Session Bean得Remove方法一直都不被调用会怎么样
2012/07/14 面试题
高中学生干部学习的自我评价
2014/02/21 职场文书
三方合作协议书范本
2014/04/18 职场文书
临时租车协议范本
2014/09/23 职场文书
开学典礼致辞
2015/07/29 职场文书
python DataFrame中stack()方法、unstack()方法和pivot()方法浅析
2022/04/06 Python