您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關Laravel框架中如何實現composer自動加載,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
基礎
自動加載允許你通過即用即加載的方式來加載需要的類文件,而不用每次都寫繁瑣的require 和include語句。因此,每一次請求的執行過程都只加載必須的類,也不不要關心類的加載問題,只要需要的時候直接使用即可。
laravel 框架是通過composer 實現的自動加載。
是通過 下面的代碼實現的。
require_once __DIR__ . '/composer' . '/autoload_real.php'; return ComposerAutoloaderInit7b20e4d61e2f88170fbbc44c70d38a1f::getLoader();
首先我們對spl_autoload_register和spl_autoload_unregister 這兩個函數進行解釋一下。
spl_autoload_register 自動注冊 一個或多個 自動加載函數,這些函數一般在 實例化類的時候,自動運行。
spl_autoload_unregister 恰恰相反。
貼上我實驗的代碼:
這是autoload.php
<?php /** * Created by PhpStorm. * User: Administrator * Date: 2017/12/7 * Time: 14:10 */ namespace app; class Autoload { public function __construct() { $this->autoload(); } public function autoload(){ // spl_autoload_register(array('Autoload','ss'),true); 會觸發致命錯誤,必須帶上命名空間 spl_autoload_register(array('app\Autoload','ss'),true); } public function ss(){ echo 666; exit; } }
這是index.php
<?php /** * Created by PhpStorm. * User: Administrator * Date: 2017/12/7 * Time: 14:10 */ require 'autoload.php'; $autoload=new \app\Autoload(); $b=new B();// 此時自動運行自動加載函數 echo 77; exit;
找到getLoader 這個函數,并對其進行分析:
public static function getLoader() { if (null !== self::$loader) { return self::$loader; } //注冊自動加載函數,在加載或實例化類,運行loadClassLoader函數 spl_autoload_register(array('ComposerAutoloaderInit7b20e4d61e2f88170fbbc44c70d38a1f', 'loadClassLoader'), true, true); self::$loader = $loader = new \Composer\Autoload\ClassLoader(); spl_autoload_unregister(array('ComposerAutoloaderInit7b20e4d61e2f88170fbbc44c70d38a1f', 'loadClassLoader')); /********************1******************************************************** $map = require __DIR__ . '/autoload_namespaces.php'; foreach ($map as $namespace => $path) { $loader->set($namespace, $path); } $map = require __DIR__ . '/autoload_psr4.php'; foreach ($map as $namespace => $path) { $loader->setPsr4($namespace, $path); } $classMap = require __DIR__ . '/autoload_classmap.php'; if ($classMap) { $loader->addClassMap($classMap); } /********************1******************************************************** $loader->register(true); $includeFiles = require __DIR__ . '/autoload_files.php'; foreach ($includeFiles as $fileIdentifier => $file) { composerRequire7b20e4d61e2f88170fbbc44c70d38a1f($fileIdentifier, $file); } return $loader; }}
/***** 包圍的部分,主要對ClassLoader 中的
$prefixesPsr0 、$prefixDirsPsr4 、$classMap 等屬性進行賦值。即加載一些配置好的文件,在后面進行加載或尋找文件時候,就是從加載的配置文件中尋找。尋找要加載的類主要通過register 函數來實現。然后分析register函數。
public function register($prepend = false) { spl_autoload_register(array($this, 'loadClass'), true, $prepend); }
發現實際將該類中loadClass 函數注冊為自動加載函數。于是開始分析loadClass函數,最終是通過findFile進行類的尋找。
public function findFile($class) { /// 特別注意 參數$class 是根據命名空間生成的class名稱,具體請參考命名空間特性。 // work around for PHP 5.3.0 - 5.3.2 https://bugs.php.net/50731 if ('\\' == $class[0]) { $class = substr($class, 1); } // class map lookup 首先從加載的classMap 中尋找 if (isset($this->classMap[$class])) { return $this->classMap[$class]; } if ($this->classMapAuthoritative) { return false; } // 從剛才加載的配置文件中尋找文件。先按照 psr4 規則尋找,再按照psr0 尋找 // 兩種規則的不同主要是對下劃線的處理方式。 $file = $this->findFileWithExtension($class, '.php'); // Search for Hack files if we are running on HHVM if ($file === null && defined('HHVM_VERSION')) { $file = $this->findFileWithExtension($class, '.hh'); } if ($file === null) { // Remember that this class does not exist. return $this->classMap[$class] = false; } return $file; }
至此register函數分析完。我們接著分析getLoader函數剩余代碼。
$includeFiles = require __DIR__ . '/autoload_files.php'; foreach ($includeFiles as $fileIdentifier => $file) { composerRequire7b20e4d61e2f88170fbbc44c70d38a1f($fileIdentifier, $file); }
這段代碼其實就是加載autoload_file.php 文件。
關于“Laravel框架中如何實現composer自動加載”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。