网站建设资讯

NEWS

网站建设资讯

php自动加载数据库配置 php自动载入自定义函数文件

详解PHP文件的自动加载(autoloading)

传统上,在PHP里,当我们要用到一个class文件的时候,我们都得在文档头部require或者include一下:

十年的科尔沁左翼网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。成都营销网站建设的优势是能够根据用户设备显示端的尺寸不同,自动调整科尔沁左翼建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。成都创新互联从事“科尔沁左翼网站设计”,“科尔沁左翼网站推广”以来,每个客户项目都认真落实执行。

?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);

}

如何修改文件config.php或者加载自定义的配置文件

按这样修改就可以了:

public目录下的自定义配置文件siteconfig.inc.php,用如下代码:

?php

$siteconfig = require '__PUBLIC__/siteconfig.inc.php';

$config = array(

//'配置项'='配置值'

// 添加数据库配置信息

'USERNAME' = 'admin',

'DB_TYPE' = 'mysql', // 数据库类型

'DB_HOST' = '127.0.0.1', // 服务器地址

'DB_NAME' = 'detectinfo', // 数据库名

//'DB_USER' = 'root', // 用户名

//'DB_PWD' = '', // 密码

'DB_PORT' = '', // 端口

'DB_PREFIX' = '', // 数据库表前缀

);

return array_merge($config,$siteconfig);

?

复制代码

但是require函数会报错

ERROR:require(): Failed opening required '__PUBLIC__/siteconfig.inc.php' (include_path='.;C:\php\pear;C:\wamp\www\ThinkPHP/Extend/Vendor/') in C:\wamp\www\PluginDetect\Conf\config.php on line 2

怎么用phpadmin导入数据库

1.打开任意浏览器,在地址栏中输入:“localhost/phpmyadmin”并点击“Enter”回车键进入下一步。(如果页面打不开,检查一下电脑的Apache服务器和MySQL数据库是否已经开启)

2.在PhpMyAdmin管理界面中,找到“数据库”字样按钮并点击进入下一步

3.在界面的“新建数据库”下方的方框中输入自己需要创建的数据库名称,数据库的编码选择“utf8_general_ci”这一栏,并点击页面后方的“创建”按钮完成新数据库的建立。

4.在PhpMyAdmin界面左边栏的数据库列表中,找到自己刚才创建的数据库名称,点击进入界面,在右方的顶部菜单栏中找到“导入”按钮并点击,然后找到页面中的“选择”按钮点击进入下一步。

5.此时已经进入数据库文件的选择窗口,找到自己将要导入的数据库文件,然后点击窗口右下方的“打开”按钮进入下一步。

6.此时数据库会自动加载进入PhpMyAdmin中,找到页面中的“执行”按钮点击完成数据库的导入操作。

遇到导入过大文件时,首先检查php.ini 配置文件中的以下三个地方,upload_max_filesize, memory_limit 和post_max_size,并且推荐修改的值要稍大于导入的巨大sql数据库文件;依照这个提示,我修改了以上三个在php.ini中的值以后,重启 了php环境,再次导入时,虽然phpMyAdmin还是显示导入最大限制:20,480 KB,但巨大的80M数据库文件已经被成功的导入了。

php,thinkphp自动加载怎么实现的呢?

php 中有个魔术方法__autoload ,这个函数在找不到类的时候就会调用,自动加载就是在这里实现的。通过指定自动加载类的路径,只要保证文件名和类名一样。就可以自动加载。这也是为什么你看很多源码中类的名字和文件名一样的原因,这样可以实现自动加载,不需要include.


网页标题:php自动加载数据库配置 php自动载入自定义函数文件
标题URL:http://njwzjz.com/article/dogeiii.html