主頁 > 知識庫 > Laravel框架中composer自動加載的實現(xiàn)分析

Laravel框架中composer自動加載的實現(xiàn)分析

熱門標(biāo)簽:外呼系統(tǒng)人工客服 隨州銷售電銷機器人公司 福建高頻外呼防封系統(tǒng)哪家好 400電話申請辦理 全國各省地圖標(biāo)注點 百度地圖標(biāo)注類型是酒店 網(wǎng)絡(luò)電話400申請 周口網(wǎng)絡(luò)回撥外呼系統(tǒng) 商丘外呼系統(tǒng)好處

基礎(chǔ)

自動加載允許你通過即用即加載的方式來加載需要的類文件,而不用每次都寫繁瑣的require 和include語句。因此,每一次請求的執(zhí)行過程都只加載必須的類,也不不要關(guān)心類的加載問題,只要需要的時候直接使用即可。

laravel 框架是通過composer 實現(xiàn)的自動加載。

是通過  下面的代碼實現(xiàn)的。

require_once __DIR__ . '/composer' . '/autoload_real.php';
return ComposerAutoloaderInit7b20e4d61e2f88170fbbc44c70d38a1f::getLoader();

首先我們對spl_autoload_register和spl_autoload_unregister 這兩個函數(shù)進行解釋一下。

spl_autoload_register 自動注冊 一個或多個 自動加載函數(shù),這些函數(shù)一般在 實例化類的時候,自動運行。

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); 會觸發(fā)致命錯誤,必須帶上命名空間
  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();// 此時自動運行自動加載函數(shù)
echo 77;
exit;

找到getLoader 這個函數(shù),并對其進行分析:

 public static function getLoader()
 {
  if (null !== self::$loader) {
   return self::$loader;
  }
  //注冊自動加載函數(shù),在加載或?qū)嵗?,運行l(wèi)oadClassLoader函數(shù)
  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 等屬性進行賦值。即加載一些配置好的文件,在后面進行加載或?qū)ふ椅募r候,就是從加載的配置文件中尋找。尋找要加載的類主要通過register 函數(shù)來實現(xiàn)。然后分析register函數(shù)。

public function register($prepend = false)
{
 spl_autoload_register(array($this, 'loadClass'), true, $prepend);
}

發(fā)現(xiàn)實際將該類中l(wèi)oadClass 函數(shù)注冊為自動加載函數(shù)。于是開始分析loadClass函數(shù),最終是通過findFile進行類的尋找。

public function findFile($class)
{
/// 特別注意 參數(shù)$class 是根據(jù)命名空間生成的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 規(guī)則尋找,再按照psr0 尋找
// 兩種規(guī)則的不同主要是對下劃線的處理方式。
 $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函數(shù)分析完。我們接著分析getLoader函數(shù)剩余代碼。

$includeFiles = require __DIR__ . '/autoload_files.php';
foreach ($includeFiles as $fileIdentifier => $file) {
 composerRequire7b20e4d61e2f88170fbbc44c70d38a1f($fileIdentifier, $file);
}

這段代碼其實就是加載autoload_file.php 文件。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • PHP管理依賴(dependency)關(guān)系工具 Composer的自動加載(autoload)
  • Laravel 解決composer相關(guān)操作提示php相關(guān)異常的問題
  • laravel 實現(xiàn)向公共模板中傳值 (view composer)
  • 淺談laravel 5.6 安裝 windows上使用composer的安裝過程
  • 使用composer 安裝 laravel框架的方法圖文詳解
  • 一次因composer錯誤使用引發(fā)的問題與解決
  • tp5框架使用composer實現(xiàn)日志記錄功能示例
  • windows環(huán)境下使用Composer安裝ThinkPHP5
  • PHP創(chuàng)建自己的Composer包方法
  • 分析Composer實現(xiàn)自動加載原理

標(biāo)簽:迪慶 六安 海南 佛山 定西 南寧 十堰 樂山

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Laravel框架中composer自動加載的實現(xiàn)分析》,本文關(guān)鍵詞  Laravel,框架,中,composer,自動,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Laravel框架中composer自動加載的實現(xiàn)分析》相關(guān)的同類信息!
  • 本頁收集關(guān)于Laravel框架中composer自動加載的實現(xiàn)分析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章