当前位置: 首页 > news >正文

顺德网站建设原创百度网站的优化方案

顺德网站建设原创,百度网站的优化方案,企业推广方式隐迅推知名,四川省住房城乡建设厅官网查询转载地址:http://www.toolmao.com/composer-autoload composer的出现真是让人们眼前一亮,web开发从此变成了一件很『好玩』的事情,开发一个CMS就像在搭积木,从packagist中取出『积木』搭建在自己的代码中,一点一点搭建…

转载地址:http://www.toolmao.com/composer-autoload


composer的出现真是让人们眼前一亮,web开发从此变成了一件很『好玩』的事情,开发一个CMS就像在搭积木,从packagist中取出『积木』搭建在自己的代码中,一点一点搭建出一个属于自己的王国。
从此以后我基本就抛弃了require和include函数,一个项目中,这两个函数只可能出现一次,那就是require '../vendor/autoload.php'
那么,既然抛弃了传统的文件包含方法,我们使用所有类库都将用namespace和composer自带的autoload。可是,我们自己编写的函数库与类库,怎么用composer的方法来自动加载呢?

这就要从composer.json说起,我们需要通过修改这个文件来达到目的。
composer.json相当于是composer的配置文件,这个配置文件中有一个autoload段,比如我的一个项目:

autoload

其中又包含主要的两个选项: files 和 psr-4。
files就是需要composer自动帮我们加载的函数库(不含类),只要在后面的数组中将函数库的文件路径写入即可。
psr-4顾名思义,是一个基于psr-4(http://www.php-fig.org/psr/psr-4/)规则的类库自动加载对应关系,只要在其后的对象中,以 "命名空间": "路径" 的方式写入自己的类库信息即可。
修改完成后,只要执行一下composer update,即可完成对应工作。

之后,我们在项目中,用如下方式即可加载自定义类库:

new \Core\View();

composer的autoload将会自动包含”./core/view.php”,并找到其中的Core命名空间下的View类。

我们来深挖一下,探索一下autoload的原理。
在我们修改完composer.json并执行update后,将会修改./vender/composer/autoload_psr4.php,比如我的某个项目,其中增加了这样一个对应关系:

autoload

这其实就是我刚刚在.json中添加的对应关系,他等于将.josn的配置文件,换成了php的形式。
那么我看到vendor/autoload.php:

<?php// autoload.php @generated by Composerrequire_once __DIR__ . '/composer' . '/autoload_real.php';return ComposerAutoloaderInitff1d77c91141523097b07ee2acc23326::getLoader();

其执行了一个自动生成的类ComposerAutoloaderInitff1d77c91141523097b07ee2acc23326中的getLoader方法。
跟进:

    public static function getLoader(){if (null !== self::$loader) {return self::$loader;}spl_autoload_register(array('ComposerAutoloaderInitff1d77c91141523097b07ee2acc23326', 'loadClassLoader'), true, true);self::$loader = $loader = new \Composer\Autoload\ClassLoader();spl_autoload_unregister(array('ComposerAutoloaderInitff1d77c91141523097b07ee2acc23326', 'loadClassLoader'));$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);}$loader->register(true);$includeFiles = require __DIR__ . '/autoload_files.php';foreach ($includeFiles as $file) {composerRequireff1d77c91141523097b07ee2acc23326($file);}return $loader;}

可以明显看到,他将autoload_namespaces.php、autoload_psr4.php、autoload_classmap.php、autoload_files.php等几个配置文件包含了进来,并进行了相关处理(setPsr4),最后注册(register)。
那么我们跟进register方法:

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

这函数就一行,但简单明了,直接调用php自带的spl_autoload_register函数,注册处理__autoload的方法,也就是loadClass方法。再跟进loadClass方法:

    public function loadClass($class){if ($file = $this->findFile($class)) {includeFile($file);return true;}}

从函数名字就可以大概知道流程:如果存在$class对应的这个$file,则include进来。
那么进findFile方法里看看吧:

    public function findFile($class){// work around for PHP 5.3.0 - 5.3.2 https://bugs.php.net/50731if ('\\' == $class[0]) {$class = substr($class, 1);}// class map lookupif (isset($this->classMap[$class])) {return $this->classMap[$class];}if ($this->classMapAuthoritative) {return false;}$file = $this->findFileWithExtension($class, '.php');// Search for Hack files if we are running on HHVMif ($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;}

通过类名找文件,最终锁定在findFileWithExtension方法中。
不过发现了一个小宝藏:在php5.3.0~5.3.2版本下,类名的第一个字符是\的小bug,也许以后挖漏洞会用上。
还是跟进findFileWithExtension方法:

    private function findFileWithExtension($class, $ext){// PSR-4 lookup$logicalPathPsr4 = strtr($class, '\\', DIRECTORY_SEPARATOR) . $ext;$first = $class[0];if (isset($this->prefixLengthsPsr4[$first])) {foreach ($this->prefixLengthsPsr4[$first] as $prefix => $length) {if (0 === strpos($class, $prefix)) {foreach ($this->prefixDirsPsr4[$prefix] as $dir) {if (file_exists($file = $dir . DIRECTORY_SEPARATOR . substr($logicalPathPsr4, $length))) {return $file;}}}}}// PSR-4 fallback dirsforeach ($this->fallbackDirsPsr4 as $dir) {if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr4)) {return $file;}}// PSR-0 lookupif (false !== $pos = strrpos($class, '\\')) {// namespaced class name$logicalPathPsr0 = substr($logicalPathPsr4, 0, $pos + 1). strtr(substr($logicalPathPsr4, $pos + 1), '_', DIRECTORY_SEPARATOR);} else {// PEAR-like class name$logicalPathPsr0 = strtr($class, '_', DIRECTORY_SEPARATOR) . $ext;}if (isset($this->prefixesPsr0[$first])) {foreach ($this->prefixesPsr0[$first] as $prefix => $dirs) {if (0 === strpos($class, $prefix)) {foreach ($dirs as $dir) {if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr0)) {return $file;}}}}}// PSR-0 fallback dirsforeach ($this->fallbackDirsPsr0 as $dir) {if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr0)) {return $file;}}// PSR-0 include paths.if ($this->useIncludePath && $file = stream_resolve_include_path($logicalPathPsr0)) {return $file;}}

最终实现将命名空间\类这样的类名,给转换成目录名/类名.php这样的路径,并返回完整路径。
我发现composer的autoload与php自带的spl_autoload,在包含文件时有一点小区别。那就是,spl_autoload会查找.inc类型的文件名,但composer不会。
另外也可以发现,虽然配置文件的名字是autoload_psr4.php,但实际上psr0格式的自动加载也是支持的。二者最大的不同就是psr0中用”_”来代替目录间的”\


http://www.15wanjia.com/news/51502.html

相关文章:

  • 武夷山网站制作seo顾问培训
  • ppt做杂志模板下载网站seo搜索引擎优化教程
  • 有什么平面设计的网站百度视频排名优化
  • 网站 运营 外包 每个月多少钱手机优化什么意思
  • 有什么网站可以做浏览单公司做网站怎么做
  • 怎么把网站建设推广出去长春网站建设公司
  • 鞍山信息港二手房出租seo文章是什么意思
  • 律师行业网站模板如何制作个人网站
  • 宜春代做网站河南郑州做网站的公司
  • 做市场浏览什么网站关键词查询网站的工具
  • 六盘水网络推广seo排名推广工具
  • 北京网站域名备案百度竞价渠道户
  • qq空间如何做微网站杭州百度人工优化
  • 房地产企业网站模板免费下载seo优化在线
  • 自己怎么做系统网站网址注册查询
  • 网站制作要花多少钱app推广项目从哪接一手
  • 高端企业网站建设蓦然郑州网站建设班级优化大师手机版下载
  • 网站代码免费下载seo策划
  • 怎样在网上建网站做电商生意友情链接怎么弄
  • 老牛影视传媒有限公司夫唯seo视频教程
  • 视频 收费 网站怎么做关键词制作软件
  • 网站开发需要哪些能力做一个私人网站需要多少钱
  • 深圳网络营销网站建设北京seo收费
  • 免费html网页模板网站app营销模式有哪些
  • 上海网站建设自学哈尔滨seo优化培训
  • 数码产品网站开发背景seo排名系统源码
  • wordpress翻译教程seo百度贴吧
  • 战地之王网站做任务重庆网络推广外包
  • 怎么建立一个网站?seo关键词有哪些类型
  • 网站和域名有关系吗文件关键词搜索工具