译注: 期待 Laravel 5.0 已经很久很久了, 之前跳票说要到今年一月份发布. 从一月份就一直在刷新官网和博客, 始终没有更新的消息, 前几天终于看到官网文档切换到了 5.0 版. 新版本带来了众多令人激动的新特性, 尤其是定时任务队列和表单请求两个特性, 光看一下更新说明中的简单介绍都忍不住要上手尝试了. 今天总算抽出一点时间把官方的新特性说明文档简单地翻译了一下, 希望所有喜欢 Laravel 框架的朋友都能感受到这个版本带来的激动人心的改变. 当然, 如果你需要的是 Phalcon 那样的性能, 那它肯定不是你需要的. 如果你是因为虚拟主机不支持 php 5.4 而不能享受 Laravel, 那你还不扔了你的虚拟主机??? 阿里云\腾讯云\linode... VPS的选择不要太多...
[b]Laravel 5.0[/b]
Laravel 5.0 引入了全新的项目目录结构. 新的目录结构更有利于用 Laravel 来创建应用. 5.0 版从头到尾都采用了新的 PSR-4 自动加载标准. 以下是 5.0 版主要的新特性:
[b]目录结构[/b]
以前版本中的 app/models 目录被整个移除. 如今你可以直接把代码放在 app 目录下, 该目录下的所有代码默认会被组织到 app 命名空间. 这个命名空间是可以通过新增加的 Artisan 命令 app:name 来修改的.
Controllers, middleware 和 requests (Laravel 5.0 新增加的一种类) 被组织到 app/Http 目录, 因为他们都是与你应用的 HTTP 传输层相关的类. 与之前把所有路由过滤器放到单一的 filters 文件下不同, 现在所有的 middleware (类似之前的 route filter) 被分别存放到各自自己的类文件中.
新版本中增加了一个 app/Providers 目录来代替之前 4.x 版本的 app/start 文件. 这些 service providers 为应用提供各种各样的引导方法, 比如错误处理, 日志记录, 路由加载等. 除此之外你当然也可以创建额外的 service providers.
应用的语言文件和视图被移到了 resources 目录.
[b]Contracts[/b]
Laravel 的所有主要组件都实现了存放在 illuminate/contracts 仓库中的接口. 该仓库没有额外的依赖项. 拥有这样一个方便的, 集中存放的接口集合, 你就可以很容易地通过它来对 Laravel Facades 进行解耦和依赖注入方面的选择和修改.
了解有关 contracts 的更多信息, 可以查看它的[url=http://laravel.com/docs/5.0/contracts]完整文档[/url].
[b]路由缓存[/b]
如果你的应用由各种各样的控制器路由 (controller routes) 组成, 你可以利用新增的 Artisan 命令 route:cache 大幅度提升路由的注册速度. 这在路由数量超过 100 个的应用中尤其有效, 可以 大幅度 提升整个应用在路由部分的速度.
[b]路由中间件 (Route Middleware)[/b]
在 4.0 版风格的路由 "过滤器" 基础上, 新版 5.0 已经支持 HTTP 中间件, Laravel 自带的 "authentication" 和 "filters" 已经被转换成中间件. 中间件为所有类型的过滤器提供了单一接口, 你可以很容易地对请求进行审查和拒绝.
了解有关中间件的更多信息, 可以查看它的[url=http://laravel.com/docs/5.0/middleware]完整文档[/url].
[b]控制器方法注入[/b]
除了现有的构造器注入以外, 在新版本中还可以在控制器方法中的依赖项进行类型约束. [url=http://laravel.com/docs/5.0/container]IoC container [/url]会自动注入依赖项, 即使在路由包含其它参数的时候也是.
[url=http://laravel.com/docs/5.0/events]完整文档[/url].
[b]命令/队列[/b]
在 4.0 版支持的任务队列基础上, 5.0 支持把任务队列定义为简单的命令对象. 这些命令存放在 app/Commands 目录. 下面是一个简单的命令示例:
[url=http://laravel.com/docs/5.0/events]命令桥[/url]的详细文档.
[b]数据库队列[/b]
新版 Laravel 包含 database 队列驱动, 提供简单的, 本地的队列驱动, 无需安装额外的包. (译注:比如让不支持事务的数据库进行类似事务的数据操作)
[b]Laravel 定时任务[/b]
在过去, 为了定时执行控制台任务, 开发者必须依赖 Cron 任务. 这带来很大不便. 因为定时任务并不包括在网站的源代码中, 而且必须通过 SSH 登陆到服务器去添加 Cron 任务. 新版 Laravel 的定时任务允许开发者在 Laravel 框架内来定义定时执行的命令, 然后只需要在服务器上定义一个总的 Cron 任务即可.
比如:
[url=http://laravel.com/docs/5.0/artisan#scheduling-artisan-commands]完整文档[/url].
[b]Tinker / Psysh[/b]
php artisan tinker 命令在新版本中借助了 Justin Heleman 开发的 Psysh. 如果你喜欢 Laravel 4.0 里的 Boris, 你肯定会喜欢 Psysh. Boris 在 Windows 下运行得不好, Psysh 完全支持 Windows! 使用方法和以前一样:
[url=https://github.com/vlucas/phpdotenv]DotEnv [/url]替代了以前版本中的嵌套结构, 容易让人困惑的环境配置目录. 这个框架提供了一种非常简单的管理环境配置的方式. 在 Laravel 5.0 中检测和区分不同的运行环境变得轻而易举. 了解更多详情, 请访问完整的[url=http://laravel.com/docs/5.0/configuration#environment-configuration]配置文档[/url].
[b]Laravel Elixir[/b]
由 Jeffrey Way 提供的 Laravel Elixir 提供了简明易懂的合并, 编译资源文件的接口. 如果你曾经对配置 Grunt 或者 Gulp 感到很头大, 那么现在你得到解放了. Elixir 让你可以轻松地借助 Gulp 来编译你的 Less, Sass 和 CoffeeScript 文件. 它甚至可以替你执行测试.
了解 Elixir 的更多详情, 请访问[url=http://laravel.com/docs/5.0/elixir]完整文档[/url].
[b]Laravel Socialite[/b]
Laravel Socialite 只兼容 Laravel 5.0 以上版本的可选包, 它提供了完整而且上手毫无难度的 OAuth 解决方案. 目前, Socialite 支持 Facebook, Twitter, Google 和 Github. 它看起来是这个样子的:
[url=http://laravel.com/docs/5.0/authentication#social-authentication]完整文档 [/url]包含有关这个可选包的全部细节.
[b]Flysystem 集成[/b]
新版 Laravel 还包含了强大的 [url=https://github.com/thephpleague/flysystem]Flysystem [/url]文件处理静态库. 通过这个库, 开发者可以轻易上手, 使用完全一致的 API 来实现本地, Amazon S3 或者 Rackspace 进行文件存储. 比如, 在 Amazon S3 存储一个文件, 可以简单到这样:
[url=http://laravel.com/docs/5.0/filesystem]完整文档[/url]
[b]表单请求[/b]
Laravel 5.0 带来了全新的 form requests, 它扩展自 Illuminate\Foundation\Http\FormRequest 类. 这些请求对象可以和控制器方法注入相结合, 提供一种全新的验证用户输入的方法. 简单举一个 FormRequest 的示例:
[url=http://laravel.com/docs/5.0/validation#form-request-validation]文档[/url].
[b]控制器请求简单验证[/b]
Laravel 5.0 的控制器基类还包含了一个 ValidatesRequests 的 trait. 该 trait 提供了简单的 validate 方法, 用于验证请求. 如果 FormRequests 对于你的应用来说太重了, 那你就可以用这个轻量版的:
[url=http://laravel.com/docs/5.0/validation#controller-validation]文档[/url].
[b]全新的生成器[/b]
为了方便生成新的默认应用结构, 全新的 Artisan 生成命令已经被添加到框架中. 你可以通过 php artisan list 查看详细命令.
[b]配置缓存[/b]
通过 config:cache 命令, 可以把所有的配置项写入一个缓存文件中.
[b]Symfony VarDumper[/b]
用于输出变量信息进行调试的辅助方法 dd, 在新版本中进行了升级, 使用强大的 Symfony VarDumper. 它可以输出带有颜色高亮和数组折叠功能的调试信息. 你可以尝试一下:
dd([1, 2, 3]);
微信版

扫一扫进微信版
返回顶部