laravel应用程序中index.php是所有请求的入口。当用户提交一个form或者访问一个网页时,首先由kernel捕捉到该session PHP运行环境下的用户数据,
生成一个request对象,该对象再传入routing系统寻址到对应的controller,最终由controller形成response返回给浏览器,完成整个网页请求的生命周期。
$kernel->handle $request=Illuminate\Http\Request::capture->createFromBase->createFromGlobals->
$request = self::createRequestFromFactory($_GET, $_POST, array(), $_COOKIE, $_FILES, $server);(Symfony\Component\HttpFoundation\Request::createRequestFromFactory)
$response = $this->sendRequestThroughRouter($request); Kernel.php(Illuminate\Foundation\Http\Kernel)
$this->app['events']->fire('kernel.handled', [$request, $response]);
return $response; response->send();
从上面的简单分析可以看出,laravel中的请求生命周期分为三个部分:
1. 一个HTTP请求被routed到一个controller(request对象本身的生成过程如上面所描述)
2. controller执行特定的action访问数据库获取数据按照商业逻辑处理后返回到View;
3. View本身将数据做格式化,最终提供HTTP的response到浏览器
虽然大体过程如上面描述,但是除此之外,也有很多异常流程并未提及。一个request的整个生命周期可以分为三个部分: Loading, Booting, Running.
loading steps:
有三个你的应用能够影响loading步骤的三个区域:
1)workbench: workbench允许你开发和调试一个package
2)你可以修改bootstrap/strat.php并且增加你的应用环境检测;
3)你可以修改bootstrap/paths.php来定制你的应用路径
Booting steps
有10个你的应用可以影响到booting steps的不同区域:
1. configuration:你的应用配置影响到boot process和laravel的运行;
2.service providers:任何你创建的service provider都将在boot process的早期加载到应用中。如果你的service provider 不被deferred,那么他的register()方法将在这时调用;
3.registering the strat files.你的三个application startup file将在应用的booted 事件发生时被加载
4.handle middleware going down
5.booting service providers, 这时所有non-deferred service provider的boot()函数被调用
6.booting callbacks. 任何使用APP::booting()函数注册的callbacks将被调用
7.booted callback. 既然应用已经booted了,那么任何使用App::booted()函数注册的回调将被调用。这包括在第三步中用于加载三个application startup文件的callback
8.Your application start script被调用。这时app/start/globals.php文件。这时任何你希望你的应用在任何request被处理之前所调用的。
9.app/start/{environment}.php如果你需要在特定环境下初始化的代码可以放到这里。
10.app/routes.php:你的应用程序的路由。
running steps
1.Maintenance mode:如果你有一个maintenance mode侦听函数被注册了,那么你的listener将在此运行;
2.App "before" filter:
如果你有任何用App::before()来注册的filter,那么他们在此运行;
3.Route/Controller "before"filters
如果你有任何在route或者controller level的before filter,则在此运行;
4.action:
这里是一个controller method或者一个route callback当处理请求是被调用;
5.Route/Controller "after" filters:如果你有route或者controller level的after filter,则在这里被调用;
6.App "after" filters.
如果你有任何使用App::after()函数注册的filter,则在这里调用。任何一个middleware可以在response被返回前来修改它;
7.middleware repsponse handling:
8. middleware shtdown.如果你提供了一个实现了TerminableInterface的middleware,则他的shutdown()
9.Finish callbacks:
如果你有App::finish()注册的callback,则这时调用;
10.shutdown callbacks。最后,如果你有使用App::shutdown()注册的callback则这时调用
http://laravel-recipes.com/recipes/52/understanding-the-request-lifecycle