본 강좌는 구성 파일 형식(php/ini/json/xml)부터 장면 구성, 모듈 구성, 확장 구성, 독립 구성, 동적 구성, 사용자 정의 구성 로딩, 환경 변수, 파노라마까지 10개의 모듈로 구성되어 있습니다. 다채로운 ThinkPHP5 구성의 세계~~.
더 나은 효과를 보려면 사진을 새 웹페이지에서 열어보세요. 또는 다운로드하여 로컬에서 볼 수도 있습니다. 이 사진은 xmind 마인드맵으로 만든 것입니다. 하단에 xmind 소스 파일 다운로드가 있습니다. xmind 소프트웨어로 여는 것이 더 좋을 것입니다.
1. 마인드맵:
2. 파일 설명:
ThinkPHP5 프레임워크 구성
1 구성 디렉터리
1.1 기본 구성 디렉터리
1.1.1 애플리케이션 구성: 애플리케이션 디렉터리
1.1.2 모듈 구성: 애플리케이션/모듈 디렉터리
1.2 사용자 정의 구성 디렉터리
1.2.1 항목 파일에서: 정의('CONF_PATH', __DIR__.'/../config/');
1.2.2 정의 사용자 정의 구성 파일 디렉터리 및 애플리케이션 디렉터리와 동일한 수준
1.2.3 애플리케이션 구성 파일에는 다음 세 가지가 포함됩니다: config.php/database.php/route.php
1.2. 4 모듈 구성 파일에는 세 가지가 포함됩니다: config.php/database.php
1.2.5 경로는 애플리케이션 초기화 중에 생성되었으므로 모듈에서 Route.php를 구성하지 마십시오
1.3 확장 구성 디렉터리
1.3.1 애플리케이션 또는 모듈 구성 디렉터리 아래에 추가 디렉터리를 생성
1.3.2 추가 디렉터리 아래에 생성되는 구성 파일의 이름은 확장 구성 이름이므로 확장 구성은 모두 2차원 배열입니다
1. 추가 디렉토리에 생성: myconf.php
2 myconf.php 파일에서:
1 2 3 4 | <?php
return [
'site_name'=>'www.php.cn',
];
|
로그인 후 복사
3. 컨트롤러에서 액세스:
1 | dump(\think\Config::get());
|
로그인 후 복사
끝에서 볼 수 있습니다:
1 2 3 | [ "myconf" ] => array (1) {
[ "site_name" ] => string(10) "www.php.cn"
}
|
로그인 후 복사
1.3.3 최종 생성된 확장 구성 항목은 애플리케이션 구성 항목(dump( thinkConfig::get());//View)
2 구성 형식
2.1 배열 형식
2.1.1 이는 기본 형식이므로 항목 파일
2.1에서 CONF_EXT를 구성할 필요가 없습니다. 2 구성 파일: config.php, 내용은 return
1 2 3 4 | <?php
return [
'my_name' => '朱老师',
];
|
로그인 후 복사
에서 반환한 배열입니다. 2.1.3 2차원 배열
1 2 3 4 5 6 7 8 | <?php
return [
'my_info' => [
'my_name' => '朱老师',
'my_age' => 28,
'my_sex' => '男',
],
];
|
로그인 후 복사
로 표현되는 두 가지 구성을 지원합니다. 2.1.4 반환된 콘텐츠는 애플리케이션 구성과 자동으로 병합되어 배열
1 2 3 4 5 | [ "my_info" ] => array (3) {
[ "my_name" ] => string(9) "朱老师"
[ "my_age" ] => int(28)
[ "my_sex" ] => string(3) "男"
}
|
로그인 후 복사
2.2 ini 형식
2.2.1 형식으로 반환됩니다. 항목 파일의 구성 형식: Define('CONF_EXT', '.ini');
1 2 3 4 5 6 7 8 9 | <?php
define('APP_PATH', __DIR__ . '/../application/');
define('CONF_PATH', __DIR__ . '/../config/');
define('CONF_EXT', '.ini');
require __DIR__ . '/../thinkphp/start.php';
|
로그인 후 복사
2.2.2 구성 파일: config.ini 내용이 구성됩니다. 이름-값 쌍은 등호로 연결됩니다.
이름은 헝가리식 명명법을 사용하며 이름과 값은 등호로 연결됩니다. . 값에는 구분 기호가 필요하지 않습니다
1 2 3 4 | config.ini
内容:
my_name=朱老师 ;我的姓名
;my_name是配置名称,朱老师是值,分号后面是该配置项的注释部分,可以省略
|
로그인 후 복사
2.2.3 보조 구성 및 구성 항목을 지원합니다. 대괄호 안에 넣으세요
config.ini의 두 번째 수준 구성 콘텐츠
1 2 3 4 | [base_info]
my_name=朱老师;我的姓名
my_age=28 ;我的年龄
my_sex=男 ;我的性别
|
로그인 후 복사
2.2.4 반환된 콘텐츠는 자동으로 애플리케이션 구성과 병합되어 배열을 형성합니다. 메서드는
을 반환합니다. 🎜>
애플리케이션 구성에서 반환된 결과는 2차원 배열입니다.
1 2 3 4 5 | [ "base_info" ] => array (3) {
[ "my_name" ] => string(9) "朱老师"
[ "my_age" ] => string(2) "28"
[ "my_sex" ] => string(3) "男"
}
|
로그인 후 복사
2.3 xml 형식
2.3 .1 구성 변경 항목 파일의 형식: 정의('CONF_EXT', '.xml');
1 2 3 4 5 6 7 8 9 | <?php
define('APP_PATH', __DIR__ . '/../application/');
define('CONF_PATH', __DIR__ . '/../config/');
define('CONF_EXT', '.xml');
require __DIR__ . '/../thinkphp/start.php';
|
로그인 후 복사
로그인 후 복사
2.3.2 구성 파일: config.xml, 구성 항목은 태그 쌍에 배치되며, 태그 이름은 구성 항목은
1 2 3 4 5 6 7 8 9 10 | < config >
< my_home >安徽省合肥市</ my_home >
</ config >
< abc >
< my_home >安徽省合肥市</ my_home >
</ abc >
|
로그인 후 복사
2.3.3 보조 구성을 지원하며 구성 항목은
1 2 3 4 5 6 | < abc >
< info >
< my_home >安徽省合肥市</ my_home >
< my_work >中文网</ my_work >
</ info >
</ abc >
|
로그인 후 복사
태그 쌍에 배치됩니다. 2.3.4 반환된 콘텐츠는 자동으로 애플리케이션과 병합됩니다. 배열의 구성 반환
애플리케이션 구성에서 반환된 결과는 2차원 배열입니다:
1 2 3 4 | [ "info" ] => array (2) {
[ "my_home" ] => string(18) "安徽省合肥市"
[ "my_work" ] => string(9) "中文网"
}
|
로그인 후 복사
2.4 json 형식
2.4.1 입구에서 파일의 구성 형식을 변경합니다: 정의('CONF_EXT', '.json');
1 2 3 4 5 6 7 8 9 | <?php
define('APP_PATH', __DIR__ . '/../application/');
define('CONF_PATH', __DIR__ . '/../config/');
define('CONF_EXT', '.xml');
require __DIR__ . '/../thinkphp/start.php';
|
로그인 후 복사
로그인 후 복사
2.4.2 구성 파일: config.json, 구성 항목은 다음과 같습니다. json 개체에 배치되며 구성 항목의 이름과 값은 동일한 JavaScript 개체 표현입니다
1 2 3 4 5 | {
"my_name" : "朱老师" ,
"my_age" :28,
"my_sex" : "男"
}
|
로그인 후 복사
특별 참고 사항: 마지막 구성 항목 뒤에 쉼표를 추가하지 마세요
2.4.3 보조 구성을 지원하며 구성 항목은 한 쌍의 태그에 배치됩니다
1 2 3 4 5 6 7 | {
"base_info" :{
"my_name" : "朱老师" ,
"my_age" :28,
"my_sex" : "男"
}
}
|
로그인 후 복사
매우 간단합니다. 모든 구성 위에 레이어 하나를 추가한 다음 현재 데이터를 그것.
2.4.4 반환된 콘텐츠는 자동으로 애플리케이션 구성과 병합되어 배열로 반환됩니다.
1 2 3 4 5 | [ "base_info" ] => array (3) {
[ "my_name" ] => string(9) "朱老师"
[ "my_age" ] => int(28)
[ "my_sex" ] => string(3) "男"
}
|
로그인 후 복사
3장면 구성
3.1 목적: 다양한 환경에서 다양한 구성 항목 사용
3.2 애플리케이션 구성 config.php에서 'app_status'=> 수정 ; '장면 이름',
이 장면 이름은 애플리케이션 구성 디렉터리 아래의 구성 파일에 해당합니다. 구성 파일의 내용은 기본적으로 배열 모드입니다.
예를 들어 집에서 일하면서 사무실과 다른 데이터베이스 연결 매개변수를 사용할 수 있습니다.
그런 다음 먼저
'app_status'=>'home'을 집으로 설정할 수 있습니다
同样,如果你到了公司,要换成公司的数据库,可以在应用配置文件中:
1 2 3 4 5 | <?php
return [
'app_status' => 'office',
];
|
로그인 후 복사
3.3 在应用配置目录下创建与场景名称同名的php文件做为配置文件,以数组方式返回配置项
然后在当前应用配置目录下面创建一个:home.php文件
里面写上如下内容:
实际上就是database.php中的内容复制一份就行。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 | <?php
return [
'type' => 'mysql',
'hostname' => 'localhost',
'database' => 'home',
'username' => 'root_home',
'password' => 'root_home',
'hostport' => '',
'dsn' => '',
'params' => [],
'charset' => 'utf8',
'prefix' => '',
'debug' => true,
'deploy' => 0,
'rw_separate' => false,
'master_num' => 1,
'slave_no' => '',
'fields_strict' => true,
'resultset_type' => ' array ',
'auto_timestamp' => false,
'datetime_format' => 'Y-m-d H:i:s',
'sql_explain' => false,
'builder' => '',
'query' => '\\think\\db\\Query',
];
|
로그인 후 복사
同样,如果你到了公司,要换成公司的数据库,
然后在应用配置目录下创建office.php文件,将数据库配置信息写入,以数据形式返回,就可以了。
4 模块配置
4.1 模块也可以有自己的独立配置:模块名/config.php
4.2 模块配置优先于应用配置,相同配置会覆盖应用配置
4.3 模块也支持场景状态配置,原理与步骤与应用一致
1.创建模块配置文件: application/index/config.php
2. 添加配置项,修改应用状态
1 2 3 4 5 | <?php
return [
'app_status' => 'module_office',
];
|
로그인 후 복사
3.在index模块目录下创建: modult_office.php,做为模块的场景状态配置文件
文件内容也以数据库连接为例:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 | <?php
return [
'type' => 'mysql',
'hostname' => 'localhost',
'database' => 'modult_office',
'username' => 'modult_office',
'password' => 'modult_office',
'hostport' => '',
'dsn' => '',
'params' => [],
'charset' => 'utf8',
'prefix' => '',
'debug' => true,
'deploy' => 0,
'rw_separate' => false,
'master_num' => 1,
'slave_no' => '',
'fields_strict' => true,
'resultset_type' => ' array ',
'auto_timestamp' => false,
'datetime_format' => 'Y-m-d H:i:s',
'sql_explain' => false,
'builder' => '',
'query' => '\\think\\db\\Query',
];
|
로그인 후 복사
4. 保存后,打开浏览器查看,可以看到配置更新结果
5 其它位置的配置文件
5.1 全部在控制器的方法中动态调用Config类中的方法完成手工加载
5.2 用Config::load(配置文件):可以加载任何位置的配置文件,默认Array格式
先在与config目录中创建同级的newconf目录,在该目录下创建conf.php,如果是.php文件,就默认是以数组方式返回配置项,采用Config::load()方法手工动态加载
config/newconf/conf.php文件内容
1 2 3 4 | <?php
return [
'user_define' =>'www.php.cn'
];
|
로그인 후 복사
控制器中的:index/index/中的index方法
1 2 3 4 5 6 7 8 9 10 11 | <?php
namespace app\index\controller;
class Index
{
public function index()
{
\think\Config::load(APP_PATH.'../config/newconf/conf.php');
dump(\think\Config::get());
}
}
|
로그인 후 복사
5.3 如果是其它格式(ini/xml/json)用Config::parse(文件,'类型')来加载
先在与config目录中创建同级的newconf目录,在该目录下创建conf.ini,按框架的约定,不论是什么格式的配置文件,最终必须是以数组方式返回配置项,所以第一步就是要将其它格式的数组,解析成数组,所以就不能再用Config::load()方法了,Config类提供了一个Config::parse()方法来加载其它格式的配置文件,这个方法有二个参数,第一个是要加载的配置文件,第二个就是当前配置文件的格式,如ini,xml或json等
我们以ini格式为例
config/newconf/conf.ini文件内容
1 2 | my_system = mac_os
my_phone = huawei
|
로그인 후 복사
控制器中的:index/index/中的index方法
1 2 3 4 5 6 7 8 9 10 11 | <?php
namespace app\index\controller;
class Index
{
public function index()
{
\think\Config::parse(APP_PATH.'../config/newconf/conf.ini','ini');
dump(\think\Config::get());
}
}
|
로그인 후 복사
5.4 最终与前面一样,都是与应用配置合并后以数组方式返回全部配置项
1 2 | [ "my_system" ] => string(6) "mac_os"
[ "my_phone" ] => string(6) "huawei"
|
로그인 후 복사
6 读取配置项
6.1 方法1:Config::get('参数'),不传入参数则是读取应用的全部配置项
6.2 方法二:作用助手函数config(),不需要导入命名空间直接使用,效率低不推荐
6.3 Config::get('my_info.my_system')方法可以读取二级配置,配置项之间用.点连接
6.4 Config::has(''app_status''):has方法检测某个配置项是否存在,返回布尔值
在控制器中检测:某个配置项是否存在
1 2 3 4 5 6 7 8 9 | <?php
namespace app\index\controller;
class Index
{
public function index()
{
dump(\think\Config::has('app_status'));
}
}
|
로그인 후 복사
6.5 如何用助手函数:config('?配置参数');也返回布尔值
1 2 3 4 5 6 7 8 9 | <?php
namespace app\index\controller;
class Index
{
public function index()
{
dump(config('?app_status'));
}
}
|
로그인 후 복사
7 动态设置参数
7.1 配置项可以写在配置文件,也可以用Config::set()方法动态设置
7.2 Config::set(名称,值),可以逐个设置,也可用数组批量设置:Config::set(数组)
一、名值对方式,逐个设置
1 2 3 4 5 6 7 8 9 10 | <?php
namespace app\index\controller;
class Index
{
public function index()
{
\think\Config::set('site_domain','www.php.cn');
dump(\think\Config::get());
}
}
|
로그인 후 복사
二、数组方式,批量设置
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | <?php
namespace app\index\controller;
use think\Config;
class Index
{
public function index()
{
$config = [
'site_domain' => 'www.php.cn',
'site_name' => 'PHP中文网',
'php_tools' => 'PHP程序员工具箱',
];
Config::set( $config );
dump(Config::get());
}
}
|
로그인 후 복사
7.3 助手函数config(名值对/数组),也可以进行动态设置
将上面的用Config类的代码微微改一下就行,
去掉上面的空间导入
将Config::set()和Config::get()全部换成config()就可了。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | <?php
namespace app\index\controller;
class Index
{
public function index()
{
$config = [
'site_domain' => 'www.php.cn',
'site_name' => 'PHP中文网',
'php_tools' => 'PHP程序员工具箱',
];
config( $config );
dump(config());
}
}
|
로그인 후 복사
8 独立配置文件
8.1 5.0.1以上版本,直接将独立配置文件放在应用或模块的extra目录下即可
自动读取的独配置文件都是二级配置参数,一级配置名称就是扩展配置的文件名。
8.2 默认设置了2个独立配置文件,database.php(数据库配置) 和 validate.php(验证规 则)
8.3 四类默认加载的独立配置文件不用放在extra目录下
8.3.1 应用或者模块配置文件:config.php
8.3.2 数据库配置文件:database.php
8.3.3 行为定义文件:tags.php
8.3.4 场景配置文件:例如home.php,office.php
9 配置参数的作用域
9.1 类似于命名空间,以二维数组方式来收纳参数
9.2 切换作用域: Config::range(),默认值为:_sys_
9.3 可以将扩展配置或独立配置归纳到作用域,或动态设置Config::set()
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 | <?php
namespace app\index\controller;
use think\Config;
class Index
{
public function index()
{
$config = [
'user_name'=>'peter',
'user_age'=>28,
];
Config::set( $config ,'user');
dump(Config::get());
dump(Config::get('user.user_name'));
Config::set('user.user_name','php.cn');
echo '<hr>';
dump(Config::get('user.user_name'));
Config::range('_sys_');
dump(Config::get());
}
}
|
로그인 후 복사
10 系统环境变量配置
10.1 在应用同级目录创建.env文件来模拟系统变量,内容格式为:ini
1 | app_status = office ;配置场景为office
|
로그인 후 복사
10.2 原生方法:获取系统环境变量:$_ENV,getenv(变量名),
10.3 TP提供Env.php类,该类只有一个方法:Env::get(变量名)来获取环境变量
10.4 .env文件不支持非标量,如需使用数组,要用_下划线连接方式进行参数分级设置
注意,环境变量不支持数组参数,如果需要使用数组参数可以,使用下划线分割定义配置参数名:
1 2 3 | database_username = database_password = root 123456
[database] username = password = root 123456
|
로그인 후 복사
10.5 对于数组参数,访问时可以用下划线或者.点语法都可以
获取环境变量的值可以使用下面的两种方式获取:
1 2 3 4 | Env::get('database.username'); Env::get('database.password');
Env::get('database_username');
Env::get('database_password');
|
로그인 후 복사
可以支持默认值,例如:
// 获取环境变量 如果不存在则使用默认值root Env::get('database.username','root');
10.6 环境变量读取优先于应用配置参数,所以可以配置参数中引用环境变量
可以直接在应用配置中使用环境变量,例如:
1 | return [ 'hostname' => Env::get('hostname','127.0.0.1'), ];
|
로그인 후 복사
三、思维导图下载:
框架配置.zip
위 내용은 ThinkPHP5 프레임워크 그림(4): 프레임워크 구성을 한 장의 그림으로 완벽하게 이해(최종 버전)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!