🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
入口文件是应用的单一入口,对应用的所有请求都定向到应用入口文件,系统会从URL参数中解析当前请求的模块、控制器和操作: ~~~ ~~~ http://serverName/index.php/模块/控制器/操作 ~~~ ~~~ 这是3.2版本的标准URL格式。 > 可以通过设置模块绑定或者域名部署等方式简化URL地址中的模块及控制器名称。 ### URL大小写 ThinkPHP框架的URL是区分大小写(主要是针对模块、控制器和操作名,不包括应用参数)的,这一点非常关键,因为ThinkPHP的命名规范是采用驼峰法(首字母大写)的规则,而URL中的模块和控制器都是对应的文件,因此在Linux环境下面必然存在区分大小写的问题。 框架内置了一个配置参数用于解决URL大小写的问题,如下: ~~~ ~~~ 'URL_CASE_INSENSITIVE' => true, ~~~ ~~~ 当`URL_CASE_INSENSITIVE`设置为true的时候表示URL地址不区分大小写,这个也是框架在部署模式下面的默认设置。 > 当开启调试模式的情况下,这个参数是false,因此你会发现在调试模式下面URL区分大小写的情况。 ### URL模式 如果我们直接访问入口文件的话,由于URL中没有模块、控制器和操作,因此系统会访问默认模块(Home)下面的默认控制器(Index)的默认操作(index),因此下面的访问是等效的: ~~~ ~~~ http://serverName/index.php http://serverName/index.php/Home/Index/index ~~~ ~~~ 这种URL模式就是系统默认的PATHINFO模式,不同的URL模式获取模块和操作的方法不同,ThinkPHP支持的URL模式有四种:**普通模式、PATHINFO、REWRITE和兼容模式**,可以设置**URL_MODEL**参数改变URL模式。 | URL模式 | URL_MODEL设置 | |-----|-----| | 普通模式 | 0 | | PATHINFO模式 | 1 | | REWRITE模式 | 2 | | 兼容模式 | 3 | > 如果你整个应用下面的模块都是采用统一的URL模式,就可以在应用配置文件中设置URL模式,如果不同的模块需要设置不同的URL模式,则可以在模块配置文件中设置。 ### 普通模式 **普通模式**也就是传统的GET传参方式来指定当前访问的模块和操作,例如: `http://localhost/?m=home&c=user&a=login&var=value` m参数表示模块,c参数表示控制器,a参数表示操作(当然这些参数都是可以配置的),后面的表示其他GET参数。 如果默认的变量设置和你的应用变量有冲突的话,你需要重新设置系统配置,例如改成下面的: ~~~ ~~~ 'VAR_MODULE' => 'module', // 默认模块获取变量 'VAR_CONTROLLER' => 'controller', // 默认控制器获取变量 'VAR_ACTION' => 'action', // 默认操作获取变量 ~~~ ~~~ 上面的访问地址则变成: `http://localhost/?module=home&controller=user&action=login&var=value` > 注意,VAR_MODULE只能在应用配置文件中设置,其他参数可以则也可以在模块配置中设置 ### PATHINFO模式 **PATHINFO模式**是系统的默认URL模式,提供了最好的SEO支持,系统内部已经做了环境的兼容处理,所以能够支持大多数的主机环境。对应上面的URL模式,PATHINFO模式下面的URL访问地址是: `http://localhost/index.php/home/user/login/var/value/` PATHINFO地址的前三个参数分别表示模块/控制器/操作。 > 不过,PATHINFO模式下面,依然可以采用普通URL模式的参数方式,例如: `http://localhost/index.php/home/user/login?var=value` 依然是有效的 PATHINFO模式下面,URL是可定制的,例如,通过下面的配置: ~~~ ~~~ // 更改PATHINFO参数分隔符 'URL_PATHINFO_DEPR'=>'-', ~~~ ~~~ 我们还可以支持下面的URL访问: `http://localhost/index.php/home-user-login-var-value` ### REWRITE模式 **REWRITE模式**是在PATHINFO模式的基础上添加了重写规则的支持,可以去掉URL地址里面的入口文件index.php,但是需要额外配置WEB服务器的重写规则。 如果是Apache则需要在入口文件的同级添加.htaccess文件,内容如下: ~~~ ~~~ <IfModule mod_rewrite.c> RewriteEngine on RewriteCond %{REQUEST_FILENAME} !-d RewriteCond %{REQUEST_FILENAME} !-f RewriteRule ^(.*)$ index.php/$1 [QSA,PT,L] </IfModule> ~~~ ~~~ 接下来,就可以用下面的URL地址访问了: `http://localhost/home/user/login/var/value` > 更多环境的URL重写支持参考部署部分的URL重写。 ### 兼容模式 **兼容模式**是用于不支持PATHINFO的特殊环境,URL地址是: `http://localhost/?s=/home/user/login/var/value` 可以更改兼容模式变量的名称定义,例如: ~~~ ~~~ 'VAR_PATHINFO' => 'path' ~~~ ~~~ PATHINFO参数分隔符对兼容模式依然有效,例如: ~~~ ~~~ // 更改PATHINFO参数分隔符 'URL_PATHINFO_DEPR'=>'-', ~~~ ~~~ 使用以上配置的话,URL访问地址可以变成: `http://localhost/?path=/home-user-login-var-value` 兼容模式配合Web服务器重写规则的定义,可以达到和REWRITE模式一样的URL效果。 例如,我们在Apache下面的话,.htaccess文件改成如下内容: ~~~ ~~~ <IfModule mod_rewrite.c> RewriteEngine on RewriteCond %{REQUEST_FILENAME} !-d RewriteCond %{REQUEST_FILENAME} !-f RewriteRule ^(.*)$ index.php?s=/$1 [QSA,PT,L] </IfModule> ~~~ ~~~ 就可以和REWRITE模式一样访问下面的URL地址访问了: `http://localhost/home/user/login/var/value`