当URL_CASE_INSENSITIVE
设置为true的时候表示URL地址不区分大小写,这个也是框架在部署模式下面的默认设置。'URL_CASE_INSENSITIVE' => true,
数字约束
支持对变量的类型检测,但仅仅支持数字类型的约束定义,例如
'blog/:idd'=>'Blog/read',
因为操作方法就是控制器的一个方法,所以遇到有和系统的关键字冲突的方法可能就不能定义了,这个时候我们可以设置操作方法的后缀来解决,例如:
'ACTION_SUFFIX' => 'Action', // 操作方法后缀
实例化控制器
访问控制器的实例化通常是自动完成的,系统会根据URL地址解析出访问的控制器名称自动实例化,并且调用相关的操作方法。
如果你需要跨控制器调用的话,则可以单独实例化:
// 实例化Home模块的User控制器
$User = new HomeControllerUserController();
// 实例化Admin模块的Blog控制器
$Blog = new AdminControllerBlogController();
系统为上面的控制器实例化提供了一个快捷调用方法A,上面的代码可以简化为:
// 假设当前模块是Home模块
$User = A('User');
$Blog = A('Admin/Blog');
默认情况下,A方法实例化的是默认控制器层(Controller),如果你要实例化其他的分层控制器的话,可以使用:
// 假设当前模块是Home模块
// 实例化Event控制器
$User = A('User','Event');
$Blog = A('Admin/Blog','Event');
上面的代码等效于:
// 实例化Home模块的User事件控制器
$User = new HomeEventUserEvent();
// 实例化Admin模块的Blog事件控制器
$Blog = new AdminEventBlogEvent();
URL操作
可以在common模块中设置
URL_CASE_INSENTIVE => 'true' 忽略url大小写
对于忽略大小写的情况,如果出现UserTypeController的情况,则需要在地址中这样对应 user_type
设置可访问模块
MODULE_ALLOW_LIST => array('Home','Array')
默认模块,可以省略模块名直接进入
DEFAULT_MODULE => 'Home'
默认伪静态结尾是 html
通过设置 URL_HTML_SUFFIX 来设置,如果该值为空,则可以任意后缀
目前伪静态的常量是 {$Think.const.__EXT__}来获取
可以限定 URL_HTML_SUFFIX => 'html|xhtml|xml' 就限定只能使用这三个后缀
模型的定义可以放在 Common/Model下面,这样所有模块都可以访问得到