(*暂时未拆分前端控制器和应用控制器,全部集成在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和Python各有优势,选择应基于项目需求。1.PHP适合web开发,语法简单,执行效率高。2.Python适用于数据科学和机器学习,语法简洁,库丰富。

PHP不是在消亡,而是在不断适应和进化。1)PHP从1994年起经历多次版本迭代,适应新技术趋势。2)目前广泛应用于电子商务、内容管理系统等领域。3)PHP8引入JIT编译器等功能,提升性能和现代化。4)使用OPcache和遵循PSR-12标准可优化性能和代码质量。

PHP的未来将通过适应新技术趋势和引入创新特性来实现:1)适应云计算、容器化和微服务架构,支持Docker和Kubernetes;2)引入JIT编译器和枚举类型,提升性能和数据处理效率;3)持续优化性能和推广最佳实践。

在PHP中,trait适用于需要方法复用但不适合使用继承的情况。1)trait允许在类中复用方法,避免多重继承复杂性。2)使用trait时需注意方法冲突,可通过insteadof和as关键字解决。3)应避免过度使用trait,保持其单一职责,以优化性能和提高代码可维护性。

依赖注入容器(DIC)是一种管理和提供对象依赖关系的工具,用于PHP项目中。DIC的主要好处包括:1.解耦,使组件独立,代码易维护和测试;2.灵活性,易替换或修改依赖关系;3.可测试性,方便注入mock对象进行单元测试。

SplFixedArray在PHP中是一种固定大小的数组,适用于需要高性能和低内存使用量的场景。1)它在创建时需指定大小,避免动态调整带来的开销。2)基于C语言数组,直接操作内存,访问速度快。3)适合大规模数据处理和内存敏感环境,但需谨慎使用,因其大小固定。

PHP通过$\_FILES变量处理文件上传,确保安全性的方法包括:1.检查上传错误,2.验证文件类型和大小,3.防止文件覆盖,4.移动文件到永久存储位置。

JavaScript中处理空值可以使用NullCoalescingOperator(??)和NullCoalescingAssignmentOperator(??=)。1.??返回第一个非null或非undefined的操作数。2.??=将变量赋值为右操作数的值,但前提是该变量为null或undefined。这些操作符简化了代码逻辑,提高了可读性和性能。


热AI工具

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

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

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

记事本++7.3.1
好用且免费的代码编辑器

Dreamweaver CS6
视觉化网页开发工具

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

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具