您可以在应用目录的某处创建一个新目录,例如app/libraries
然后在您的 composer.json 文件中,您可以在您的自动加载类映射中包含 app/libraries:
{
"name": "laravel/laravel",
"description": "The Laravel Framework.",
"keywords": ["framework", "laravel"],
"license": "MIT",
"require": {
"laravel/framework": "4.2.*",
},
"autoload": {
"classmap": [
"app/commands",
"app/controllers",
"app/models",
"app/libraries", <------------------ YOUR CUSTOM DIRECTORY
"app/database/migrations",
"app/database/seeds",
"app/tests/TestCase.php"
]
},
"scripts": {
"post-install-cmd": [
"php artisan clear-compiled",
"php artisan optimize"
],
"post-update-cmd": [
"php artisan clear-compiled",
"php artisan optimize"
],
"post-create-project-cmd": [
"php artisan key:generate"
]
},
"config": {
"preferred-install": "dist"
},
"minimum-stability": "stable",
}
请务必在修改您的 composer.json 后运行 composer dump-autoload。
假设您的类名为CustomClass.php,它位于app/libraries 目录中(因此完整路径为app/libraries/CustomClass.php)。如果您已正确命名您的类,按照惯例,您的命名空间可能会命名为libraries。为了清楚起见,我们将命名空间称为custom 以避免与目录混淆。
$class = new \custom\CustomClass();
或者,您可以在 app/config/app.php 文件中为其指定别名:
/*
|--------------------------------------------------------------------------
| Class Aliases
|--------------------------------------------------------------------------
|
| This array of class aliases will be registered when this application
| is started. However, feel free to register as many as you wish as
| the aliases are "lazy" loaded so they don't hinder performance.
|
*/
'aliases' => array(
...
'CustomClass' => 'custom\CustomClass',
...
)
您可以在应用程序的任何位置实例化该类,就像使用任何其他类一样:
$class = new CustomClass();
希望这会有所帮助!