PHP單例模式數(shù)據(jù)庫連接類與頁面靜態(tài)化實(shí)現(xiàn)方法
本文實(shí)例講述了PHP單例模式數(shù)據(jù)庫連接類與頁面靜態(tài)化實(shí)現(xiàn)方法。分享給大家供大家參考,具體如下:
數(shù)據(jù)庫test中數(shù)據(jù)表account內(nèi)容

單例模式的數(shù)據(jù)庫連接類
db.php
<?php
//單例模式的數(shù)據(jù)庫連接
class DB {
//存儲實(shí)例的靜態(tài)成員變量
static public $_instance;
//數(shù)據(jù)庫連接靜態(tài)變量
static public $_connectSource;
//連接數(shù)據(jù)庫配置,由于前幾天學(xué)習(xí)了PDO,這里就使用PDO
private $_dbConfig = array(
'host' => 'localhost',
'user' = > 'root',
'password' => '',
'database' => 'test'
);
//禁止外部實(shí)例化
private function __construct() {
}
//實(shí)例化
public static function getInstance() {
if(self::$_instance instanceof self) {
return self::$_instance;
}
self::$_instance = new self();
return self::$_instance;
}
//數(shù)據(jù)庫連接
public function connect() {
//如果不存在數(shù)據(jù)庫連接就創(chuàng)建一個
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實(shí)現(xiàn)頁面靜態(tài)化的例子
其實(shí)原理很簡單,這里用到了幾個函數(shù),ob_start(),ob_get_contents(),file_put_contents(),ob_start()是開啟緩沖區(qū)的意思,ob_get_contents()是得到緩沖區(qū)內(nèi)容的意思,file_put_contents()是把內(nèi)容放到一個文件里的意思,如果不理解緩沖區(qū)的意思,可以自行百度一下,我理解的緩沖區(qū)就是,當(dāng)我們要在PHP中輸出一些數(shù)據(jù)顯示出來時,會先經(jīng)過緩沖區(qū),而我們可以從緩沖區(qū)中得到這些內(nèi)容。所以實(shí)現(xiàn)純靜態(tài)頁面的方法就是,獲取緩沖區(qū)中的內(nèi)容放到一個靜態(tài)文件中,并在入口中根據(jù)需求設(shè)置訪問動態(tài)文件還是靜態(tài)文件,這種方法一般用于數(shù)據(jù)不經(jīng)常變化的動態(tài)頁面中。下面就來具體的實(shí)現(xiàn)這個功能。
static.php
<?php
//1.使用剛才寫的數(shù)據(jù)庫連接類連接數(shù)據(jù)庫
//2.把獲取到的數(shù)據(jù)填充到模板文件中
//3.把頁面轉(zhuǎn)化為靜態(tài)文件
//如果我們本地有這個靜態(tài)文件并且這個文件生成的時間小于5分鐘那么就去訪問這個靜態(tài)文件,filemtime()用來獲取文件的最后修改時間
if(is_file('./static.shtml') && (time() - filemtime('./static.shtml')) < 300) {
//這里很簡單,直接把靜態(tài)文件拿過來
require_once('./static.shtml');
}else {
//如果不存在這個靜態(tài)文件,或者這個靜態(tài)文件的最后修改時間距離現(xiàn)在已經(jīng)超過了5分鐘,那么就訪問動態(tài)獲取數(shù)據(jù)的模板,然后更新static.shtml文件的內(nèi)容
//連接數(shù)據(jù)庫
header('Content-Type:text/html;charset=utf-8');
require_once('./db.php');
$connect = DB::getInstance()->connect();
//執(zhí)行查詢操作
$sql = 'select * from account';
$res = $connect->query($sql);
//開啟緩沖區(qū)
ob_start();
//ob_get_clean()這個函數(shù)可以獲取緩沖區(qū)的內(nèi)容并清空,一會我會測試一下ob_get_clean()和ob_get_contents()的
require_once('./static_show.php');
//把緩沖區(qū)的內(nèi)容寫入到靜態(tài)文件
file_put_contents('./static.shtml', ob_get_contents());
}
?>
動態(tài)展示模板文件static_show.php
<?php
foreach($res as $row) {
echo '名字:'.$row['name'].'<br/>';
echo '錢包:'.$row['money'].'<br/>';
echo '<hr/>';
}
?>
當(dāng)我們訪問static.php的時候,因?yàn)闆]有static.shtml,所以會先執(zhí)行else的操作,展示在static_show.php并生成static.shtml文件

如果這時候我把數(shù)據(jù)庫修改了,zjp的money改為800,然后再訪問static.php會展示什么樣的內(nèi)容呢,沒錯,zjp的錢包還是600,為什么呢,因?yàn)樗鼒?zhí)行了if中的內(nèi)容,直接顯示了static.shtml,我們可以看一下static.shtml是什么樣的:

如果5分鐘過后再訪問staitc.php呢,會顯示什么呢,沒錯!zjp的錢包就變成800了,并且static.shtml的內(nèi)容會更新為zjp的錢包是800。
測試ob_get_clean()和ob_get_contents()
測試方法很簡單:
<?php $test = 'Hello World!'; //開啟緩沖區(qū) ob_start(); //測試ob_get_contents() echo $test; echo ob_get_contents(); //輸出結(jié)果:Hello World!Hello World! //測試ob_get_clean() echo $test; echo ob_get_clean(); //輸出結(jié)果:Hello World! echo $test; ob_get_clean(); //輸出結(jié)果: ?>
這樣就可以很清楚的看出來了,當(dāng)我們使用了ob_get_clean()的時候,輸出語句并不會輸出任何值,因?yàn)?code>ob_get_clean()會獲取緩沖區(qū)中的內(nèi)容并將緩沖區(qū)清空。所以當(dāng)我們echo test的時候并沒有得到test的時候并沒有得到test的值,echo ob_get_clean()的時候卻能夠獲取到值。而當(dāng)我們使用ob_get_contents()的時候緩沖區(qū)中的內(nèi)容并沒有被清空。
實(shí)際上,ob_get_clean()函數(shù)相當(dāng)于執(zhí)行了,ob_get_contents()和ob_end_clean()。
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《PHP數(shù)組(Array)操作技巧大全》、《PHP基本語法入門教程》、《PHP運(yùn)算與運(yùn)算符用法總結(jié)》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
前后端分離和跨域問題的詳細(xì)解決方案(CORS的原理)
前后端跨域問題由瀏覽器同源策略而來,下面這篇文章主要給大家介紹了關(guān)于前后端分離和跨域問題的詳細(xì)解決方案,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-02-02
php開發(fā)中的頁面跳轉(zhuǎn)方法總結(jié)
PHP頁面跳轉(zhuǎn)實(shí)現(xiàn)的功能就是將網(wǎng)站中一個網(wǎng)頁跳轉(zhuǎn)到另一個網(wǎng)頁中。對于剛剛學(xué)習(xí)PHP語言的朋友來說,是必須要掌握的基礎(chǔ)方法。2015-04-04
PHP基于MySQL數(shù)據(jù)庫實(shí)現(xiàn)對象持久層的方法
這篇文章主要介紹了PHP基于MySQL數(shù)據(jù)庫實(shí)現(xiàn)對象持久層的方法,實(shí)例分析了php實(shí)現(xiàn)持久層的相關(guān)技巧,需要的朋友可以參考下2015-06-06
用mysql觸發(fā)器自動更新memcache的實(shí)現(xiàn)代碼
不錯的一篇文章,用于項(xiàng)目中可以帶來更多的便利,按照方法已經(jīng)調(diào)試成功,可以大大提高項(xiàng)目的速度。2009-10-10
php通過baihui網(wǎng)API實(shí)現(xiàn)讀取word文檔并展示
這篇文章主要介紹了php通過baihui網(wǎng)API實(shí)現(xiàn)讀取word文檔并展示的相關(guān)資料,需要的朋友可以參考下2015-06-06
通過緩存數(shù)據(jù)庫結(jié)果提高PHP性能的原理介紹
眾所周知,緩存數(shù)據(jù)庫查詢的結(jié)果可以顯著縮短腳本執(zhí)行時間,并最大限度地減少數(shù)據(jù)庫服務(wù)器上的負(fù)載。如果要處理的數(shù)據(jù)基本上是靜態(tài)的,則該技術(shù)將非常有效。這是因?yàn)閷h(yuǎn)程數(shù)據(jù)庫的許多數(shù)據(jù)請求最終可以從本地緩存得到滿足,從而不必連接到數(shù)據(jù)庫、執(zhí)行查詢以及獲取結(jié)果2012-09-09
PHP將Excel導(dǎo)入數(shù)據(jù)庫及數(shù)據(jù)庫數(shù)據(jù)導(dǎo)出至Excel的方法
這篇文章主要介紹了PHP將Excel導(dǎo)入數(shù)據(jù)庫及數(shù)據(jù)庫數(shù)據(jù)導(dǎo)出至Excel的方法,涉及php操作數(shù)據(jù)庫及Excel的相關(guān)技巧,需要的朋友可以參考下2015-06-06

