写一个属于自己的PHP的MVC框架(二)
第一篇文章已经把所需的目录搭建好了,接下来的工作就是写一些代码了
用编辑器打开public/index.php文件,写上下面的代码
<?php define(DS, DIRECTORY_SEPARATOR); define(ROOT, dirname(dirname(__FILE__))); $url = $_GET['url']; // 加载引导 require_once( ROOT . DS . 'core' . DS . 'bootstrap.php' );
入口文件的代码很简洁,其中$url是个全局变量,用来获取当做请求的参数
现在先把加载引导的那句注释掉,然后在下面echo $url,即
//require_once( ROOT . DS . 'core' . DS . 'bootstrap.php' );echo $url;
然后在浏览器地址栏输入http://localhost/wudicsmvc/
注:D:\AppServ\www\wudicsmvc
然后,你会发现,啥也没显示。
接着输入http://localhost/wudicsmvc/wudics
就会发现网页打出wudics这几个字
说明可以正常获取url参数了,这个作为一个全局变量存在,主要用来获取客户端的请求
如访问哪个控制器的哪个方法
http://localhost/wudicsmvc/home/index
可以这样规定,访问home控制器的index方法,当然你也可以有不同的规定,也就是路由规则,据说是mvc一个很重要的概念
index.php文件没有啥内容,加载了一个bootstrap.php文件,打开core目录下的bootstrap.php文件:
<?php // 加载配置 require_once(ROOT . DS . 'cfg' . DS . 'config.php'); // 路由请求 require_once(ROOT . DS . 'core' . DS . 'route.php');
同样加载了两个文件,一个是cfg目录下的config.php,一个是core目录下的route.php
看下config.php
<?php // mysql连接参数 define('DB_HOST', 'localhost'); define('DB_USER', 'root'); define('DB_PASS', '123456'); define('DB_NAME', 'transdb'); // smarty的一些常量 define('DIR_TPL', ROOT . DS . 'app' . DS . 'view' . DS . 'template_dir' . DS . 'default' . DS); define('DIR_CPL', ROOT . DS . 'app' . DS . 'view' . DS . 'compile_dir' . DS); define('DIR_CFG', ROOT . DS . 'app' . DS . 'view' . DS . 'config_dir' . DS); define('DIR_CAC', ROOT . DS . 'app' . DS . 'view' . DS . 'cache_dir' . DS); // 默认控制类方法 $default['controller'] = 'home'; $default['action'] = 'index'; // pulibc文件夹的路径,方便模板设计 define('WEBSITE', 'http://localhost'); define('WEBIMG', WEBSITE . dirname(dirname($_SERVER['PHP_SELF'])) . '/public/img/');
一些常量和全局变量,这个很有用,因为常量和全局变量在单一入口php程序里都是共享的资源
然后是route.php文件
<?php function callHook() { global $url; global $default; // Get the $controller $action $param $param = array(); $urlArr = explode("/", rtrim($url, "/")); $controller = array_shift($urlArr); $action = array_shift($urlArr); $param = $urlArr; if ($controller == "") { $controller = $default['controller']; $action = $default['action']; } if ($action == "") { $action = $default['action']; } // 控制类书写规则 HomeController->Index $controllerName = ucfirst($controller).'Controller'; $dispatch = new $controllerName($controller, $action); if (method_exists($dispatch, ucfirst($action))) { call_user_func_array(array($dispatch, ucfirst($action)), $param); } else { /* Error Code for Method is not exists */ die('method not exitsts.<br>'); } } // 自动加载类 function __autoload($classname) { if (file_exists(ROOT . DS . 'core' . DS . strtolower($classname) . '.class.php')) { require_once(ROOT . DS . 'core' . DS . strtolower($classname) . '.class.php'); } else if (file_exists(ROOT . DS . 'app' . DS . 'controller' . DS . strtolower($classname) . '.php')) { require_once(ROOT . DS . 'app' . DS . 'controller' . DS . strtolower($classname) . '.php'); } else if (file_exists(ROOT . DS . 'app' . DS . 'model' . DS . strtolower($classname) . '.php')) { require_once(ROOT . DS . 'app' . DS . 'model' . DS . strtolower($classname) . '.php'); } else { /* Error Code for can not find the files */ die('class not found.<br>'); } } callHook();
这个页面,首先定义了两个函数callHook和__autoload,然后页面底部有一句callHook();到此,程序就开始执行了。
callHook函数:
其作用就是定位上面所说的控制器,方法,参数
当代码执行这里时
// 控制类书写规则 HomeController->Index $controllerName = ucfirst($controller).'Controller'; $dispatch = new $controllerName($controller, $action);
程序就会执行__autoload方法,这个方法可以在你使用类的时候可以自动加载所需的文件
不需要手动require,这样可以方便的时候各种类库,方便省事,不需要每次调用类之前都手动加载.php类文件
method_exists方法判断这个类中是不是存在该方法,若存在,就call_user_func_array调用该方法
注:__autoload方法是一些加载类库文件的规则,这个要根据你的习惯来定义的。
至此,程序就跳到某某控制器的某某方法执行了。比如说HomeController类中的Index方法,该文件就在你的__autoload规则里定义着。
我这里的就是app/controller/homecontroller.php文件了
<?phpclass HomeController extends Controller{ public function Index() { $user = new user(); $tpl = new tpl(); $tpl->set('name', $user->name); $tpl->render('index.html'); }}
这个方法里加载了user类(Model)和tpl类(view)
user类负责从数据库读数据
tpl类负责把显示数据
所以也可以这样说,controller类起到了一个连接的作用,控制着数据和显示,使两者可以很好的绑定在一起,model和view就分开了
这样做就可以实现了当初的想法,把php代码和html布局分离开来
我期待我能够整合出一个属于自己的方便使用的php框架,希望大家来QQ群给点意见,QQ群号:667110936671109366711093

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

JWT是一種基於JSON的開放標準,用於在各方之間安全地傳輸信息,主要用於身份驗證和信息交換。 1.JWT由Header、Payload和Signature三部分組成。 2.JWT的工作原理包括生成JWT、驗證JWT和解析Payload三個步驟。 3.在PHP中使用JWT進行身份驗證時,可以生成和驗證JWT,並在高級用法中包含用戶角色和權限信息。 4.常見錯誤包括簽名驗證失敗、令牌過期和Payload過大,調試技巧包括使用調試工具和日誌記錄。 5.性能優化和最佳實踐包括使用合適的簽名算法、合理設置有效期、

會話劫持可以通過以下步驟實現:1.獲取會話ID,2.使用會話ID,3.保持會話活躍。在PHP中防範會話劫持的方法包括:1.使用session_regenerate_id()函數重新生成會話ID,2.通過數據庫存儲會話數據,3.確保所有會話數據通過HTTPS傳輸。

PHP8.1中的枚舉功能通過定義命名常量增強了代碼的清晰度和類型安全性。 1)枚舉可以是整數、字符串或對象,提高了代碼可讀性和類型安全性。 2)枚舉基於類,支持面向對象特性,如遍歷和反射。 3)枚舉可用於比較和賦值,確保類型安全。 4)枚舉支持添加方法,實現複雜邏輯。 5)嚴格類型檢查和錯誤處理可避免常見錯誤。 6)枚舉減少魔法值,提升可維護性,但需注意性能優化。

SOLID原則在PHP開發中的應用包括:1.單一職責原則(SRP):每個類只負責一個功能。 2.開閉原則(OCP):通過擴展而非修改實現變化。 3.里氏替換原則(LSP):子類可替換基類而不影響程序正確性。 4.接口隔離原則(ISP):使用細粒度接口避免依賴不使用的方法。 5.依賴倒置原則(DIP):高低層次模塊都依賴於抽象,通過依賴注入實現。

在PHPStorm中如何進行CLI模式的調試?在使用PHPStorm進行開發時,有時我們需要在命令行界面(CLI)模式下調試PHP�...

如何在系統重啟後自動設置unixsocket的權限每次系統重啟後,我們都需要執行以下命令來修改unixsocket的權限:sudo...

使用PHP的cURL庫發送JSON數據在PHP開發中,經常需要與外部API進行交互,其中一種常見的方式是使用cURL庫發送POST�...
