>백엔드 개발 >PHP 튜토리얼 >상세한 thinkPHP5.0 프레임워크 모듈 설계

상세한 thinkPHP5.0 프레임워크 모듈 설계

黄舟
黄舟원래의
2017-03-20 09:09:491836검색

이 글에서는 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\User
URL 라우팅 기능을 통해 더 많은 URL 단순화 및 사용자 정의도 가능합니다.

위 내용은 상세한 thinkPHP5.0 프레임워크 모듈 설계의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.