php自动加载
Ⅰ php,thinkphp自动加载怎么实现的呢
php 中有个魔术方法__autoload ,这个函数在找不到类的时候就会调用,自动加载就是在这里实现的。通过指定自动加载类的路径,只要保证文件名和类名一样。就可以自动加载。这也是为什么你看很多源码中类的名字和文件名一样的原因,这样可以实现自动加载,不需要include.
Ⅱ PHP怎么自动加载同一目录下同一命名空间的类文件
自动加载的,只有在实例化时才会真的载入。实例化时,调用公共空间的方式是直接在元素名称前加
\
就可以了,否则PHP解析器会认为我想调用当前空间下的元素。
Ⅲ php类自动加载器实现方法
本文实例讲述了php类自动加载器实现方法。分享给大家供大家参考。具体如下:
这里autoload
可兼容以下格式:
Cache_File_Json
class_xxx.php
xxx.class.php
xxx.php
php代码如下:
function
__autoload($className){
$dirs=explode('_',$className);
$fileName=array_pop($dirs);
//print_r($dirs);
$filePath=$fileName;
if(is_array($dirs)
&&
(count($dirs)
>
0)){
//echo
'\n---\n';
print_r($dirs);
$dirPath='';
foreach
($dirs
as
$dir){
if($dir){
$dirPath.=strtolower($dir).DIRECTORY_SEPARATOR;
}
}
$filePath=$dirPath.$fileName.'.php';
}else
{
if(
file_exists('class_'.$fileName.'.php')){
$filePath='class_'.$fileName.'.php';
}else
{
if(
file_exists($fileName.'.class.php')){
$filePath=$fileName.'.class.php';
}
else
{
$filePath=$fileName.'.php';
}
}
}
//var_mp($filePath);
require
$filePath;
}
希望本文所述对大家的php程序设计有所帮助。
Ⅳ thinkphp5 自动加载的类 怎么使用
ThinkPHP的类库主要包括公共类库和应用类库,都是基于命名空间进行定义和扩展的。只要按照规范定义,都可以实现自动加载。
类库存放位置:
Think目录:系统核心类库
Org目录:第三方公共类库
这些目录下面的类库都可以自动加载,只要把相应的类库放入目录中,然后添加或者修改命名空间定义。你可以在Org/Util/目录下面添加一个Image.class.php
文件,然后添加命名空间如下:
namespace Org\Util;
class Image {
}
这样,就可以用下面的方式直接实例化Image类了:$image = new \Org\Util\Image;
公共类库除了在系统的Library目录之外,还可以自定义其他的命名空间,只需要注册一个新的命名空间,在应用或者模块配置文件中添加下面的设置参数:
'AUTOLOAD_NAMESPACE' => array(
'Lib' => APP_PATH.'Lib',
)
如果类库没有采用命名空间的话,需要使用import方法先加载类库文件,然后再进行实例化,例如:定义了一个Counter类(位于Com/Sina/Util/Counter.class.php):
import('Com.Sina.Util.Couter');
$object = new \Counter();
Ⅳ PHP中如何用autoload($class) 实现Lib目录下的类的自动加载并可以兼容子目录
php自动载方法有两种.
第一种方案用__autoload,这个函数较简单,也较弱.
但有一问题没有解决, 就是在include前判断文件是否存在的问题.
set_include_path('aa'.PATH_SEPARATOR.get_include_path());
function__autoload($className)
{
//如果加这个检测,因为此文件不在当前目录下,它就会检测不到文件存在,
//但include是能成功的
if(file_exists($className.'.php')){
include_once($className.'.php');
}else{
exit('nofile');
}
}
$a=newAcls();
第二种方案用spl自动加载,这里具体说一下这个.
spl_autoload_register()
一个简单的例子
set_include_path('aa'.PATH_SEPARATOR.get_include_path());
//function__autoload($className)
//{
//if(file_exists($className.'.php')){
//include_once($className.'.php');
//}else{
//exit('nofile');
//}
//}
spl_autoload_register();
$a=newAcls();
Ⅵ php 命名空间是怎么自动加载的
实现自动加载最简单的方式就是使用 __autoload 魔术方法。当需要使用的类没有被引入时,这个函数会在PHP报错前被触发,未定义的类名会被当作参数传入。至于函数具体的逻辑,这需要用户自己去实现。
Ⅶ 详解PHP文件的自动加载(autoloading)
传统上,在PHP里,当我们要用到一个class文件的时候,我们都得在文档头部require或者include一下:
<?php
require_once('../includes/functions.php');
require_once('../includes/database.php');
require_once('../includes/user.php');
...
但是一旦要调用的文档多了,就得每次都写一行,瞅着也不美观,有什么办法能让PHP文档自动加载呢?
<?php
function
__autoload($class_name)
{
require
"./{$class_name}.php";
}
对,可以使用PHP的魔法函数__autoload(),上面的示例就是自动加载当前目录下的PHP文件。当然,实际当中,我们更可能会这么来使用:
<?php
function
__autoload($class_name)
{
$name
=
strtolower($class_name);
$path
=
"../includes/{$name}.php";
if(file_exists($path)){
require_once($path);
}else{
die("the
file
{$class_name}
could
not
be
found");
}
}
也即是做了一定的文件名大小写处理,然后在require之前检查文件是否存在,不存在的话显示自定义的信息。
类似用法经常在私人项目,或者说是单一项目的框架中见到,为什么呢?因为你只能定义一个__autoload
function,在多人开发中,做不到不同的developer使用不同的自定义的autoloader,除非大家都提前说好了,都使用一个__autoload,涉及到改动了就进行版本同步,这很麻烦。
也主要是因为此,有个好消息,就是这个__autoload函数马上要在7.2版本的PHP中弃用了。
Warning
This
feature
has
been
DEPRECATED
as
of
PHP
7.2.0.
Relying
on
this
feature
is
highly
discouraged.
那么取而代之的是一个叫spl_autoload_register()的东东,它的好处是可以自定义多个autoloader.
//使用匿名函数来autoload
spl_autoload_register(function($class_name){
require_once('...');
});
//使用一个全局函数
function
Custom()
{
require_once('...');
}
spl_autoload_register('Custom');
//使用一个class当中的static方法
class
MyCustomAutoloader
{
static
public
function
myLoader($class_name)
{
require_once('...');
}
}
//传array进来,第一个是class名,第二个是方法名
spl_autoload_register(['MyCustomAutoloader','myLoader']);
//甚至也可以用在实例化的object上
class
MyCustomAutoloader
{
public
function
myLoader($class_name)
{
}
}
$object
=
new
MyCustomAutoloader;
spl_autoload_register([$object,'myLoader']);
值得一提的是,使用autoload,无论是__autoload(),还是spl_autoload_register(),相比于require或include,好处就是autoload机制是lazy
loading,也即是并不是你一运行就给你调用所有的那些文件,而是只有你用到了哪个,比如说new了哪个文件以后,才会通过autoload机制去加载相应文件。
当然,laravel包括各个package里也是经常用到spl_autoload_register,比如这里:
/**
*
Prepend
the
load
method
to
the
auto-loader
stack.
*
*
@return
void
*/
protected
function
prependToLoaderStack()
{
spl_autoload_register([$this,
'load'],
true,
true);
}
Ⅷ 在PHP 7.2以后版本中可以通过什么函数实现自动加载函数
对单个文件的载入:使用require语句
调用类时自动执行的自动加载注册函数:spl_autoload_register
php7对命名空间的支持,在文件路径组合时仅需要使用根路径和命名空间
Ⅸ PHP spl_autoload_register实现自动加载研究
这里通过一个实验谈谈这个函数的部分特征。
函数原型
bool
spl_autoload_register
([
callback
$autoload_function
[,
bool
$throw
=
true
[,
bool
$prepend
=
false
]]]
)
版本兼容
PHP
5
>=
5.1.2
实验过程
第一步,使用spl_autoload_register()函数注册load()方法
复制代码
代码如下:
<?php
function
load(){
require_once
'lib.php';
}
spl_autoload_register('load');
?>
其中lib.php文件代码如下
复制代码
代码如下:
<?php
class
className{
function
method(){
echo
'a
method
in
class';
}
}
function
onlyMethod(){
echo
'method
only';
}
?>
说明:lib.php文件为一个className类和一个onlyMethod函数
第二步,调用自动加载类
复制代码
代码如下:
$class
=
new
className();
$class->method();
onlyMethod();
输出:
a
method
in
class
method
only
说明:实例化className类,并调用类method()函数,同时调用onlyMethod()方法,输出正常,没有出现错误
第三步,直接调用函数
onlyMethod();
说明:没有实例化类,直接调用lib.php文件中的onlyMethod()函数
输出:
Fatal
error:
Call
to
undefined
function
onlyMethod()
in
'...(省略路径)'
第四步,实例化className类,再直接调用
$class
=
new
className();
onlyMethod();
输出:method
only
从上面的四步实验发现,如果加载的文件包含函数,使用则一定需要实例化里面的类,否则就产生异常情况
Call
to
undefined
function错误,具体在使用中要注意一下。
参与资料:spl_autoload_register
Ⅹ php自动加载实现加载不同文件夹相同类名问题
不知道你说的命名空间是不是use之后直接加载的。
命名空间在你这个问题上是最简单,最直接的解决方案。
你已经实现这个了,改下就可以了
functionautoload($dir,$file){
include_once$dir.'/'.$file.'.class.php';
}
functionload_file($dir,$file){
spl_autoload_register('autoload');
}