随着您不断向routes.php添加越来越多的路由,它变得越来越大。你是如何组织它们的?
我创建了一个目录/application/routes/并在其中添加了文件。每个文件只是一组路由。然后在routes.php中,我添加了以下代码以包括所有代码:
// Dynamically include all files in the routes directory
foreach (new DirectoryIterator(__DIR__.DS.'routes') as $file)
{
if (!$file->isDot() && !$file->isDir() && $file->getFilename() != '.gitignore')
{
require_once __DIR__.DS.'routes'.DS.$file->getFilename();
}
}
即使采用了其他答案中提到的所有最佳实践,即:使用资源控制器、路由组等
你可以用旧的方式简单地"包含"路由文件。正如Chris G在评论中提到的。
您可以创建简单的目录结构,并将路由文件包含在route.php文件中。
../myroutes
--route-type-1.php
--route-type-2.php
在route.php文件中
include('myroutes/route-type-1.php');
它没有错。这就是包裹中包含路线的方式。
http://laravel.com/docs/packages#package-路由
我通常使用Group routes(因为如果控制器是相关的,则它们往往具有相同类型的过滤)来组织它们,或者如果您希望/可以有一个较小的routes文件,您可能希望注册您的控制器,并在控制器内部对URL的参数进行额外的验证检查。
实际上,路由应该保持精简。只需将代码移动到控制器,并使用路由进行注册和重定向。惯例是每个文件存储一个控制器,这样代码就会自动组织起来。
看看这个
// application/controllers/sample.php
class Sample_Controller extends Base_Controller
{
public function action_index()
{
echo "Wellcome to the root" //www.testapp.com/sample
}
public function action_edit()
{
echo "Some editing functions here." //www.testapp.com/sample/edit
}
public function action_whatsoever()
{
echo "Put here whatever you like." //www.testapp.com/sample/whatsoever
}
}
控制器动作路线可以这样注册:
//application/routs.php
Route::controller('admin::home');
很直,很舒服。
更新:
您也可以使用这条线为整个应用程序自动注册所有控制器:
Route::controller(Controller::detect());
或所有动作的控制器:
Route::controller(Controller::detect('yourcontroller'));
或者,您可以将路由存储在不同的文件中,然后使用include:获取这些文件
Route::group(stuff,function(){
include __DIR__.DS.'routes1.php';
include __DIR__.DS.'routes2.php';
});
当代码太多时,这提供了一种很好的、干净的排序处理方法,你也可以提到
Route::controller(Controller::detect());
然后相应地构建控制器:
class Account_Controller extends Base_Controller {
public function action_login() {
//Login
}
public function action_logout() {
...
}
如果您必须将参数传递给某些功能:
public function dosomething($input){
...
}
你可以达到这样的功能:
http://yourapp/account/login
http://yourapp/account/logout
然后,您可以通过将参数附加到URL来调用该函数,
http://yourapp.account/dosomething/somedata
如果你需要保护一些方法,那么在没有操作的情况下附加它们,这样公众就不能访问它们。
或者,您可以切换到restful方法,这基本上是一种根据您获得的查询类型来响应某些输入的方式,例如,当您收到对登录页面的"get"请求时,这意味着用户需要查看登录屏幕,当你收到一个"POST"请求时,通常意味着用户正在发布登录数据,因此你可以做出响应,这将帮助你减少函数的数量。有关restful方法的更多信息,你可以阅读Ryan Tomayako的这篇精彩文章http://tomayko.com/writings/rest-to-my-wife
要使用restful方法,您需要将restful提到true,然后在函数名称之前附加action关键字。
public $restful = true;
public function get_login() {
return View::make('login');
//This function is accessible using GET request to http://yourapp/login
}
public function post_login() {
$data = Input::get();
//do something using the Input data
//This function is accessible using a POST request to http://yourapp/login
}
通过这种方式,您可以消除另一个路由来处理和验证用户凭据的需要!
如果您不希望使用restful方法访问某些方法,那么就不要在函数名中包含action关键字(get,post,…)。
将restful方法与智能路由相结合是保持代码干净和安全的最有效方法。