zoukankan      html  css  js  c++  java
  • ThinkPHP的四种URL模式 URL_MODEL

    ThinkPHP支持四种URL模式,可以通过设置URL_MODEL参数来定义,包括普通模式、PATHINFO、REWRITE和兼容模式。

    普通模式 设置URL_MODEL 为0
    采用传统的URL参数模式
    http://serverName/appName/?m=module&a=action&id=1

    PATHINFO模式 设置URL_MODEL 为1
    默认情况使用URL_PATHINFO模式,ThinkPHP内置强大的PATHINFO支持,提供灵活和友好URL支持。PATHINFO模式还包括普通模式和智能模式两种:
    普通模式 设置PATH_MODEL 参数为1
    该模式下面URL参数没有顺序,例如
    http://serverName/appName/m/module/a/action/id/1
    http://serverName/appName/a/action/id/1/m/module
    以上URL等效

    智能模式 设置PATH_MODEL 参数为2 (系统默认的模式)
    自动识别模块和操作,例如
    http://serverName/appName/module/action/id/1/  或者
    http://serverName/appName/module,action,id,1/
    在智能模式下面,第一个参数会被解析成模块名称(或者路由名称,下面会有描述),第二个参数会被解析成操作(在第一个参数不是路由名称的前提下),后面的参数是显式传递的,而且必须成对出现,例如:
    http://serverName/appName/module/action/year/2008/month/09/day/21/
    其中参数之间的分割符号由PATH_DEPR参数设置,默认为"/",例如我们设置PATH_DEPR为"^"的话,就可以使用下面的URL访问:
    http://serverName/appName/module^action^id^1/
    注意不要使用"@" 和"&"符号进行分割,该符号有特殊用途,可能会导致其他的冲突。
    略加修改,就可以展示出富有诗意的URL,呵呵~
    如果想要简化URL的形式可以通过路由功能(后面会有描述),在PATH_INFO模式下面,会把相关参数转换成GET变量,以及并入REQUEST变量,因此不妨碍应用里面的以上变量获取。

    REWRITE模式 设置URL_MODEL 为2
    该URL模式和PATHINFO模式功能一样,除了可以不需要在URL里面写入口文件,和可以定义.htaccess 文件外。
    例如,我们可以增加如下的.htaccess内容把所有操作都指向index.php文件。

    RewriteEngine on
    RewriteCond %{REQUEST_FILENAME} !-d
    RewriteCond %{REQUEST_FILENAME} !-f
    RewriteRule ^(.*)$ index.php/$1 [QSA,PT,L]

    兼容模式 设置URL_MODEL 为3
    兼容模式是普通模式和PATHINFO模式的结合,并且可以让应用在需要的时候直接切换到PATHINFO模式而不需要更改模板和程序,基本上可以支持任何的运行环境。
    只需要传入PATHINFO 兼容模式获取变量VAR_PATHINFO,默认值为s,例如
    http://serverName/appName/?s=/module/act

    ion/id/1/ 
    会执行和上面的URL等效的操作,并且也可以支持参数分割符号的定义,例如在PATH_DEPR设置为"~"的情况下,下面的URL有效:
    http://serverName/appName/?s=module~action~id~1
    兼容模式的情况下面模板文件不用做任何更改,保持和PATHINFO模式的写法一样,只需要在切换URL模式的时候清空下模板缓存目录。

  • 相关阅读:
    asp.net导出数据到execl并保存到本地 不需要调用Office组件
    动态创建DataTable,GridView创建多表头,表头跨行或跨列合并,创建计算列及列内容自适应等
    Oracle内置SQL函数收集整理大全
    无比强大的GridView,表头固定,表体有滚动条可滚动
    很不错的asp.net文件上传类c# 搜索文件 移动文件 删除文件等
    【备用】非常不错的ASP操作数据库类,支持多数据库MSSQL,ACCESS,ORACLE,MYSQL等
    Asp.Net读取Execl常见问题收集
    经常用到的交叉表问题,一般用动态SQL能生成动态列
    C# asp.net中常见的字符串处理函数及数字格式化
    比较两个DataTable中不同的记录,且合并两个DataTable的列显示,有图
  • 原文地址:https://www.cnblogs.com/ZDPPU/p/5853475.html
Copyright © 2011-2022 走看看