Api SlimPhp 微框架上的路由模式?
Api route pattern on the SlimPhp microframework?
是否有一些路由模式以及如何使用 SlimPhp 编写结构?
例如,我创建了一个 api 文件夹,其中包含 index.php 来存储我所有的路线:
$app->get('/api/shirt/{id}', function (Request $request, Response $response) {
//CODE
});
$app->get('/api/some-other-endpoint/{id}', function (Request $request, Response $response)
//CODE
});
但过了一段时间,我意识到我的索引文件会变得很大。
那么,如何管理端点路由?使用 类、控制器、动作?
在哪里可以找到有关这些特定概念的文档?
在涉及到Slim的router之前,我一般都有自己的router,根据domain之后的路径来决定使用哪条路由:
public/index.php
chdir(dirname(__DIR__));
require_once 'vendor/autoload.php';
$app = new Slim\App;
require 'app/routes/index.php';
$app->run();
app/routes/index.php
$_url = parse_url($_SERVER['REQUEST_URI']);
$_routes = explode('/',$_url['path']);
$_baseRoute = $_routes[1];
switch ($_baseRoute) {
case 'api':
$_routeFile = 'app/api/' . $_routes[2] . '.php';
break;
default:
$_routeFile = 'app/routes/' . $_baseRoute . '.php';
break;
}
if (file_exists($_routeFile)) {
require $_routeFile;
}
else {
die('Invalid API request');
}
我正在使用控制器(在本例中名为 Action)并且仍然将所有路由放在一个文件中。
此外,我尽可能地使用分组,因为它提供了更好的结构(在我看来)。
我尝试使 Action-classes 尽可能小,这样我就不需要查看路由文件来获取我想要更改的 class。
举个例子:
路由文件:
$app->get('/user/{name}', [ShowUserAction::class, 'showUser'])->setName('user');
$app->get('/login', [LoginUserAction::class, 'showLogin'])->setName('login');
$app->group('/api', function () {
$this->get('/images', [ImagesApi::class, 'getImages'])->setName('api.images');
$this->get('/tags', [ImagesApi::class, 'getTags'])->setName('api.tags');
$this->get('/notifications', [UserNotificationsApiAction::class, 'getNotifications'])->setName('api.notifications');
$this->get('/bubbleCount', [BubbleCountApiAction::class, 'getBubbleCount'])->setName('api.bubbleCount');
});
$app->group('/review', function() use ($currentUser) {
$this->get('', [ReviewAction::class, 'showReviewOverview'])->setName('review.overview')->setName('review')
$this->get('/{type}', [ReviewAction::class, 'showReviewWithType'])->setName('review.type')
$this->get('/{type}/{id}', [ReviewAction::class, 'showReview'])->setName('review.type.id')
});
动作-class:
class LoginUserAction
{
public function __construct() { } // with parameters
public function showLogin(Request $request, Response $response)
{
if ($this->currentUser->isLoggedIn()) {
return $response->withRedirect($this->router->pathFor('index'));
}
return $this->view->render($response, 'user/login.twig');
}
public function doLogin(Request $request, Response $response)
{
// check user name password and then login
}
}
是否有一些路由模式以及如何使用 SlimPhp 编写结构?
例如,我创建了一个 api 文件夹,其中包含 index.php 来存储我所有的路线:
$app->get('/api/shirt/{id}', function (Request $request, Response $response) {
//CODE
});
$app->get('/api/some-other-endpoint/{id}', function (Request $request, Response $response)
//CODE
});
但过了一段时间,我意识到我的索引文件会变得很大。
那么,如何管理端点路由?使用 类、控制器、动作?
在哪里可以找到有关这些特定概念的文档?
在涉及到Slim的router之前,我一般都有自己的router,根据domain之后的路径来决定使用哪条路由:
public/index.php
chdir(dirname(__DIR__));
require_once 'vendor/autoload.php';
$app = new Slim\App;
require 'app/routes/index.php';
$app->run();
app/routes/index.php
$_url = parse_url($_SERVER['REQUEST_URI']);
$_routes = explode('/',$_url['path']);
$_baseRoute = $_routes[1];
switch ($_baseRoute) {
case 'api':
$_routeFile = 'app/api/' . $_routes[2] . '.php';
break;
default:
$_routeFile = 'app/routes/' . $_baseRoute . '.php';
break;
}
if (file_exists($_routeFile)) {
require $_routeFile;
}
else {
die('Invalid API request');
}
我正在使用控制器(在本例中名为 Action)并且仍然将所有路由放在一个文件中。
此外,我尽可能地使用分组,因为它提供了更好的结构(在我看来)。 我尝试使 Action-classes 尽可能小,这样我就不需要查看路由文件来获取我想要更改的 class。
举个例子:
路由文件:
$app->get('/user/{name}', [ShowUserAction::class, 'showUser'])->setName('user');
$app->get('/login', [LoginUserAction::class, 'showLogin'])->setName('login');
$app->group('/api', function () {
$this->get('/images', [ImagesApi::class, 'getImages'])->setName('api.images');
$this->get('/tags', [ImagesApi::class, 'getTags'])->setName('api.tags');
$this->get('/notifications', [UserNotificationsApiAction::class, 'getNotifications'])->setName('api.notifications');
$this->get('/bubbleCount', [BubbleCountApiAction::class, 'getBubbleCount'])->setName('api.bubbleCount');
});
$app->group('/review', function() use ($currentUser) {
$this->get('', [ReviewAction::class, 'showReviewOverview'])->setName('review.overview')->setName('review')
$this->get('/{type}', [ReviewAction::class, 'showReviewWithType'])->setName('review.type')
$this->get('/{type}/{id}', [ReviewAction::class, 'showReview'])->setName('review.type.id')
});
动作-class:
class LoginUserAction
{
public function __construct() { } // with parameters
public function showLogin(Request $request, Response $response)
{
if ($this->currentUser->isLoggedIn()) {
return $response->withRedirect($this->router->pathFor('index'));
}
return $this->view->render($response, 'user/login.twig');
}
public function doLogin(Request $request, Response $response)
{
// check user name password and then login
}
}