这次给大家带来PHP基于面向对象实现留言本步骤详解,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($page<1 || $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;$i<ceil($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。项目越大越能体现模块划分、面向对象的好处。
下面是完整的代码
$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($page<1 || $page>$count) $page = 1; $pnum = 9; $begin = ($page-1) * $pnum; $end = ($begin+$pnum) > $count ? $count :$begin + $pnum; for($i=$begin; $i<$end; $i++) { echo '',$i+1,'',$handle[$i],'
'; } for($i=1;$i'.$i.''; } } //写入留言 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基于面向对象实现留言本步骤详解的详细内容。更多信息请关注PHP中文网其他相关文章!

phpsessionstrackuserdataacrossmultiplepagerequestsusingauniqueIdStoredInacookie.here'showtomanageThemeffectionaly:1)startAsessionWithSessionwwithSession_start()和stordoredAtain $ _session.2)

在PHP中,遍历会话数据可以通过以下步骤实现:1.使用session_start()启动会话。2.通过foreach循环遍历$_SESSION数组中的所有键值对。3.处理复杂数据结构时,使用is_array()或is_object()函数,并用print_r()输出详细信息。4.优化遍历时,可采用分页处理,避免一次性处理大量数据。这将帮助你在实际项目中更有效地管理和使用PHP会话数据。

会话通过服务器端的状态管理机制实现用户认证。1)会话创建并生成唯一ID,2)ID通过cookies传递,3)服务器存储并通过ID访问会话数据,4)实现用户认证和状态管理,提升应用安全性和用户体验。

Tostoreauser'snameinaPHPsession,startthesessionwithsession_start(),thenassignthenameto$_SESSION['username'].1)Usesession_start()toinitializethesession.2)Assigntheuser'snameto$_SESSION['username'].Thisallowsyoutoaccessthenameacrossmultiplepages,enhanc

PHPSession失效的原因包括配置错误、Cookie问题和Session过期。1.配置错误:检查并设置正确的session.save_path。2.Cookie问题:确保Cookie设置正确。3.Session过期:调整session.gc_maxlifetime值以延长会话时间。

在PHP中调试会话问题的方法包括:1.检查会话是否正确启动;2.验证会话ID的传递;3.检查会话数据的存储和读取;4.查看服务器配置。通过输出会话ID和数据、查看会话文件内容等方法,可以有效诊断和解决会话相关的问题。

多次调用session_start()会导致警告信息和可能的数据覆盖。1)PHP会发出警告,提示session已启动。2)可能导致session数据意外覆盖。3)使用session_status()检查session状态,避免重复调用。

在PHP中配置会话生命周期可以通过设置session.gc_maxlifetime和session.cookie_lifetime来实现。1)session.gc_maxlifetime控制服务器端会话数据的存活时间,2)session.cookie_lifetime控制客户端cookie的生命周期,设置为0时cookie在浏览器关闭时过期。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。