(*暂时未拆分前端控制器和应用控制器,全部集成在Command类实现)
1 注册表模式//注册表模式//注册表模式用于提供一个系统级别对象,在任何地方都方便访问(可以使用单例模式)class Registry{ private static $instance; private $request; private function __construct(){} static function instance(){ if(!isset(self::$instance)){ self::$instance=new self(); } return self::$instance; } function getRequest(){ $this->request; } function setRequest(Request $request){ $this->request=$request; }}class Request{} 2 三种作用域下的注册表namespace woo\controller;class Request{}class Complex{}//创建一个具有作用域的注册表模式//请求级别注册表namespace woo\base;use woo;abstract class Registry{ abstract protected function get($key); abstract protected function set($key,$val); }class RequestRegistry extends Registry{ private $values=array(); private static $instance; private function __construct(){} //返回唯一实例 static function instance(){ if(!isset(self::$instance)){ self::$instance=new self(); } return self::$instance; } protected function get($key){ if(isset($this->values[$key])){ return isset($this->values[$key]); } return null; } protected function set($key, $val){ $this->values[$key]=$val; } static function getRequest(){ return self::instance()->get('request'); } static function setRequest(woo\controller\Request $request){ return self::instance()->set('request', $request); }}//会话级别的注册表class SessionRegistry extends Registry{ private static $instance; private function __construct(){ session_start(); } //返回唯一实例 static function instance(){ if(!isset(self::$instance)){ self::$instance=new self(); } return self::$instance; } protected function get($key){ if( isset($_SESSION[__CLASS__][$key]) ){ return isset($_SESSION[__CLASS__][$key]); } return null; } protected function set($key, $val){ $_SESSION[__CLASS__][$key]=$val; } static function getComplex(){ return self::instance()->get('complex'); } static function setRequest(woo\controller\Complex $request){ return self::instance()->set('complex', $request); }}//应用程序级别的注册表class ApplicationRegistry extends Registry{ private static $instance; private $freezedir='Data'; private $values=array(); private $mtimes=array(); private function __construct(){ session_start(); } //返回唯一实例 static function instance(){ if(!isset(self::$instance)){ self::$instance=new self(); } return self::$instance; } //get,set都是单独保存一个$key到文件中 protected function get($key){ $path=$this->freezedir.DIRECTORY_SEPARATOR.$key; if(file_exists($path)){ clearstatcache(); //获取文件修改时间 $mtime=filemtime($path); if(!isset($this->mtimes[$key])){ $this->mtimes[$key]=0; } //如果文件被修改 if($mtime > $this->mtimes[$key]){ $data=file_get_contents($path); $this->mtimes[$key]=$mtime; return ($this->values[$key]=unserialize($data)); } } if(isset($this->values[$key])){ return $this->values[$key]; } return null; } protected function set($key, $val){ $this->values[$key]=$val; $path=$this->freezedir.DIRECTORY_SEPARATOR.$key; //文件不存在会自动创建 file_put_contents($path, serialize($val)); $this->mtimes[$key]=time(); } static function getDSN(){ return self::$instance()->get('DSN'); } static function setDSN($dsn){ return self::$instance()->set('DSN',$dsn); }}3 前端控制器Controller----结合注册表模式与命令模式打造统一入口框架<?phpnamespace Woo\Command;include_once("./Woo/Controller/Request.php");//Command类 //* 命令对象拥有独立处理视图的功能abstract class Command{ //任何子类都无法覆盖该方法(永远无参数) final function __construct(){} //该方法传入一个Request对象,所以拥有访问请求数据的能力 function execute(\Woo\Controller\Request $request){ //可以做其他事情 //... //再调用doExecute方法 $this->doExecute($request); } function disPlay($request){ //获取cmd,用于决定调取那个页面 $cmd=$request->getProperty('cmd'); //写法不是很好....截取command之前的字符 print $cmd; $viewUrl="./Woo/View/".substr($cmd,0,strlen($cmd)-(7))."View.html"; include_once($viewUrl); } abstract function doExecute(\Woo\Controller\Request $request);} <?phpnamespace Woo\Command;include_once("./Woo/Controller/Request.php");include_once("./Woo/Command/DefaultCommand.php");//CommandResolver 命令解析器class CommandResolver{ private static $base_cmd; private static $default_cmd; function __construct(){ if(!self::$base_cmd){ self::$base_cmd=new \ReflectionClass("\Woo\Command\Command"); self::$default_cmd=new DefaultCommand(); } } function getCommand(\Woo\Controller\Request $request){ //指定需要调用的Command的key为cmd $cmd=$request->getProperty('cmd'); $sep=DIRECTORY_SEPARATOR; //找不到指定cmd数据时,返回默认cmd实例 if(!$cmd){ return clone self::$default_cmd; } $cmd=str_replace(array('.',$sep), "", $cmd); $filePath=".\Woo{$sep}Command{$sep}{$cmd}.php"; $className="\Woo\\Command\\{$cmd}"; if(file_exists($filePath)){ require_once("$filePath"); //判断传入的类是否存在,是否是base_cmd的子类 if(class_exists($className)){ $cmd_class=new \ReflectionClass($className); if($cmd_class->isSubclassOf(self::$base_cmd)){ return $cmd_class->newInstance(); }else{ //解析失败,跳转到默认页面 $request->addFeedback("command '$cmd' is not a command"); return clone self::$default_cmd; } } }else{ $request->addFeedback("command '$cmd' is not found"); return clone self::$default_cmd; } }}<?phpnamespace Woo\Command;include_once("./Woo/Controller/Request.php");include_once("./Woo/Command/Command.php");class DefaultCommand extends Command{ function doExecute(\Woo\Controller\Request $request){ $request->addFeedback("Welcome to WOO!"); $feedbacks=$request->getFeedback(); foreach ($feedbacks as $key=>$val){ print $val; print "<br>"; } include_once("Woo/View/main.html"); }}<?phpnamespace Woo\Command;include_once("./Woo/Controller/Request.php");include_once("./Woo/Command/Command.php");class MyCommand extends Command{ function doExecute(\Woo\Controller\Request $request){ $request->addFeedback("Welcome to WOO!"); $feedbacks=$request->getFeedback(); foreach ($feedbacks as $key=>$val){ print $val; print "<br>"; } $this->disPlay($request); }}<?phpnamespace Woo\Base;include_once("./Woo/Base/Registry.php");//应用程序级别的注册表//*DNS Data Source Nameclass ApplicationRegistry extends Registry{ private static $instance; private $freezedir='./Woo/Cache'; private $values=array(); private $mtimes=array(); private function __construct(){ session_start(); } //返回唯一实例 static function instance(){ if(!isset(self::$instance)){ self::$instance=new self(); } return self::$instance; } //get,set都是单独保存一个$key到文件中 protected function get($key){ $path=$this->freezedir.DIRECTORY_SEPARATOR.$key; if(file_exists($path)){ clearstatcache(); //获取文件修改时间 $mtime=filemtime($path); if(!isset($this->mtimes[$key])){ $this->mtimes[$key]=0; } //如果文件被修改 if($mtime > $this->mtimes[$key]){ $data=file_get_contents($path); $this->mtimes[$key]=$mtime; return ($this->values[$key]=unserialize($data)); } } if(isset($this->values[$key])){ return $this->values[$key]; } return null; } protected function set($key, $val){ $this->values[$key]=$val; $path=$this->freezedir.DIRECTORY_SEPARATOR.$key; if(!is_dir($this->freezedir)){ mkdir($this->freezedir); } //文件不存在会自动创建 file_put_contents($path, serialize($val)); $this->mtimes[$key]=time(); } static function getDSN(){ return self::instance()->get('DSN'); } static function setDSN($dsn){ return self::instance()->set('DSN',$dsn); }}<?phpnamespace Woo\Base;//创建一个具有作用域的注册表模式//请求级别注册表abstract class Registry{ abstract protected function get($key); abstract protected function set($key,$val);}<?phpnamespace Woo\Base;include_once("./Woo/Base/Registry.php");include_once("./Woo/Controller/Request.php");//请求级别注册表class RequestRegistry extends Registry{ private $values=array(); private static $instance; private function __construct(){} //返回唯一实例 static function instance(){ if(!isset(self::$instance)){ self::$instance=new self(); } return self::$instance; } protected function get($key){ if(isset($this->values[$key])){ return isset($this->values[$key]); } return null; } protected function set($key, $val){ $this->values[$key]=$val; } static function getRequest(){ return self::instance()->get('request'); } static function setRequest(\Woo\Controller\Request $request){ return self::instance()->set('request', $request); }}<?phpnamespace Woo\Base;include_once("./Woo/Base/Registry.php");//会话级别的注册表class SessionRegistry extends Registry{ private static $instance; private function __construct(){ session_start(); } //返回唯一实例 static function instance(){ if(!isset(self::$instance)){ self::$instance=new self(); } return self::$instance; } protected function get($key){ if( isset($_SESSION[__CLASS__][$key]) ){ return isset($_SESSION[__CLASS__][$key]); } return null; } protected function set($key, $val){ $_SESSION[__CLASS__][$key]=$val; } static function getComplex(){ return self::instance()->get('complex'); } static function setRequest(Woo\Controller\Complex $request){ return self::instance()->set('complex', $request); }}<?phpnamespace Woo\Controller;include_once("./Woo/Base/ApplicationRegistry.php");//ApplicationHelper 应用助手类--负责读取配置文件数据,提供给客户端代码//*本类利用缓存机制,提高性能class ApplicationHelper{ private static $instance; private $config="./Woo/Config/woo_options.xml"; //使用单例模式,用于获取配置 private function __construct(){} static function instance(){ if(!self::$instance){ self::$instance=new self(); } return self::$instance; } function init(){ //查看缓存数据是否存在 $dsn=\Woo\Base\ApplicationRegistry::getDSN(); if(!is_null($dsn)){ //$dsn不为空时直接返回 return; } $this->getOptions(); } //只有缓存数据不存在时才会调用该方法 private function getOptions(){ $this->ensure(file_exists($this->config), "Could not find options file!"); $options=simplexml_load_file($this->config); print get_class($options); $dsn=$options->dsn; $this->ensure($dsn, "No DSN found!"); //获取值之后,将其存放进应用程序级别注册表中,方便缓存使用 //先转化成数组,方便序列化 \Woo\Base\ApplicationRegistry::setDSN(array($dsn->__toString())); //设置其他值 //... } private function ensure($expr,$message){ if(!$expr){ throw new \Exception($message); } }}<?phpnamespace Woo\Controller;class Complex{ }<?phpnamespace Woo\Controller;//引入所有需要的文件include_once("./Woo/Controller/ApplicationHelper.php");include_once("./Woo/Command/CommandResolver.php");include_once("./Woo/Command/Command.php");//Controller类class Controller{ private $applicationHelper; private function __construct(){} //该类只能通过run方法获得实例 static function run(){ $instance=new Controller(); //理论上讲init只需在应用程序第一次启动时调用 //(但是PHP属于解释型语言,所以每次都必须调用) $instance->init(); //理论上讲handleRequest需要在每次请求到来时运行 $instance->handleRequest(); } function init(){ //获取一个单例,用于做全局配置 $applicationHelper=ApplicationHelper::instance(); $applicationHelper->init(); } //每次请求都需要调用一次 function handleRequest(){ $request=new Request(); $cmd_r=new \Woo\Command\CommandResolver(); //根据request生成对应command抽象类(接口)的子类实例 //之后要利用command执行相关动作 $cmd=$cmd_r->getCommand($request); $cmd->execute($request); }}<?phpnamespace Woo\Controller;include_once("./Woo/Base/RequestRegistry.php");//用于存储需要和视图层交换的数据class Request{ private $properties; private $feedback=array(); function __construct(){ $this->init(); \Woo\Base\RequestRegistry::setRequest($this); } //同时支持HTTP请求和命令行参数(可用于调试程序使用) //*用于将参数填充进properties属性里 function init(){ //表单提交方式 if(isset($_SERVER['REQUEST_METHOD'])){ //用于收集表单提交的数据 $this->properties=$_REQUEST; return; } //$_SERVER['argv'] 传递给该脚本的参数 foreach ($_SERVER['argv'] as $arg){ //搜索字符串第一次出现的位置 if(strpos($arg, '=')){ list($key,$val)=explode("=", $arg); $this->setProperty($key,$val); } } } function getProperty($key){ if(isset($this->properties[$key])){ return $this->properties[$key]; } return null; } function setProperty($key,$val){ $this->properties[$key]=$val; } function addFeedback($msg){ array_push($this->feedback, $msg); } function getFeedback(){ return $this->feedback; } function getFeedbackString($separator="\n"){ return implode($separator,$this->feedback); }}//woo_options.xml<?xml version="1.0" encoding="UTF-8"?><data><dsn>dsn</dsn><dsn2>DSN</dsn2></data> //框架入口index.php<?phpuse Woo\Controller\Controller;include_once("./Woo/Controller/Controller.php");//print_r($_GET);//框架入口Controller::run();

PHP는 주로 절차 적 프로그래밍이지만 객체 지향 프로그래밍 (OOP)도 지원합니다. Python은 OOP, 기능 및 절차 프로그래밍을 포함한 다양한 패러다임을 지원합니다. PHP는 웹 개발에 적합하며 Python은 데이터 분석 및 기계 학습과 같은 다양한 응용 프로그램에 적합합니다.

PHP는 1994 년에 시작되었으며 Rasmuslerdorf에 의해 개발되었습니다. 원래 웹 사이트 방문자를 추적하는 데 사용되었으며 점차 서버 측 스크립팅 언어로 진화했으며 웹 개발에 널리 사용되었습니다. Python은 1980 년대 후반 Guidovan Rossum에 의해 개발되었으며 1991 년에 처음 출시되었습니다. 코드 가독성과 단순성을 강조하며 과학 컴퓨팅, 데이터 분석 및 기타 분야에 적합합니다.

PHP는 웹 개발 및 빠른 프로토 타이핑에 적합하며 Python은 데이터 과학 및 기계 학습에 적합합니다. 1.PHP는 간단한 구문과 함께 동적 웹 개발에 사용되며 빠른 개발에 적합합니다. 2. Python은 간결한 구문을 가지고 있으며 여러 분야에 적합하며 강력한 라이브러리 생태계가 있습니다.

PHP는 현대화 프로세스에서 많은 웹 사이트 및 응용 프로그램을 지원하고 프레임 워크를 통해 개발 요구에 적응하기 때문에 여전히 중요합니다. 1.PHP7은 성능을 향상시키고 새로운 기능을 소개합니다. 2. Laravel, Symfony 및 Codeigniter와 같은 현대 프레임 워크는 개발을 단순화하고 코드 품질을 향상시킵니다. 3. 성능 최적화 및 모범 사례는 응용 프로그램 효율성을 더욱 향상시킵니다.

phphassignificallyimpactedwebdevelopmentandextendsbeyondit

PHP 유형은 코드 품질과 가독성을 향상시키기위한 프롬프트입니다. 1) 스칼라 유형 팁 : PHP7.0이므로 int, float 등과 같은 기능 매개 변수에 기본 데이터 유형을 지정할 수 있습니다. 2) 반환 유형 프롬프트 : 기능 반환 값 유형의 일관성을 확인하십시오. 3) Union 유형 프롬프트 : PHP8.0이므로 기능 매개 변수 또는 반환 값에 여러 유형을 지정할 수 있습니다. 4) Nullable 유형 프롬프트 : NULL 값을 포함하고 널 값을 반환 할 수있는 기능을 포함 할 수 있습니다.

PHP에서는 클론 키워드를 사용하여 객체 사본을 만들고 \ _ \ _ Clone Magic 메소드를 통해 클로닝 동작을 사용자 정의하십시오. 1. 복제 키워드를 사용하여 얕은 사본을 만들어 객체의 속성을 복제하지만 객체의 속성은 아닙니다. 2. \ _ \ _ 클론 방법은 얕은 복사 문제를 피하기 위해 중첩 된 물체를 깊이 복사 할 수 있습니다. 3. 복제의 순환 참조 및 성능 문제를 피하고 클로닝 작업을 최적화하여 효율성을 향상시키기 위해주의를 기울이십시오.

PHP는 웹 개발 및 컨텐츠 관리 시스템에 적합하며 Python은 데이터 과학, 기계 학습 및 자동화 스크립트에 적합합니다. 1.PHP는 빠르고 확장 가능한 웹 사이트 및 응용 프로그램을 구축하는 데 잘 작동하며 WordPress와 같은 CMS에서 일반적으로 사용됩니다. 2. Python은 Numpy 및 Tensorflow와 같은 풍부한 라이브러리를 통해 데이터 과학 및 기계 학습 분야에서 뛰어난 공연을했습니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

WebStorm Mac 버전
유용한 JavaScript 개발 도구

Dreamweaver Mac版
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)
