FuelPHP 系列(二) ------ route 路由
FuelPHP 中,默认可以通过 /controller_name/function_name 这种方式来访问,也可以通过自定义路由来访问。
路由配置在 /fuel/app/config/routes.php 文件中。
一、最简单的路由设置,键值对形式。
return array(
'article' => 'article/index',
'article/add' => 'article/create',
'article/edit' => 'article/edit',
);
键名是 URL 中输入的内容,对应的值为请求的控制器中的方法。
二、在路由中加入一些规则
| :any | 可以匹配任意字符,但不能为空 |
| :everything | 匹配任何字符 |
| :segment | 匹配 URL 的一部分,这一部分可以是任何字符, |
| :num | 匹配任意数字 |
| :alpha | 匹配希腊字母 |
| :alnum | 匹配任意字母和数字 |
return array(
'article/(:any)' => 'article/indexxxxx',
'article(:everything)' => 'article/add',
'(:segment)/article' => 'test/article',
'(:segment)article' => 'test1/article',
'(\d{2})/article' => 'site2/article',
'blog/:year/:month/:id' => 'blog/entry',
);
三、根据不同请求方式,把 URL 路由到控制器的方法,有 GET、POST、DELETE 等。
return array(
'blog' => array(array('GET', new Route('blog/all')), array('POST', new Route('blog/create'))),
'blog/(:any)' => array(array('GET', new Route('blog/show/$1'), true)),
);
这个也可以和上面的规则结合使用。
四、设置有名字的路由
return array(
'admin/start/overview' => array('admin/overview', 'name' => 'admin_overview'),
);
静态页面中,可以用路由 name 实现点击跳转
echo Html::anchor(Router::get('admin_overview'), 'Overview');
<a href="{Router::get('admin_overview')}">Overview</a>
五、core 目录下的 Route 类
1、 add($path, $options = null, $prepend = false, $case_sensitive = null) 添加一条路由
$path 路由指向的控制器的方法
$options 路由中的参数
$prepend true 路由为已经加载的路由做准备
$case_sensitive 是否大小写敏感
Router::add('this/that', 'something/else'); //类似一中的简单键值对
2、 get($name, $named_params = array()) 通过已定义的路由名字,获取路由
$name 已定义的路由名称
$named_params 路由参数
//1、
return array(
'thread/(?P<thread_id>\d+?)/post' => array('post', 'name' => 'post'),
); //根据上面定义的路由,下面这些将返回 'thread/1/post':
echo Router::get('post', array('thread_id' => 1));
echo Router::get('post', array('$1' => 1));
echo Router::get('post', array(1)); //2、
return array(
'country/(?P<country>\d+?)/state/(?P<state>\d+?)/location' => array('location', 'name' => 'location'),
); // 根据上面定义的路由,下面这些将返回 'country/japan/state/tokyo/location':
echo Router::get('location', array('country' => 'japan', 'state' => 'tokyo'));
echo Router::get('location', array('$1' => 'japan', '$2' => 'tokyo'));
echo Router::get('location', array('japan', 'tokyo'));
echo Router::get('location', array('country' => 'japan', 'tokyo'));
echo Router::get('location', array('$1' => 'japan', 'tokyo'));
3、 delete($path, $case_sensitive = null) 删除已定义的路由
$path 路由 URL
$case_sensitive 是否大小写敏感
// 删除路由 'this/that'
Router::delete('this/that'); // 删除路由 'this/that' 和'some/other'
Router::delete(array('this/that', 'some/other')); // 设置路由区分大小写
Router::delete('this/that', true); // 删除 module controller 的所有路由
Router::delete('module/controller(:any)');
FuelPHP 系列(二) ------ route 路由的更多相关文章
- 探索ASP.Net Core 3.0系列二:聊聊ASP.Net Core 3.0 中的Startup.cs
原文:探索ASP.Net Core 3.0系列二:聊聊ASP.Net Core 3.0 中的Startup.cs 前言:.NET Core 3.0 SDK包含比以前版本更多的现成模板. 在本文中,我将 ...
- Web 前端开发精华文章推荐(HTML5、CSS3、jQuery)【系列二十二】
<Web 前端开发精华文章推荐>2014年第一期(总第二十二期)和大家见面了.梦想天空博客关注 前端开发 技术,分享各类能够提升网站用户体验的优秀 jQuery 插件,展示前沿的 HTML ...
- Laravel教程 二:路由,视图,控制器工作流程
Laravel教程 二:路由,视图,控制器工作流程 此文章为原创文章,未经同意,禁止转载. View Controller 上一篇教程我们走了那么长的路,终于把Laravel安装好了,这一篇教程我们就 ...
- [知识库分享系列] 二、Web(高性能Web站点建设)
知识库分享系列: [知识库分享系列] 二..NET(ASP.NET) [知识库分享系列] 一.开篇 分享介绍 此知识库之所以为 Web 系列,因为和 .NET 没有完全的关系,其中的技术和实践实用于各 ...
- MVC3/4/5/6 布局页及Razor语法及Route路由配置
一.目录结构 二.Razor语法 代码块:@{},如:@{Html.Raw(“”);} @if(){} @switch(){} @for(){} @foreach(){} @while(){} @do ...
- Flask系列(二)Flask基础
知识点回顾 1.flask依赖wsgi,实现wsgi的模块:wsgiref(django),werkzeug(flask),uwsgi(上线) 2.实例化Flask对象,里面是有参数的 app = F ...
- struts2官方 中文教程 系列二:Hello World项目
先贴个本帖的地址,免得其它网站被爬去了struts2入门系列二之Hello World 即 http://www.cnblogs.com/linghaoxinpian/p/6898779.html ...
- 学习ASP.NET Core Blazor编程系列二——第一个Blazor应用程序(中)
学习ASP.NET Core Blazor编程系列一--综述 学习ASP.NET Core Blazor编程系列二--第一个Blazor应用程序(上) 四.创建一个Blazor应用程序 1. 第一种创 ...
- 学习ASP.NET Core Blazor编程系列二——第一个Blazor应用程序(完)
学习ASP.NET Core Blazor编程系列一--综述 学习ASP.NET Core Blazor编程系列二--第一个Blazor应用程序(上) 学习ASP.NET Core Blazor编程系 ...
- 前端构建大法 Gulp 系列 (二):为什么选择gulp
系列目录 前端构建大法 Gulp 系列 (一):为什么需要前端构建 前端构建大法 Gulp 系列 (二):为什么选择gulp 前端构建大法 Gulp 系列 (三):gulp的4个API 让你成为gul ...
随机推荐
- OpenCV——漫水填充
- js基础知识整理
一.javaScript,也称之为js,是专为网页交互设计的脚本语言.主要由以下三部分组成: 1)ECMAScript 由ECMA-262定义,提供核心语言功能. 2)DOM对象(document ...
- JAVA框架 Spring 引入多个配置文件
1.如果配置文件比较长,可以分多个配置文件.有两种方式: 1)在主配置文件加标签<import/> <import resource="jd/com/other/appli ...
- day 21 今日学习内容
今日没有学习新的内容,可能今天就是对于前一段时间学习的总结,今天做了一个相对之前作业更加完善的ATM+购物车,在今天的学习里,我对于编程有了新的见解,编程并非一味的for..if...for...更多 ...
- 第43章 RTC—实时时钟
第43章 RTC—实时时钟 全套200集视频教程和1000页PDF教程请到秉火论坛下载:www.firebbs.cn 野火视频教程优酷观看网址:http://i.youku.com/fireg ...
- #define GPIOA ((GPIO_TypeDef *) GPIOA_BASE)
((GPIO_TypeDef *) GPIOA_BASE)表示将GPIOA_BASE强制转换为指针类型的结构体, #define GPIOA ((GPIO_TypeDef *) GPIOA_BASE) ...
- css样式显示省略号
用css样式显示省略号,记 .xx{ display: block; width:200px;/*对宽度的定义,根据情况修改*/ overflow: hidden; white-space: n ...
- 课程设计个人报告——基于ARM实验箱的Android交友软件的设计与实现
个人贡献 熟悉试验箱各元件功能以及连接组装试验箱 一.实验内容 研究实验箱串口.USB线的调通连接 二.实践步骤 1.打开实验箱,首先了解各元件功能 这个是LTE模块,也叫4G模块,具体的作用是硬件将 ...
- 20155338《网络对抗》Exp8 Web基础
20155338<网络对抗>Exp8 Web基础 实验内容 Web前端:HTML 使用netstat -aptn查看80端口是否被占用,如果被占用了就kill 原进程号,我的没有被占用. ...
- MFC如何为程序添加标题
1.在CMainFrame类中找到函数PreCreateWindow,在该函数中添加 cs.style &=~FWS_ADDTOTITLE;//去掉窗口的 自动标题 属性. 这句很重要不然的话 ...