http://avnpc.com/pages/autoloader-third ... thout-psr0
Zend Framework 2.0的自动加载机制主要基于PSR-0标准,引入新的第三方库只需要注册新的命名空间即可。
比如加载ZendOAuth模块,下载后放于vendor/ZendOAuth,然后在依赖的模块Module.php中加入一行即可:
public function getAutoloaderConfig()
{
return array(
'Zend\Loader\StandardAutoloader' => array(
'namespaces' => array(
'ZendOAuth' => __DIR__ . '/../../vendor/ZendOAuth/library/ZendOAuth',
__NAMESPACE__ => __DIR__ . '/src/' . __NAMESPACE__,
),
),
);
}
ZF2加载非PSR-0标准库
不过由于第三方库质量参差不齐,并不一定所有的库都遵循PSR-0标准,ZF2也提供了非PSR-0标准库的自动加载方式,可以在Zend\Loader中新增ClassMapAutoloader,以键值对的形式引入需要加载的第三方库文件。下面以一个正好碰到的实例说明:
GeoIP地理位置查询+ZF2实例
项目中正好有一个简单的需求,要根据用户IP显示用户所在地,IP来源可能是全球范围,所以需要找一个IP与地理位置对应的数据库:GeoIP
GeoIP数据库由MaxMind公司负责维护,免费版可以获得精确到城市一级的IP与地理位置对应数据,对于一般的应用来说已经够用了。
首先需要下载GeoIP数据库,选择Binary GeoLite City版,同时还需要下载PHP GeoIP数据库接口,为了更好的兼容性选择了纯php版本的GeoIP接口
最后项目中这样放置:
project/
--data/
----GeoLiteCity.dat
--module/
----MyModule/
------Module.php
------vendor/
--------GeoIP/
----------geoip.inc
----------geoipcity.inc
----------geoipregionvars.php
在模块Module.php中首先引入ClassMapAutoloader,并在同目录下放置一个autoload_classmap.php文件
public function getAutoloaderConfig()
{
return array(
'Zend\Loader\ClassMapAutoloader' => array(
__DIR__ . '/autoload_classmap.php',
),
'Zend\Loader\StandardAutoloader' => array(
'namespaces' => array(
__NAMESPACE__ => __DIR__ . '/src/' . __NAMESPACE__,
),
),
);
}
在autoload_classmap.php文件中需要制定第三方库文件的位置
<?php
return array(
'GeoIP' => __DIR__ . '/vendor/GeoIP/geoipcity.inc',
);
最后在模块Controller中就可以通过自动加载机制直接使用:
public function geoAction()
{
$city = 'unkown';
$geoData = __DIR__ . '/../../../../../data/databases/GeoLiteCity.dat';
new \GeoIP();
$ip = $_SERVER['REMOTE_ADDR'];
$gi = geoip_open($geoData, GEOIP_STANDARD);
$record = geoip_record_by_addr($gi, $ip);
if(isset($record->city)){
$city = $record->city;
}
geoip_close($gi);
return array(
'city' => $city
);
}
ZF2自动加载下划线分割的PSR-0类库
以下划线作为类名分隔符也很常见,这一种类库的加载在ZF2中仍然使用StandardAutoloader,不过需要指定的不是Namespaces而是Prefixes,比如加载PHP-Resque这个项目,在Module.php中加入:
public function getAutoloaderConfig()
{
return array(
'Zend\Loader\ClassMapAutoloader' => array(
__DIR__ . '/autoload_classmap.php',
),
'Zend\Loader\StandardAutoloader' => array(
'prefixes' => array(
'Resque' => __DIR__ . '/../../vendor/Resque/lib/Resque',
),
),
);
}
同时在autoload_classmap中加入
return array(
'Resque' => __DIR__ . '/../../vendor/Resque/lib/Resque.php',
);
即可。
ZF2自动加载非PSR-0标准库及实例
前往
- Software
- ↳ CodeCharge Studio
- ↳ CodeCharge
- ↳ DemoCharge
- ↳ SuperPDF
- ↳ 551einv
- ↳ E3進銷存
- 程式語言
- ↳ PHP
- ↳ CodeLobster PHP Edition
- ↳ Yii
- ↳ CodeIgniter
- ↳ Phalcon
- ↳ Symfony
- ↳ FuelPHP
- ↳ Zend Framework 2
- ↳ laravel
- ↳ WordPress
- ↳ ASP.NET/C#
- ↳ ASP/VBScript
- ↳ JSP
- ↳ Java Servlets
- ↳ ColdFusion
- ↳ Perl
- ↳ Java Script
- ↳ jQuery
- ↳ HTML + CSS
- ↳ jQuery
- ↳ nodejs
- ↳ VB6
- ↳ Git
- ↳ App Inventor 2
- ↳ bash
- ↳ C++/ VC/ OpenCV
- ↳ OpenCV
- ↳ go
- ↳ cordova
- ↳ python
- ↳ Xamarin
- ↳ Assembly
- 資料庫
- ↳ MySQL
- ↳ PostgreSQL
- ↳ ORACLE
- ↳ Access
- ↳ SQL Server
- ↳ SQLite
- ↳ MariaDB
- ↳ Mongodb
- 作業系統
- ↳ Linux
- ↳ Ubuntu
- ↳ CentOS
- ↳ Mint
- ↳ Mandriva
- ↳ Debian
- ↳ Red Hat Enterprise Linux
- ↳ Oracle Linux
- ↳ Fedora
- ↳ Kali Linux
- ↳ OpenSUSE
- ↳ Elementary OS
- ↳ Microsoft
- ↳ Server 2008 R2
- ↳ Server 2012 R2
- ↳ Server 2012
- ↳ 8
- ↳ 10
- ↳ System Center 2016
- ↳ NOVELL
- ↳ FreeBSD
- ↳ VMware
- ↳ VirtualBox
- ↳ Mac OS X
- ↳ Solaris
- ↳ iOS
- ↳ Android
- ↳ Cloud
- ↳ OpenStack
- ↳ Docker
- ↳ Proxmox VE
- ↳ CloudReady
- ↳ chrome
- 網頁伺服器
- ↳ apache
- ↳ tomcat
- ↳ nginx
- ↳ IIS
- ↳ JBoss
- ↳ weblogic
- ↳ WebHosting
- 硬體
- ↳ 硬體及週邊
- ↳ RouterOS
- ↳ LEGO NXT
- ↳ Arduino
- ↳ MSP430
- ↳ Raspberry Pi
- ↳ OpenERP
- ↳ Storage
- ↳ Server
- ↳ Brocade
- ↳ MODELS
- ↳ FortiGate
- 軟體
- ↳ sublime
- ↳ LibreNMS