在我们的开发过程中,我们可能会对项目进行定制,使项目开发更符合我们的开发习惯。很多常用的设置ThinkPHP都内置了,我们只需要在配置文件中定义就可以了。今天给大家分享一些ThinkPHP的参考配置。
图片来自互联网
配置文件
ThinkPHP中有N 1个配置文件,其中N是指项目下的模块数量,如上图所示。因此,Application\Common\conf下的config.php是全局配置文件,Application\Home\Conf下的config.php是模块配置文件。ThinkPHP会先读取全局配置,再读取模块配置。如果模块配置与全局配置冲突,模块配置将覆盖全局配置中的不同配置信息。
图片来自互联网
1.应用程序设置
APP_USE_NAMESPACE'=true,//应用类库是否使用命名空间?
' App _ sub _ domain _ deploy'=false。//要打开子域部署吗?
App _ sub _ domain _ rules'=array(),//子域部署规则
APP_DOMAIN_SUFFIX'=' ',//如果是com.cn net.cn这样的后缀,必须设置域名后缀。
ACTION_SUFFIX'=' ',//操作方法后缀
MULTI_MODULE'=true,//允许多个模块。如果为false,则必须设置DEFAULT_MODULE。
module _ deny _ list '=array(' common ',' runtime '),//禁用模块的列表
MODULE_ALLOW_LIST'=array(),//允许访问的模块列表
控制器级别'=1,
app _ autoload _ layer '=' controller,model ',//自动加载应用类库层(为非命名空间定义的类库)
APP_AUTOLOAD_PATH'=' ',//自动加载的路径(为非命名空间定义的类库)
2.设置默认值
DEFAULT_M_LAYER'='Model ',//默认的模型层名称
Default _ c _ layer'=' controller ',//默认的控制器层名称
DEFAULT_V_LAYER'='View ',//默认的视图层名称
DEFAULT_LANG'='zh-cn ',//默认语言
DEFAULT_THEME'=' ',//默认模板主题名称
DEFAULT_MODULE'='Home ',//默认模块
DEFAULT_CONTROLLER'='Index ',//默认控制器名称
DEFAULT_ACTION'='index ',//默认操作名称
DEFAULT_CHARSET'='utf-8 ',//默认输出编码
DEFAULT_TIMEZONE'='PRC ',//默认时区
DEFAULT_AJAX_RETURN'='JSON ',//默认AJAX数据返回格式,可选JSON XML
default _ JSONP _ handler '=' JSONP return ',//默认JSONP格式返回的处理方法
default _ filter '=' HTMLSPECIALCHARS ',//I函数使用默认的参数过滤方法
3.cookie设置
COOKIE_EXPIRE'=0,//Cookie有效期
COOKIE_DOMAIN'=' ',//Cookie是有效的域名
COOKIE_PATH'='/',//Cookie路径
COOKIE_PREFIX'=' ',//Cookie前缀以避免冲突
COOKIE_HTTPONLY'='
', // Cookie的httponly属性 3.2.2新增4.数据库设置
'DB_TYPE' => '', // 数据库类型
'DB_HOST' => '', // 服务器地址
'DB_NAME' => '', // 数据库名
'DB_USER' => '', // 用户名
'DB_PWD' => '', // 密码
'DB_PORT' => '', // 端口
'DB_PREFIX' => '', // 数据库表前缀
'DB_FIELDS_CACHE' => true, // 启用字段缓存
'DB_CHARSET' => 'utf8', // 数据库编码默认采用utf8
'DB_DEPLOY_TYPE' => 0, // 数据库部署方式:0 集中式(单一服务器),1 分布式(主从服务器)
'DB_RW_SEPARATE' => false, // 数据库读写是否分离 主从式有效
'DB_MASTER_NUM' => 1, // 读写分离后 主服务器数量
'DB_SLAVE_NO' => '', // 指定从服务器序号
'DB_BIND_PARAM' => false, // 数据库写入数据自动参数绑定
'DB_DEBUG' => false, // 数据库调试模式
'DB_LITE' => false, // 数据库Lite模式
5.数据缓存设置
'DATA_CACHE_TIME' => 0, // 数据缓存有效期 0表示永久缓存
'DATA_CACHE_COMPRESS' => false, // 数据缓存是否压缩缓存
'DATA_CACHE_CHECK' => false, // 数据缓存是否校验缓存
'DATA_CACHE_PREFIX' => '', // 缓存前缀
'DATA_CACHE_TYPE' =>'File',// 数据缓存类型,支持:File|Db|Apc|Memcache|Shmop|Sqlite|Xcache|Apachenote|Eaccelerator
'DATA_CACHE_PATH' => TEMP_PATH,// 缓存路径设置 (仅对File方式缓存有效)
'DATA_CACHE_SUBDIR' => false, // 使用子目录缓存 (自动根据缓存标识的哈希创建子目录)
'DATA_PATH_LEVEL' => 1, // 子目录缓存级别
图片来自网络
6.错误设置
'ERROR_MESSAGE' => '页面错误!请稍后再试~',//错误显示信息,非调试模式有效
'ERROR_PAGE' => '', // 错误定向页面
'SHOW_ERROR_MSG' => false, // 显示错误信息
'TRACE_MAX_RECORD' => 100, // 每个级别的错误信息 最大记录数
7.日志设置
'LOG_RECORD' => false, // 默认不记录日志
'LOG_TYPE' => 'File', // 日志记录类型 默认为文件方式
'LOG_LEVEL' => 'EMERG,ALERT,CRIT,ERR',// 允许记录的日志级别
'LOG_EXCEPTION_RECORD' => false, // 是否记录异常信息日志
8.SESSION设置
'SESSION_AUTO_START' => true, // 是否自动开启Session
'SESSION_OPTIONS' => array(), // session 配置数组 支持type name id path expire domain 等参数
'SESSION_TYPE' => '', // session hander类型 默认无需设置 除非扩展了session hander驱动
'SESSION_PREFIX' => '', // session 前缀
9.模板引擎设置
'TMPL_CONTENT_TYPE' => 'text/html', // 默认模板输出类型
'TMPL_ACTION_ERROR' => THINK_PATH.'Tpl/dispatch_jump.tpl', // 默认错误跳转对应的模板文件
'TMPL_ACTION_SUCCESS' => THINK_PATH.'Tpl/dispatch_jump.tpl', // 默认成功跳转对应的模板文件
'TMPL_EXCEPTION_FILE' => THINK_PATH.'Tpl/think_exception.tpl',// 异常页面的模板文件
'TMPL_DETECT_THEME' => false, // 自动侦测模板主题
'TMPL_TEMPLATE_SUFFIX' => '.html', // 默认模板文件后缀
'TMPL_FILE_DEPR' => '/', //模板文件CONTROLLER_NAME与ACTION_NAME之间的分割符
'TMPL_ENGINE_TYPE' => 'Think', // 默认模板引擎 以下设置仅对使用Think模板引擎有效
'TMPL_CACHFILE_SUFFIX' => '.php', // 默认模板缓存后缀
'TMPL_DENY_FUNC_LIST' => 'echo,exit', // 模板引擎禁用函数
'TMPL_DENY_PHP' => false, // 默认模板引擎是否禁用PHP原生代码
'TMPL_L_DELIM' => '{', // 模板引擎普通标签开始标记
'TMPL_R_DELIM' => '}', // 模板引擎普通标签结束标记
'TMPL_VAR_IDENTIFY' => 'array', // 模板变量识别。留空自动判断,参数为'obj'则表示对象
'TMPL_STRIP_SPACE' => true, // 是否去除模板文件里面的html空格与换行
'TMPL_CACHE_ON' => true, // 是否开启模板编译缓存,设为false则每次都会重新编译
'TMPL_CACHE_PREFIX' => '', // 模板缓存前缀标识,可以动态改变
'TMPL_CACHE_TIME' => 0, // 模板缓存有效期 0 为永久,(以数字为值,单位:秒)
'TMPL_LAYOUT_ITEM' => '{__CONTENT__}', // 布局模板的内容替换标识
'LAYOUT_ON' => false, // 是否启用布局
'LAYOUT_NAME' => 'layout', // 当前布局名称 默认为layout
10.URL设置
'URL_CASE_INSENSITIVE' => true, // 默认false 表示URL区分大小写 true则表示不区分大小写
'URL_MODEL' => 1, // URL访问模式,可选参数0、1、2、3,代表以下四种模式:
// 0 (普通模式); 1 (PATHINFO 模式); 2 (REWRITE 模式); 3 (兼容模式) 默认为PATHINFO 模式
'URL_PATHINFO_DEPR' => '/', // PATHINFO模式下,各参数之间的分割符号
'URL_PATHINFO_FETCH' => 'ORIG_PATH_INFO,REDIRECT_PATH_INFO,REDIRECT_URL', // 用于兼容判断PATH_INFO 参数的SERVER替代变量列表
'URL_REQUEST_URI' => 'REQUEST_URI', // 获取当前页面地址的系统变量 默认为REQUEST_URI
'URL_HTML_SUFFIX' => 'html', // URL伪静态后缀设置
'URL_DENY_SUFFIX' => 'ico|png|gif|jpg', // URL禁止访问的后缀设置
'URL_PARAMS_BIND' => true, // URL变量绑定到Action方法参数
'URL_PARAMS_BIND_TYPE' => 0, // URL变量绑定的类型 0 按变量名绑定 1 按变量顺序绑定
'URL_404_REDIRECT' => '', // 404 跳转页面 部署模式有效
'URL_ROUTER_ON' => false, // 是否开启URL路由
'URL_ROUTE_RULES' => array(), // 默认路由规则 针对模块
'URL_MAP_RULES' => array(), // URL映射定义规则
11.系统变量名称设置
'VAR_MODULE' => 'm', // 默认模块获取变量
'VAR_CONTROLLER' => 'c', // 默认控制器获取变量
'VAR_ACTION' => 'a', // 默认操作获取变量
'VAR_AJAX_SUBMIT' => 'ajax', // 默认的AJAX提交变量
'VAR_JSONP_HANDLER' => 'callback',
'VAR_PATHINFO' => 's', // 兼容模式PATHINFO获取变量例如 ?s=/module/action/id/1 后面的参数取决于URL_PATHINFO_DEPR
'VAR_TEMPLATE' => 't', // 默认模板切换变量
'VAR_ADDON' => 'addon', // 默认的插件控制器命名空间变量
12.其他设置
'HTTP_CACHE_CONTROL' => 'private', // 网页缓存控制
'CHECK_APP_DIR' => true, // 是否检查应用目录是否创建
'FILE_UPLOAD_TYPE' => 'Local', // 文件上传方式
'DATA_CRYPT_TYPE' => 'Think', // 数据加密方式