通常,您有一个引导文件,其中包含 Composerautoload.php
和其他常见的东西,例如Dotenv
. 这可以是一个index.php
处理所有传入请求的文件(您会在框架中找到最常见的模式,Laravel 也是如此:https ://github.com/laravel/laravel/blob/8e5510458e1a4c0bf4b78024d9b0cf56102c8207/public/index.php#L34 )或其他一些文件,您将包含在所有.php
处理请求的文件中(如果您不使用 common index.php
)。
如果您想了解有关框架如何工作的更多信息,我建议您浏览并阅读他们的代码。你可以从更小的东西开始(比如 Slim)。
后期编辑 - 虚拟教程:
好的,让我们构建一个非常基本的项目:
第 1 步:我们从以下内容开始:
作曲家.json
{
"name": "example/project",
"type": "project",
"require": {
"vlucas/phpdotenv": "^5.3"
}
}
索引.php
<?php
use Dotenv\Dotenv;
require __DIR__.'/vendor/autoload.php';
$dotenv = Dotenv::createImmutable(__DIR__);
$dotenv->load();
echo 'Hello world!';
var_dump($_ENV);
.env
SAMPLE_ENV_VAR = some_value
运行后的文件结构composer install
:
project_root_folder/
- vendor/
- .env
- composer.json
- composer.lock
- index.php
鉴于此状态,当您在浏览器中访问 index.php(例如 http://localhost/ 或 http://localhost/index.php)时,它应该可以正常运行,并且您还应该看到我们自定义的 env var已在.env
文件中声明。
步骤 2.添加基本路由:
索引.php
<?php
use Dotenv\Dotenv;
require __DIR__.'/vendor/autoload.php';
$dotenv = Dotenv::createImmutable(__DIR__);
$dotenv->load();
// Figure out the requested page; fallback to the home page.
$page = $_GET['page'] ?? 'Home';
if ($page == 'Home') {
echo 'This is the home page.';
}
elseif ($page == 'Books/index') {
echo 'This is the books index page.';
}
elseif ($page == 'Books/detail') {
echo 'This is the detail page for book with ID: ' . $_GET['book_id'];
}
else {
echo 'NOT FOUND :(';
}
如果您现在访问 http://localhost/ 或 http://localhost/index.php 或 http://localhost/index.php?page=Home,您应该会看到主页。如果你访问 http://localhost/index.php?page=Books/index,你应该看到书籍索引页面等等......
步骤 3.将页面逻辑移出到单独的控制器:
index.php
<?php
use Dotenv\Dotenv;
require __DIR__.'/vendor/autoload.php';
$dotenv = Dotenv::createImmutable(__DIR__);
$dotenv->load();
// Figure out the requested page; fallback to the home page.
$page = $_GET['page'] ?? 'Home';
// We require the necessary controller class file and call its appropriate method:
if ($page == 'Home') {
require __DIR__.'/src/controllers/Home.php';
(new Home())->index();
}
elseif ($page == 'Books/index') {
require __DIR__.'/src/controllers/Books.php';
(new Books())->index();
}
elseif ($page == 'Books/detail') {
require __DIR__.'/src/controllers/Books.php';
(new Books())->detail();
}
else {
echo 'NOT FOUND :(';
}
src/Controllers/Home.php
<?php
class Home
{
public function index()
{
echo 'This is the home page.';
}
}
src/Controllers/Books.php
<?php
class Books
{
public function index()
{
echo 'This is the books index page.';
}
public function detail()
{
echo 'This is the detail page for book with ID: ' . $_GET['book_id'];
}
}
新的文件结构:
project_root_folder/
- src/
- Controllers/
- Home.php
- Books.php
- vendor/
- .env
- composer.json
- composer.lock
- index.php
第 4 步。利用 composer 和 PSR-4 自动加载(为了摆脱手动要求):
注意文件composer.json
的添加和添加的名称空间.php
。
作曲家.json
{
"name": "example/project",
"type": "project",
"require": {
"vlucas/phpdotenv": "^5.3"
},
"autoload": {
"psr-4": {
"Example\\Project\\": "src/"
}
}
}
确保运行composer dump-autoload
以“应用”上述更改。
src/Controllers/Home.php
<?php
namespace Example\Project\Controllers;
class Home
{
public function index()
{
echo 'This is the home page.';
}
}
src/Controllers/Books.php
<?php
namespace Example\Project\Controllers;
class Books
{
public function index()
{
echo 'This is the books index page.';
}
public function detail()
{
echo 'This is the detail page for book with ID: ' . $_GET['book_id'];
}
}
索引.php
<?php
use Dotenv\Dotenv;
require __DIR__.'/vendor/autoload.php';
$dotenv = Dotenv::createImmutable(__DIR__);
$dotenv->load();
// Figure out the requested page; fallback to the home page.
$page = $_GET['page'] ?? 'Home';
if ($page == 'Home') {
(new \Example\Project\Controllers\Home())->index();
}
elseif ($page == 'Books/index') {
(new Example\Project\Controllers\Books())->index();
}
elseif ($page == 'Books/detail') {
(new Example\Project\Controllers\Books())->detail();
}
else {
echo 'NOT FOUND :(';
}
步骤 5. 动态加载和调用控制器。
索引.php
<?php
use Dotenv\Dotenv;
require __DIR__.'/vendor/autoload.php';
$dotenv = Dotenv::createImmutable(__DIR__);
$dotenv->load();
// Figure out the requested page; fallback to the home page.
$page = $_GET['page'] ?? 'Home';
// Figure out the controller name and the method name.
if (strpos($page, '/') === FALSE) {
$page = $page . '/index';
}
[$controllerName, $method] = explode('/', $page);
$controllerClassName = '\\Example\\Project\\Controllers\\' . $controllerName;
if (class_exists($controllerClassName) && method_exists($controllerClassName, $method)) {
(new $controllerClassName())->$method();
}
else {
echo 'NOT FOUND :(';
}
在此更改之后,我们可以引入新的控制器(例如Faq
),而无需再进行修改index.php
。实现控制器类就足以让 http://localhost/index.php?page=Faq URL 正常工作。
... 等等。
以上是一个简单且不完整的路由示例。一个完整的路由机制比这复杂得多,但它可以让你基本了解如何使用 Composer、自动加载、路由。