为大家介绍php函数 spl_autoload_register
(PHP 5 >= 5.1.2)
spl_autoload_register — 注册__autoload()函数
说明
bool spl_autoload_register ([ callback $autoload_function ] )
将函数注册到SPL __autoload函数栈中。如果该栈中的函数尚未激活,则激活它们。
如果在你的程序中已经实现了__autoload函数,它必须显式注册到__autoload栈中。
因为spl_autoload_register()函数会将Zend Engine中的__autoload函数取代为spl_autoload()或
spl_autoload_call()。
参数
autoload_function
欲注册的自动装载函数。如果没有提供任何参数,则自动注册autoload的默认实现函数
spl_autoload()。
返回值
如果成功则返回 TRUE,失败则返回 FALSE。
注:SPL是Standard PHP Library(标准PHP库)的缩写。它是PHP5引入的一个扩展库,其主要功能包括autoload机制的实现及包括各种Iterator接口或类。
SPL autoload机制的实现是通过将函数指针autoload_func指向自己实现的具有自动装载功能的函数来实现的。SPL有两个不同的函数 spl_autoload, spl_autoload_call,通过将autoload_func指向这两个不同的函数地址来实现不同的自动加载机制。
例子,一个类文件A.php,里面定义了一个名字为A的类:
class A{
public function __construct(){
echo 'Got it.';
}
}
然后,有一个index.php需要用到这个类A,常规写法:
<?php
require('A.php');
$a = new A();
问题所在:
假如index.php需要包含的不只是类A,而是需要很多类,则必须写很多行require语句。
在php5中,试图使用尚未定义的类时会自动调用__autoload函数,所以可以通过编写__autoload函数来让php自动加载类。
以上的例子,可以修改为:
<?php
function __autoload($class) {
$file = $class . '.php';
if (is_file($file)) {
require_once($file);
}
}
$a = new A();
__autoload只是去include_path寻找类文件并加载,我们可以根据自己的需要定义__autoload加载类的规则。
此外,假如不想自动加载的时候调用__autoload,而是调用自己的函数(或者类方法),可以使用spl_autoload_register来注册自己的autoload函数。
函数原型如下:
bool spl_autoload_register ( [callback $autoload_function] )
继续修改以上的例子:
<?php
function loader($class) {
$file = $class . '.php';
if (is_file($file)) {
require_once($file);
}
}
spl_autoload_register('loader');
$a = new A();
php在寻找类时就没有调用__autoload而是调用自己定义的函数loader了。
以下写法也是可以的,例如:
<?php
class Loader {
public static function loadClass($class) {
$file = $class . '.php';
if (is_file($file)) {
require_once($file);
}
}
}
spl_autoload_register(array('Loader', 'loadClass'));
$a = new A();
以下代码是php中session操作的例子。
注意:session_start语句必须放在代码的第一行。
例子:
1,session1.php
<?php
session_start();
?>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"
"http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta http-equiv="content-type" content="text/html;charset=ISO-8859-1">
<title>session示例-www.</title>
</head>
<body>
<h1>php session</h1>
<hr>
<h3>PHPSESSID = <?php echo session_id(); ?></h3>
<hr>
<h2>点击下一页,即可看到访问者的session值。</h2>
<a href="/blog_article/session2/lt;php echo( SID ); /gt;.html">下一页</a>
</body>
</html>
2,session2.php
<?php
session_start();
($_SESSION['count']) ? $_SESSION['count']++ : $_SESSION['count'] = 1;
?>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"
"http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta http-equiv="content-type" content="text/html;charset=ISO-8859-1">
<title>session的例子</title>
</head>
<body>
<h1>php session 第二页</h1>
<hr>
<h3>PHPSESSID = <?php echo session_id(); ?></h3>
<hr>
<h2>您已经使用此session值登录:<?php echo( $_SESSION['count'] ); ?> 次。</h2>
<a href="/blog_article/session1/lt;php echo( SID ); /gt;.html">上一页</a>
</body>
</html>
</html>学习php中self与$this的区别。
先来看下parent与self的例子:
<?php
/*
* parent与self的区别
* by www.
*/
class A{
function __construct(){
echo "基类A的构造方法<br />";
}
}
class B extends A{
function __construct(){
parent::__construct();
echo "子类B的构造方法<br />";
self::myFun();
}
function myfun(){
echo "一个普通方法myFun()<br />";
}
}
$obj=new A();
$obj=new B();
?>
说明:
self与$this的功能极其相似,但二者又不相同。
注意:
$this不能引用静态成员和常量。
self更像类本身,而$this更像是实例本身。
变量$PHP_SELF是php的内置变量,是PHP中一个很方便的指针,其变量值就是当前页面的URL地址。
【语法】$php_self?变量1=值&变量2=值&变量3=值
使用$PHP_SELF变量而不使用页面的实际地址,是因为通过使用$PHP_SELF变量,可以方便对编写的页面代码进行修改和移动,而不必担心在每次改动之后重新输入新的页面地址。
另外,在使用$PHP_SELF变量时,可以采用如下方式:
global $PHP_SELF;
$PHP_SELF变量为全局变量。
注意:
PHP中任何的函数变量都是局部变量。
这就意味着任何函数变量的作用 域都只局限于包括该变量的函数本身。
即使函数外存在同名变量,变量的值也不相同。
因此,如果没有在代码中以显式方式声明函数变量$PHP_SELF为全局变量具有全局唯一值的话,用户就会发现函数中的变量$PHP_SELF的值将会为空,而非预先所期望的当前页面的URL地址。