好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > PHP基于面向對象實現的留言本功能實例

PHP基于面向對象實現的留言本功能實例

熱門標簽:寧波外呼營銷系統 長沙做地圖標注公司 地圖標注專員怎么樣 遼寧ai電銷機器人價格 上海做外呼線路的通信公司 四川保險智能外呼系統供應商 房產中介用的是什么外呼系統 福建銀行智能外呼系統價格 電話機器人銷售主要負責什么

本文實例講述了PHP基于面向對象實現的留言本功能。分享給大家供大家參考,具體如下:

要設計一留言本,一切都將以留言本為核心,抓到什么是什么,按流程走下來,即按用戶填寫信息->留言->展示的流程進行。

現在用面向對象的思維思考這個問題,在面向對象的世界,會想盡辦法把肉眼能看見的以及看不見的,但是實際存在的物或者流程抽象出來。既然是留言本,那么就存在留言內容這個實體,這個留言實體(domain)應該包括留言者姓名、E-mail、留言內容等要素,如下面代碼所示

//留言實體類
class message
{
  public $name;//留言者姓名
  public $email;//留言者聯系方式
  public $content;//留言內容
  public function __set($name,$value)
  {
    $this->$name = $value;
  }
  public function __get($name)
  {
    if(!isset($this->$name))
    {
      $this->$name = NULL;
    }
  }
}

上面的類就是所說的domain,是一個真實存在的、經過抽象的實體模型。然后需要一個留言本模型,這個留言本模型包括留言本的基本屬性和基本操作,代碼如下所示

class gbookModel
{
  private $bookPath;//留言本文件
  private $data;//留言數據
  public function setBookPath($bookPath)
  {
    $this->bookPath = $bookPath;
  }
  public function getBookPath()
  {
    return $this->bookPath;
  }
  public function open()
  {
  }
  public function close()
  {
  }
  public function read()
  {
    return file_get_contents($this->bookPath);
  }
  //寫入留言
  public function write($data)
  {
    $this->data = self::safe($data)->name."".self::safe($data)->email." said: ".self::safe($data)->content.PHP_EOL;
    return file_put_contents($this->bookPath,$this->data,FILE_APPEND);
  }
  //模擬數據的安全處理,先拆包再打包
  public static function safe($data)
  {
    $reflect = new ReflectionObject($data);
    $props = $reflect->getProperties();
    $messagebox = new stdClass();
    foreach($props as $props)
    {
      $ivar = $props->getName();
      $messagebox->$ivar = trim($props->getValue($data));
    }
    return $messagebox;
  }
  public function delete()
  {
    file_put_contents($this->bookPath,"it's empty now");
  }
}

實際留言的過程可能會更復雜,可能還包括一系列準備操作以及log處理,所以應定義一個類負責數據的邏輯處理,代碼如下所示

class leaveModel
{
  public function write(gbookModel $gb, $data)
  {
    $book = $gb->getBookPath();
    $gb->write($data);
    //記錄日志
  }
}

最后,通過一個控制器,負責對各種操作的封裝,這個控制器是直接面向用戶的,所以包括留言本查看、刪除、留言等功能。可以形象理解為這個控制器就是留言本所提供的直接面向使用者的功能,封裝了操作細節,只需要調用控制器的相應方法即可,代碼如下所示

class authorControl
{
  public function message(leaveModel $l, gbookModel $g, message $data)
  {
    //在留言本上留言
    $l->write($g,$data);
  }
  public function view(gbookModel $g)
  {
    //查看留言本內容
    return $g->read();
  }
  public function delete(gbookModel $g)
  {
    $g->delete();
    echo self::view($g);
  }
}

測試代碼如下所示

$message = new message;
$message->name = 'chenqionghe';
$message->email = 'cqh@cqh.net';
$message->content = 'chenqionghe is a handson boy.';
$gb = new authorControl();//新建一個留言相關的控制器
$pen = new leaveModel();//拿出筆
$book = new gbookModel();//翻出筆記本
$book->setBookPath("E:\\chenqionghe.txt");
$gb->message($pen,$book,$message);
echo $gb->view($book);
//$gb->delete($book);

這樣看起來是不是比面向對象過程要復雜多了?確實是復雜了,代碼量增多了,也難理解 。似乎體現不出優點來。但是你思考過以下問題嗎?

1.如果讓很多人來負責完善這個留言本,一部分實體關系的建立,一部人負責數據操作層的代碼,這樣是不是更容易分工了呢?

2.如果我要把這個留言本進一步開發,實現記錄在數據庫中,或者添加分頁功能,又該如何呢?

要實現上面的第二問題提出的功能,只需在gookModel類中添加分頁方法,代碼如下所示

public function readByPage()
{
    $handle = file($this->bookPath);
    $count = count($handle);
    $page = isset($_GET['page']) ? intval($_GET['page']) : 1;
    if($page1 || $page>$count)
      $page = 1;
    $pnum = 9;
    $begin = ($page-1) * $pnum;
    $end = ($begin+$pnum) > $count ? $count :$begin + $pnum;
    for($i=$begin; $i$end; $i++)
    {
      echo 'strong>',$i+1,'/strong>',$handle[$i],'br />';
    }
    for($i=1;$iceil($count/$pnum);$i++)
    {
      echo 'a href="?page='.$i.'" rel="external nofollow" rel="external nofollow" >'.$i.'/a>';
    }
}

然后到前端控制器里添加對應的action,代碼如下所示

public function viewByPage(gbookModel $g)
{
    return $g->readByPage();
}

運行結果如下

只需要這么簡單的兩步,就可以實現所需要的分頁功能,而且已有的方法都不用修改,只需要在相關類中新增方法即可。當然,這個分頁在實際點擊時是有問題的,因為沒有把Action分開,而是通通放在一個頁面里。對照著上面的思路,還可以把留言本擴展為MySQL數據庫的。

這個程序只體現了非常簡單的設計模式,這個程序還有許多要改進的地方,每個程序員心中都有一個自己的OO。項目越大越能體現模塊劃分、面向對象的好處。

下面是完整的代碼

?php
//留言實體類
class message
{
  public $name;//留言者姓名
  public $email;//留言者聯系方式
  public $content;//留言內容
  public function __set($name,$value)
  {
    $this->$name = $value;
  }
  public function __get($name)
  {
    if(!isset($this->$name))
    {
      $this->$name = NULL;
    }
  }
}
/**
 * 留言本模型,負責管理留言本
 * $bookpath:留言本屬性
 */
class gbookModel
{
  private $bookPath;//留言本文件
  private $data;//留言數據
  public function setBookPath($bookPath)
  {
    $this->bookPath = $bookPath;
  }
  public function getBookPath()
  {
    return $this->bookPath;
  }
  public function open()
  {
  }
  public function close()
  {
  }
  public function read()
  {
    return file_get_contents($this->bookPath);
  }
  public function readByPage()
  {
    $handle = file($this->bookPath);
    $count = count($handle);
    $page = isset($_GET['page']) ? intval($_GET['page']) : 1;
    if($page1 || $page>$count)
      $page = 1;
    $pnum = 9;
    $begin = ($page-1) * $pnum;
    $end = ($begin+$pnum) > $count ? $count :$begin + $pnum;
    for($i=$begin; $i$end; $i++)
    {
      echo 'strong>',$i+1,'/strong>',$handle[$i],'br />';
    }
    for($i=1;$iceil($count/$pnum);$i++)
    {
      echo 'a href="?page='.$i.'" rel="external nofollow" rel="external nofollow" >'.$i.'/a>';
    }
  }
  //寫入留言
  public function write($data)
  {
    $this->data = self::safe($data)->name."".self::safe($data)->email." said: ".self::safe($data)->content.PHP_EOL;
    return file_put_contents($this->bookPath,$this->data,FILE_APPEND);
  }
  //模擬數據的安全處理,先拆包再打包
  public static function safe($data)
  {
    $reflect = new ReflectionObject($data);
    $props = $reflect->getProperties();
    $messagebox = new stdClass();
    foreach($props as $props)
    {
      $ivar = $props->getName();
      $messagebox->$ivar = trim($props->getValue($data));
    }
    return $messagebox;
  }
  public function delete()
  {
    file_put_contents($this->bookPath,"it's empty now");
  }
}
class leaveModel
{
  public function write(gbookModel $gb, $data)
  {
    $book = $gb->getBookPath();
    $gb->write($data);
    //記錄日志
  }
}
class authorControl
{
  public function message(leaveModel $l, gbookModel $g, message $data)
  {
    //在留言本上留言
    $l->write($g,$data);
  }
  public function view(gbookModel $g)
  {
    //查看留言本內容
    return $g->read();
  }
  public function viewByPage(gbookModel $g)
  {
    return $g->readByPage();
  }
  public function delete(gbookModel $g)
  {
    $g->delete();
    echo self::view($g);
  }
}
$message = new message;
$message->name = 'chenqionghe';
$message->email = 'cqh@cqh.net';
$message->content = 'chenqionghe is a handson boy.';
$gb = new authorControl();//新建一個留言相關的控制器
$pen = new leaveModel();//拿出筆
$book = new gbookModel();//翻出筆記本
$book->setBookPath("E:\\chenqionghe.txt");
$gb->message($pen,$book,$message);
//echo $gb->view($book);
echo $gb->viewByPage($book);
//$gb->delete($book);

更多關于PHP相關內容感興趣的讀者可查看本站專題:《PHP+MySQL留言板開發專題》、《php緩存技術總結》、《PHP數組(Array)操作技巧大全》、《php字符串(string)用法總結》、《PHP錯誤與異常處理方法總結》、《php面向對象程序設計入門教程》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》

希望本文所述對大家PHP程序設計有所幫助。

您可能感興趣的文章:
  • PHP面向對象五大原則之里氏替換原則(LSP)詳解
  • 舉例解析Java的設計模式編程中里氏替換原則的意義
  • 詳解Java設計模式編程中的里氏替換原則
  • 深入理解JavaScript系列(8) S.O.L.I.D五大原則之里氏替換原則LSP
  • PHP面向對象五大原則之依賴倒置原則(DIP)詳解
  • PHP面向對象五大原則之接口隔離原則(ISP)詳解
  • PHP面向對象五大原則之開放-封閉原則(OCP)詳解
  • PHP面向對象五大原則之單一職責原則(SRP)詳解
  • PHP面向對象之里氏替換原則簡單示例

標簽:常德 佛山 工商登記 澳門 延安 深圳 宜春 宿遷

巨人網絡通訊聲明:本文標題《PHP基于面向對象實現的留言本功能實例》,本文關鍵詞  PHP,基于,面向,對象,實現,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PHP基于面向對象實現的留言本功能實例》相關的同類信息!
  • 本頁收集關于PHP基于面向對象實現的留言本功能實例的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 末世肉文小说| 色欲av人妻精品一区二区| 玩弄熟妇高跟鞋高跟鞋鞋款| 人獸交VⅰCsZ0OZ0重口| 白丝护士被吹潮在线播放| 丰满的?子2理论视频在线观看| 野瞒丰满丰流老女人HD| 欧美疯狂性受XXXXX羞涩Av| 做我的爱人1韩国| 日韩午夜在线视频不卡片| 港台三级在线| 真人实景女处被破www免费看| 911香蕉视频| 久久精品国产亚洲7777最新章节| 男女啪啪试看| 成人男女网18免费视频| 七月丁香八月婷婷综合激情| 中国69xxxx| 欧美精品高清特级aa黑寡妇| free性欧美护士视频| 高山下的花环电影免费观看| 亚洲一级色| 班花在教室伦流澡到高潮作文| 国产十六处破外女视频在线观看| 亚洲香蕉综合在人在线视看| 巜人妻侵犯波多野结衣2演员表| 给娇妻找单男的真实小说| 色综合网址| 丫头把腿开大让我添添| 免费级毛片| 啊啊好深| 九色无码精品成人Av一二三区| 国产一区亚洲二区三区达达兔| 田中瞳冲田杏梨超乳在线播放| 女主被影帝各种姿势c| 欧美牲片Av| 男女啪啪一进一出无遮挡| 毛片高清| 男女吃奶做爰视频免费观看| 巜被褥里的人妻HD中字| 神豪肉多荤文高H污污文男男|