这次给大家带来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$count) $page = 1; $pnum = 9; $begin = ($page-1) * $pnum; $end = ($begin+$pnum) > $count ? $count :$begin + $pnum; for($i=$begin; $i',$i+1,'',$handle[$i],'<br>'; } for($i=1;$i<ceil>'.$i.''; } }</ceil>
然后到前端控制器里添加对应的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$count) $page = 1; $pnum = 9; $begin = ($page-1) * $pnum; $end = ($begin+$pnum) > $count ? $count :$begin + $pnum; for($i=$begin; $i',$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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

tomodifyDatainAphPessess, startSessionstession_start (), 그런 다음 $ _sessionToset, modify, orremovevariables.

배열은 PHP 세션에 저장할 수 있습니다. 1. 세션을 시작하고 session_start ()를 사용하십시오. 2. 배열을 만들고 $ _session에 저장하십시오. 3. $ _session을 통해 배열을 검색하십시오. 4. 세션 데이터를 최적화하여 성능을 향상시킵니다.

PHP 세션 쓰레기 수집은 만료 된 세션 데이터를 정리하기위한 확률 메커니즘을 통해 트리거됩니다. 1) 구성 파일에서 트리거 확률 및 세션 수명주기를 설정합니다. 2) CRON 작업을 사용하여 고재 응용 프로그램을 최적화 할 수 있습니다. 3) 데이터 손실을 피하기 위해 쓰레기 수집 빈도 및 성능의 균형을 맞춰야합니다.

PHP의 사용자 세션 활동 추적은 세션 관리를 통해 구현됩니다. 1) Session_start ()를 사용하여 세션을 시작하십시오. 2) $ _session 배열을 통해 데이터를 저장하고 액세스하십시오. 3) 세션 _destroy ()를 호출하여 세션을 종료합니다. 세션 추적은 사용자 행동 분석, 보안 모니터링 및 성능 최적화에 사용됩니다.

데이터베이스를 사용하여 PHP 세션 데이터를 저장하면 성능 및 확장 성을 향상시킬 수 있습니다. 1) 세션 데이터를 저장하기 위해 MySQL 구성 : php.ini 또는 php 코드에서 세션 프로세서를 설정하십시오. 2) 사용자 정의 세션 프로세서 구현 : 데이터베이스와 상호 작용하기 위해 열린, 닫기, 읽기, 쓰기 및 기타 기능을 정의합니다. 3) 최적화 및 모범 사례 : 인덱싱, 캐싱, 데이터 압축 및 분산 스토리지를 사용하여 성능을 향상시킵니다.

phpsessionstrackuserdataacrossmultiplepagerequestsususingauniqueIdStoredInAcookie.here'showtomanagetheMeftically : 1) STARTASESSIONSTART_START () andSTAREDATAIN $ _SESSION.2) RegenerATERATESSESSIDIDAFTERLOGINWITHSESSION_RATERATERATES (True) TopreventSES

PHP에서 세션 데이터를 통한 반복은 다음 단계를 통해 달성 할 수 있습니다. 1. Session_start ()를 사용하여 세션을 시작하십시오. 2. $ _session 배열의 모든 키 값 쌍을 통해 Foreach 루프를 통과합니다. 3. 복잡한 데이터 구조를 처리 할 때 is_array () 또는 is_object () 함수를 사용하고 print_r ()를 사용하여 자세한 정보를 출력하십시오. 4. Traversal을 최적화 할 때 페이징을 사용하여 한 번에 많은 양의 데이터를 처리하지 않도록 할 수 있습니다. 이를 통해 실제 프로젝트에서 PHP 세션 데이터를보다 효율적으로 관리하고 사용하는 데 도움이됩니다.

이 세션은 서버 측 상태 관리 메커니즘을 통해 사용자 인증을 인식합니다. 1) 세션 생성 및 고유 ID의 세션 생성, 2) ID는 쿠키를 통해 전달됩니다. 3) ID를 통해 서버 저장 및 세션 데이터에 액세스합니다. 4) 사용자 인증 및 상태 관리가 실현되어 응용 프로그램 보안 및 사용자 경험이 향상됩니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

안전한 시험 브라우저
안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!
