php yii2框架仿站教程,关于Yii2框架搭建完整博客系统的资源分享

Yii是PHP快速开发的最佳实践之一,丰富的扩展资源,快速开发的思想,越来越受到企业的青睐,应用也愈加广泛。本课程以博客系统为例,讲述如何使用yii2.0实战开发,从中学习yii2.0的实践应用。内容分三个部分:基础配置、博客前台、博客后台。

4925251182bdc6849ac35340129364ea.png

该老师讲课风格:

教师讲课深入浅出,条理清楚,层层剖析,环环相扣,论证严密,结构严谨,用思维的逻辑力量吸引学生的注意力,用理智控制课堂教学进程。学生通过听教师的讲授,不仅学到知识,也受到思维的训练,还受到教师严谨的治学态度的熏陶和感染

本视频中较为难点是Yii框架博客系统的框架路由配置了:

基本路由

您的应用程序的绝大多数路由将在 app/routes.PHP 文件中定义。Laravel 中最简单的路由由一个 URI 和一个闭包调用组成。

基本 GET 路由

代码如下:Route::get('/', function(){return 'Hello World';});

基本 POST 路由

代码如下:Route::post('foo/bar', function()

{

return 'Hello World';

});

注册一个路由以响应所有 HTTP 方法

代码如下:Route::any('foo', function()

{

return 'Hello World';

});

强制一个路由必须通过 HTTPS 访问

代码如下:Route::get('foo', array('https', function()

{

return 'Must be over HTTPS';

}));

经常您需要根据路由产生 URLs,您可以通过使用 URL::to 方法:

代码如下:$url = URL::to('foo');

路由参数

代码如下:Route::get('user/{id}', function($id)

{

return 'User '.$id;

});

可选的路由参数

代码如下:Route::get('user/{name?}', function($name = null)

{

return $name;

});

带默认值的可选的路由参数

代码如下:Route::get('user/{name?}', function($name = 'John')

{

return $name;

});

带正则表达式约束的路由

代码如下:Route::get('user/{name}', function($name)

{

//

})

->where('name', '[A-Za-z]+');

Route::get('user/{id}', function($id)

{

//

})

->where('id', '[0-9]+');

路由过滤器

路由过滤器提供了一种限制访问指定路由的简单的方法,这在您需要为您的站点创建需要认证区域的时候非常有用。Laravel 框架中包含了一些路由过滤器,比如 auth 过滤器、auth.basic 过滤器、guest 过滤器、以及 csrf 过滤器。它们被存放在 app/filters.php 文件中。

定义一个路由过滤器

代码如下:Route::filter('old', function()

{

if (Input::get('age') < 200)

{

return Redirect::to('home');

}

});

如果一个响应从一个路由过滤器中返回,这个响应即被认为是这个请求的响应,路由将不被执行,任何关于这个路由的 after 过滤器也将被取消执行。

为一个路由指定一个路由过滤器

代码如下:Route::get('user', array('before' => 'old', function()

{

return 'You are over 200 years old!';

}));

为一个路由指定多个路由过滤器

代码如下:Route::get('user', array('before' => 'auth|old', function()

{

return 'You are authenticated and over 200 years old!';

}));

指定路由过滤器参数

代码如下:Route::filter('age', function($route, $request, $value)

{

//

});

Route::get('user', array('before' => 'age:200', function()

{

return 'Hello World';

}));

当路由过滤器接收到作为第三个参数的响应 $response:

代码如下:Route::filter('log', function($route, $request, $response, $value)

{

//

});

基本路由过滤器的模式

您可能希望根据 URI 为一组路由指定过滤器。

代码如下:Route::filter('admin', function()

{

//

});

Route::when('admin/*', 'admin');

在上面的例子中,admin 过滤器将应用带所有以 admin/ 开头的路由。星号作为一个通配符,将适配到所有字符的组合。

您也可以通过指定 HTTP 方法约束模式过滤器:

代码如下:Route::when('admin/*', 'admin', array('post'));

过滤器类

对于高级的过滤器,您可以使用一个类代替闭包函数。因为过滤器类是位于应用程序之外的 IoC 容器,您能够在过滤器中使用依赖注入,更易于测试。

定义一个过滤器类

代码如下:class FooFilter {

public function filter()

{

// Filter logic...

}

}

注册一个基于类的过滤器

代码如下:Route::filter('foo', 'FooFilter');

命名路由

命名路由在更易于在生成跳转或 URLs 时指定路由。您可以像这样为路由指定一个名字:

代码如下:Route::get('user/profile', array('as' => 'profile', function()

{

//

}));

您也可以为控制器的方法指定路由名字:

代码如下:Route::get('user/profile', array('as' => 'profile', 'uses' => 'UserController@showProfile'));

现在您在生成 URLs 或跳转的时候使用路由的名字:

代码如下:$url = URL::route('profile');

$redirect = Redirect::route('profile');

您可以使用 currentRouteName 方法获取一个路由的名字:

代码如下:$name = Route::currentRouteName();

路由组

有些时候您可能希望应用过滤器到一组路由。您不必要为每个路由指定过滤器,可以使用路由组:

代码如下:Route::group(array('before' => 'auth'), function()

{

Route::get('/', function()

{

// Has Auth Filter

});

Route::get('user/profile', function()

{

// Has Auth Filter

});

});

子域名路由

Laravel 路由也能够处理通配符的子域名,并且从域名中获取通配符参数:

注册子域名路由

代码如下:Route::group(array('domain' => '{account}.myapp.com'), function()

{

Route::get('user/{id}', function($account, $id)

{

//

});

});

路由前缀

一组路由可以通过在属性数组中使用 prefix 选项为路由组添加前缀:

为路由组添加前缀

代码如下:Route::group(array('prefix' => 'admin'), function()

{

Route::get('user', function()

{

//

});

});

路由模型绑定

模型绑定提供了一个简单的方法向路由中注入模型。比如,不仅注入一个用户的 ID,您可以根据指定的 ID 注入整个用户模型实例。首先使用 Route::model 方法指定所需要的模型:

为模型绑定一个变量

代码如下:Route::model('user', 'User');

然后, 定义一个包含 {user} 参数的路由:

代码如下:Route::get('profile/{user}', function(User $user)

{

//

});

因为我们已经绑定 {user} 参数到 User 模型,一个 User 实例将被注入到路由中。因此,比如一个 profile/1 的请求将注入一个 ID 为 1 的 User 实例。

注意: 如果在数据库中没有找到这个模型实例,将引发404错误。

如果您希望指定您自己定义的没有找到的行为,您可以为 model 方法传递一个闭包作为第三个参数:

代码如下:Route::model('user', 'User', function()

{

throw new NotFoundException;

});

有时您希望使用自己的方法处理路由参数,可以使用 Route::bind 方法:

代码如下:Route::bind('user', function($value, $route)

{

return User::where('name', $value)->first();

});

引发404错误

有两种方法在路由中手动触发一个404错误。首先,您可以使用 App::abort 方法:

代码如下:App::abort(404);

其次,您可以抛出一个 Symfony\Component\HttpKernel\Exception\NotFoundHttpException 的实例。

更多关于处理404异常和为这些错误使用使用自定义响应的信息可以在 错误 章节中找到。

路由至控制器

Laravel 不仅允许您路由至闭包,也可以路由至控制器类,甚至允许创建 资源控制器.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Yii 2.0 权威指南 本教程的发布遵循 Yii 文档使用许可. 版权所有 2014 (c) Yii Software LLC. 介绍 已定稿 关于 Yii 已定稿 从 Yii 1.1 升级 入门 已定稿 安装 Yii 已定稿 运行应用 已定稿 第一次问候 已定稿 使用 Forms 已定稿 玩转 Databases 已定稿 用 Gii 生成代码 已定稿 更上一层楼 应用结构 已定稿 结构概述 已定稿 入口脚本 已定稿 应用 已定稿 应用组件 已定稿 控制器(Controller) 已定稿 视图(View) 已定稿 模型(Model) 已定稿 过滤器 已定稿 小部件(Widget) 已定稿 模块(Module) 已定稿 前端资源(Asset) 已定稿 扩展(extensions) 请求处理 已定稿 运行概述 已定稿 引导(Bootstrapping) 已定稿 路由(Route)引导与创建 URL 已定稿 请求(Request) 已定稿 响应(Response) 已定稿 Sessions(会话)和 Cookies 已定稿 错误处理 已定稿 日志 关键概念 已定稿 组件(Component) 已定稿 属性(Property) 已定稿 事件(Event) 已定稿 行为(Behavior) 已定稿 配置(Configurations) 已定稿 类自动加载(Autoloading) 已定稿 别名(Alias) 已定稿 服务定位器(Service Locator) 已定稿 依赖注入容器(DI Container) 配合数据库工作 编撰中 数据访问对象(DAO) - 数据库连接、基本查询、事务和模式操作 编撰中 查询生成器(Query Builder) - 使用简单抽象层查询数据库 编撰中 活动记录(Active Record) - 活动记录对象关系映射(ORM),检索和操作记录、定义关联关系 编撰中 数据库迁移(Migration) - 在团体开发中对你的数据库使用版本控制 待定中 Sphinx 待定中 Redis 待定中 MongoDB 待定中 ElasticSearch 接收用户数据 编撰中 创建表单 已定稿 输入验证 编撰中 文件上传 待定中 多模型同时输入 显示数据 编撰中 格式化输出数据 待定中 分页(Pagination) 待定中 排序(Sorting) 编撰中 数据提供器 编撰中 数据小部件 编撰中 主题 安全 编撰中 认证(Authentication) 编撰中 授权(Authorization) 编撰中 处理密码 待定中 客户端认证 待定中 安全领域的最佳实践 缓存 已定稿 概述 已定稿 数据缓存 已定稿 片段缓存 已定稿 分页缓存 已定稿 HTTP 缓存 RESTful Web 服务 已定稿 快速入门 已定稿 资源 已定稿 路由 已定稿 格式化响应 已定稿 授权验证 已定稿 速率限制 已定稿 版本化 已定稿 错误处理 已定稿 测试
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值