zoukankan      html  css  js  c++  java
  • thinkphp 模块部署

    3.2对模块的访问是自动判断的,所以通常情况下无需配置模块列表即可访问,在部署模块的时候,默认情况下都是基于类似于子目录的URL方式来访问模块的,例如:

    1. http://serverName/Home/New/index //访问Home模块
    2. http://serverName/Admin/Config/index //访问Admin模块
    3. http://serverName/User/Member/index //访问User模块

    允许模块列表

    如果直接访问:http://serverName/New/index 会报错,不过通过下面的设置可以把Home模块的访问URL地址简化:

    1. // 允许访问的模块列表
    2. 'MODULE_ALLOW_LIST' => array('Home','Admin','User');
    3. 'DEFAULT_MODULE' => 'Home', // 默认模块

    这个时候再次访问 http://serverName/New/index 就不会报错了,并且实际访问的就是Home模块。默认情况下,MODULE_ALLOW_LIST 为空,表示允许任何模块的访问,不过最终是否允许访问还受 MODULE_DENY_LIST 参数的影响。

    域名绑定的模块不受MODULE_ALLOW_LIST的影响

    禁止模块访问

    如果你的应用有很多的模块,你只是想禁止访问个别模块的话,可以配置禁止访问的模块列表(用于被其他模块调用或者不开放访问),默认配置中是禁止访问Common模块和Runtime模块(Runtime目录是默认的运行时目录),我们可以增加其他的禁止访问模块列表:

    1. // 设置禁止访问的模块列表
    2. 'MODULE_DENY_LIST' => array('Common','Runtime','User'),

    这个时候,我们再访问 http://serverName/User/Member/index 的话,就会报错。

    域名绑定的模块同样不受MODULE_DENY_LIST影响

    大理石平台检验标准

    模块映射

    如果不希望用户直接访问某个模块,可以设置模块映射(对后台的保护会比较实用)。

    1. 'URL_MODULE_MAP' => array('test'=>'admin'),

    注意:设置了模块映射后,原来的Admin模块将不能访问,只能访问test模块。

    我们访问 http://serverName/Admin将会报模块不存在的错误,而 http://serverName/test 则可以正常访问Admin模块。

    如果你同时还设置了MODULE_ALLOW_LIST参数的话,必须将允许模块列表中的原来的模块改成映射后的模块名,例如:

    1. 'MODULE_ALLOW_LIST' => array('Home','Test','User'),
    2. 'DEFAULT_MODULE' => 'Home',
    3. 'URL_MODULE_MAP' => array('test'=>'admin'),

    模块映射的模块必须使用小写定义

  • 相关阅读:
    网页安装ipa
    windows开通https服务
    Asp.Net上传大文件带进度条swfupload
    Asp.Net采集网页方法大全(5种)
    asp.net上传大文件-请求筛选模块被配置为拒绝超过请求内容长度的请求
    在IIS服务器上屏蔽IP的访问
    网络广告CPS/CPC/CPV/CPM/CPA分别是什么意思
    Asp.Net判断字符是否为汉字的方法大全
    Asp.Net使用代理IP远程获取数据
    Asp.Net保存session的三种方法
  • 原文地址:https://www.cnblogs.com/furuihua/p/11849761.html
Copyright © 2011-2022 走看看