이 글에서는 thinkPHP5.0프레임워크모듈 설계를 주로 소개하고, thinkPHP5.0디렉토리 구조, 명명 규칙 및 분석을 형식으로 간략하게 설명합니다. 예제 중 클래스 라이브러리 의 원리와 접근 방법이 설명되어 있습니다. 필요한 친구들은
을 참고하세요. 이 글은 thinkPHP5.0 프레임워크 모듈 설계를 예시로 설명합니다. 참고하실 수 있도록 자세한 내용은 다음과 같습니다.
버전 5.0은 모듈 기능에 맞게 유연하게 설계되었으며 기본적으로 다중 모듈 아키텍처를 채택하고 단일 모듈 설계를 지원합니다. 모든 모듈의 네임스페이스둘 다 루트 네임스페이스로 app을 갖습니다(구성 가능하게 변경 가능).
디렉토리 구조
표준 애플리케이션 및 모듈 디렉토리 구조는 다음과 같습니다.
├─application 应用目录(可设置) │ ├─common 公共模块目录(可选) │ ├─common.php 公共函数文件 │ ├─route.php 路由配置文件 │ ├─database.php 数据库配置文件 │ ├─config.php 应用配置文件 │ ├─module1 模块1目录 │ │ ├─config.php 模块配置文件 │ │ ├─common.php 模块函数文件 │ │ ├─controller 控制器目录 │ │ ├─model 模型目录 │ │ ├─view 视图目录 │ │ └─ ... 更多类库目录 │ │ │ ├─module2 模块2目录 │ │ ├─config.php 模块配置文件 │ │ ├─common.php 模块函数文件 │ │ ├─controller 控制器目录 │ │ ├─model 模型目录 │ │ ├─view 视图目录 │ │ └─ ... 更多类库目录
ThinkPHP5.0의 명명 규칙을 따르며, 모듈은 디렉토리는 모두 소문자와 밑줄 이름을 사용합니다.
모듈 이름에 PHP 예약어를 사용하지 마세요(예약어 목록은 http://php.net/manual/zh/reserved.keywords.php 참조). 그렇지 않으면 시스템 오류가 발생합니다.
공통 모듈은 기본적으로 직접 접근이 금지된 특수 모듈로, 일반적으로 다른 모듈의 상속을 위해 일부 공용 클래스 라이브러리를 배치하는 데 사용됩니다. .
모듈 클래스 라이브러리
모듈 아래 클래스 라이브러리 파일의 네임스페이스는 동일하게 앱 모듈 이름으로 시작합니다. 예:
// index模块的Index控制器类 app\index\controller\Index // index模块的User模型类 app\index\model\User
여기서 app은 정의에 따라 이를 변경할 수 있습니다. 예를 들어 애플리케이션 구성 파일에서 이를 수정합니다.
'app_namespace' => 'application',
그런 다음 인덱스 모듈의 클래스 라이브러리 네임스페이스는 다음과 같습니다.
// index模块的Index控制器类 application\index\controller\Index // index模块的User模型类 application\index\model\User
클래스 라이브러리에 대한 자세한 내용과 naming 공백 간의 관계에 대해서는 이전 글 "ThinkPHP5.0 Framework Namespace 상세 설명"을 참고하시기 바랍니다.
모듈 및 컨트롤러 숨기기
다중 모듈 지원이 기본적으로 채택되므로 모듈이 여러 개인 경우 현재 모듈을 URL 주소에서 식별해야 합니다. 모듈의 경우 애플리케이션의 공개 파일에 다음 코드를 추가하여 모듈 바인딩을 수행할 수 있습니다.
// 绑定当前访问到index模块 \think\Route::bind('index');
바인딩 후 URL 액세스 주소는
http://serverName/index.php/控制器/操作/[参数名/参数值...]
가 됩니다. 모듈은 인덱스 모듈입니다.
애플리케이션이 비교적 간단하고 모듈과 컨트롤러가 하나만 있는 경우 다음과 같이 애플리케이션 공개 파일에 모듈과 컨트롤러를 바인딩할 수 있습니다.
// 绑定当前访问到index模块的index控制器 \think\Route::bind('index/index');
설정 후, URL 액세스 주소는 다음과 같습니다.
http://serverName/应用入口/操作/[参数名/参数值...]
액세스된 모듈은 인덱스 모듈이고 컨트롤러는 인덱스 컨트롤러입니다.
단일 모듈
애플리케이션이 상대적으로 간단하고 모듈이 하나만 있는 경우 다음과 같이 단일 모듈 구조를 사용하여 더욱 단순화할 수 있습니다. 🎜 >
먼저 애플리케이션 구성 파일에서 정의합니다:// 关闭多模块设计 'app_multi_module' => false,그런 다음 애플리케이션 디렉터리의 구조를 다음과 같이 조정합니다.
├─application 应用目录(可设置) │ ├─controller 控制器目录 │ ├─model 模型目录 │ ├─view 视图目录 │ ├─ ... 更多类库目录 │ ├─common.php 函数文件 │ ├─route.php 路由配置文件 │ ├─database.php 数据库配置文件 │ └─config.php 配置文件URL 액세스 주소는
http://serverName/index.php(或者其它应用入口)/控制器/操作/[参数名/参数值...]동시에 단일 모듈 설계에 따른 애플리케이션 클래스 라이브러리의 네임스페이스도 조정되었습니다. 예를 들어
원래
app\index\controller\Index app\index\model\User
가
app\controller\Index app\model\UserURL 라우팅 기능을 통해 더 많은 URL 단순화 및 사용자 정의도 가능합니다.
위 내용은 상세한 thinkPHP5.0 프레임워크 모듈 설계의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!