>  기사  >  php教程  >  ThinkPHP3.1 빠른 시작 (1) 기본 사항

ThinkPHP3.1 빠른 시작 (1) 기본 사항

黄舟
黄舟원래의
2016-12-20 11:29:271097검색

소개

ThinkPHP는 MVC 및 객체 지향 기반의 빠르고 간단한 경량 PHP 개발 프레임워크로, 탄생 이후 Apache2 오픈 소스 계약에 따라 출시되었습니다. 뛰어난 성능과 최소한의 코드를 유지하면서도 개발 경험과 사용 편의성에 특별히 주의를 기울였으며 독창적인 기능과 특징이 많아 WEB 애플리케이션 개발을 강력하게 지원합니다.

디렉터리 구조

최신 버전의 ThinkPHP는 공식 홈페이지(http://thinkphp.cn/down/framework.html)나 Github(https://github. com/liu21st/thinkphp /downloads) 다운로드.

다운로드한 압축 파일을 WEB 디렉터리(또는 임의 디렉터리)에 추출합니다. 프레임워크의 디렉터리 구조는 다음과 같습니다.

├─ThinkPHP.php 프레임워크 항목 파일

├ ─공통 프레임워크 공개 파일

├─Conf 프레임워크 구성 파일

├─프레임워크 확장 디렉터리

├─Lang 핵심 언어 패키지 디렉터리

├─ Lib 코어 클래스 라이브러리 디렉터리

│ ├─동작 핵심 동작 클래스 라이브러리

│ ├─Core 코어 기본 클래스 라이브러리

│ ├─드라이버 내장 드라이버

│ │ ├─Cache 내장 캐시 드라이버

│ │ ├─Db 내장 데이터베이스 드라이버

│ │ ├─TagLib 내장 태그 드라이버

│ │ └─ 템플릿 내장 템플릿 엔진 드라이버

│ └─템플릿 내장 템플릿 엔진

└─Tpl 시스템 템플릿 디렉터리

프레임워크의 공개 항목 파일 ThinkPHP.php를 직접 실행할 수 없습니다. 예, 이 파일은 프로젝트 항목 파일에서 호출되어야만 정상적으로 실행될 수 있습니다. (나중에 설명하겠습니다.) 이는 많은 초보자들이 쉽게 범하는 실수입니다.

입력 파일

시작하기 전에 웹 서버와 PHP 실행 환경이 아직 없다면 통합 개발 환경을 사용하는 것이 좋습니다. WAMPServer(Apache, PHP 및 MySQL용 개발 키트를 통합하고 여러 PHP 버전, MySQL 버전 및 Apache 버전 간의 전환을 지원함)는 로컬 개발 및 테스트에 ThinkPHP를 사용합니다.
다음으로, 먼저 WEB 루트 디렉토리(이 앱은 프로젝트 이름) 아래에 app 하위 디렉토리를 생성한 다음 해당 디렉토리 아래에 index.php 파일을 생성하고 간단한 코드 줄을 추가합니다:

< ;?php

require '/ThinkPHP 프레임워크가 위치한 디렉터리/ThinkPHP.php';

이 코드 줄의 기능은 ThinkPHP의 항목 파일 ThinkPHP.php를 로드하는 것입니다. ThinkPHP를 사용한 애플리케이션 개발의 첫 번째 단계를 기반으로 하는 프레임워크입니다.
그런 다음 브라우저에서 이 항목 파일에 액세스합니다.

http://localhost/app/

일반 웹서버의 기본 파일은 index.php이므로 URL 주소에 index.php를 추가할 필요가 없습니다. 실행하면

ThinkPHP3.1 빠른 시작 (1) 기본 사항

가 자동으로 프로젝트 디렉터리를 생성합니다. 디렉터리 구조는 다음과 같습니다.

├─index.php 프로젝트 항목 파일

├─공통 프로젝트 공용 파일 디렉터리

├─Conf 프로젝트 구성 디렉터리

├─Lang 프로젝트 언어 디렉터리

├─Lib 프로젝트 클래스 라이브러리 디렉토리

│ ├─액션 액션 클래스 라이브러리 디렉토리

│ ├─동작 행위 클래스 라이브러리 디렉토리

│ ├─모델 모델 클래스 라이브러리 디렉토리

│ └─Widget 위젯 클래스 라이브러리 디렉터리

├─런타임 프로젝트 런타임 디렉터리

│ ├─캐시 템플릿 캐시 디렉터리

│ ├─데이터 데이터 캐시 디렉터리

│ ├─로그 로그 파일 디렉터리

│ └─임시 임시 캐시 디렉터리

└─Tpl 프로젝트 템플릿 디렉터리

프로젝트의 항목 파일을 이동하려는 경우 앱 디렉토리 외부에 있는 경우 항목 파일 index.php의 내용을

define('APP_NAME','app');

define(' APP_PATH','./app/');

require '/ThinkPHP 프레임워크 디렉터리/ThinkPHP.php';

APP_NAME 및 APP_PATH 구분을 사용하여 프로젝트 이름과 프로젝트 디렉터리를 정의합니다. 프로젝트 이름은 일반적으로 프로젝트의 디렉터리 이름을 나타냅니다.

프로젝트의 엔트리 파일을 이동 및 수정한 후

http://localhost/

를 통해 앱 프로젝트에 접근할 수 있습니다. 물론 웹 루트 디렉터리 아래에 여러 하위 디렉터리를 만들어 여러 프로젝트를 배포할 수도 있습니다.

구성

각 프로젝트에는 독립적인 구성 파일이 있습니다(프로젝트 디렉터리의 Conf/config.php에 위치). 구성 파일의 정의 형식은 배열을 반환하는 PHP 방법을 채택합니다. 예:

/ /프로젝트 구성 파일

return array(

'구성 매개변수' => '구성 값',

// 추가 구성 매개변수

// .. .

);

필요한 경우 프로젝트 구성 파일에 관련 구성 항목을 추가할 수 있습니다. 일반적으로 구성 항목 추가를 언급할 때는 프로젝트 구성 파일에 추가하는 것을 의미합니다.

'구성 매개변수' => '구성 값',

구성 값은 문자열 포함을 지원할 수 있습니다. 숫자, 부울 값 및 배열의 ​​경우 일반적으로 구성 매개변수를 대문자로 정의하는 것이 좋습니다. 필요한 경우 프로젝트에 대한 다른 구성 파일을 정의할 수도 있습니다.

컨트롤러

는 각 모듈에 대한 컨트롤러 클래스를 정의해야 합니다. 컨트롤러 클래스의 명명 규칙은 모듈 이름 + Action.class.php(모듈 이름 사용)입니다. 카멜 표기, 첫 글자는 대문자)
시스템의 기본 모듈은 Index이고, 해당 컨트롤러는 프로젝트 디렉터리 아래 Lib/Action/IndexAction.class.php입니다. 클래스 이름과 파일 이름은 동일합니다. 기본 작업은 컨트롤러의 공개 메서드인 index입니다. 프로젝트 디렉터리 구조를 처음 생성할 때 시스템은 기본적으로 이미 기본 컨트롤러를 생성했습니다(앞서 본 환영 페이지). index 메서드를 다음 코드로 변경합니다.

class IndexAction은 Action을 확장합니다. {

공용 함수 인덱스(){

echo 'hello, world!';

}

}

컨트롤러는 다음을 수행해야 합니다. Action 클래스를 상속받으면 모듈에 여러 작업 메서드가 포함될 수 있습니다. 작업 방법이 protected 또는 private인 경우 URL을 통해 작업에 직접 액세스할 수 없습니다.

URL 요청

항목 파일은 프로젝트의 단일 진입점입니다. 프로젝트에 대한 모든 요청은 프로젝트의 항목 파일로 전달됩니다. URL 매개변수 및 작업에서 현재 요청을 구문 분석하면 이전에 방문한 URL 주소에 매개변수가 없으므로 시스템은 기본 모듈(인덱스)의 기본 작업(인덱스)에 액세스하므로 다음 액세스는 동일합니다. 이전 모드로:

http ://localhost/app/index.php/Index/index

이 URL 모드는 시스템의 기본 PATHINFO 모드입니다. URL 모드마다 획득 방법이 다릅니다. ThinkPHP는 일반 모드, PATHINFO, REWRITE 및 호환 모드의 네 가지 URL 모드를 지원합니다. 일반 모드: 이는 현재 액세스된 모듈 및 작업을 지정하는 전통적인 GET 매개변수 전달 방법입니다. 예:

http://localhost/app/?m=module&a=action&var=value

m 매개변수는 모듈을 나타내고, a 작업은 작업을 나타내며(모듈 및 작업의 URL 매개변수 이름은 구성 가능), 다음은 기타 GET 매개변수를 나타냅니다. PATHINFO 모드: 시스템의 기본 URL 모드로, 최상의 SEO 지원을 제공합니다. 시스템은 이미 내부적으로 환경 호환성 처리를 수행했으므로 대부분의 호스트 환경을 지원할 수 있습니다. 위의 URL 패턴에 대응하여 PATHINFO 패턴 아래의 URL 액세스 주소는

http://localhost/app/index.php/module/action/var/value/

PATHINFO입니다. address 첫 번째 매개변수는 모듈을 나타내고 두 번째 매개변수는 작업을 나타냅니다.
PATHINFO 모드에서 URL은 예를 들어 다음 구성을 통해 사용자 정의할 수 있습니다.

'URL_PATHINFO_DEPR'=>'-', // PATHINFO 매개변수 구분 기호 변경

us 다음 URL 액세스도 지원할 수 있습니다:

http://localhost/app/index.php/module-action-var-value/

REWRITE 모드: PATHINFO 모드 기반 지원 추가 다시 쓰기 규칙의 경우 URL 주소에서 항목 파일 index.php를 제거할 수 있지만 웹 서버의 다시 쓰기 규칙을 추가로 구성해야 합니다.
Apache인 경우 다음 내용을 포함하여 항목 파일과 동일한 수준에 .htaccess 파일을 추가해야 합니다.

RewriteEngine on

RewriteCond %{REQUEST_FILENAME} !-d

RewriteCond %{REQUEST_FILENAME} !-f

RewriteRule ^(.*)$ index.php/$1 [QSA, PT,L]> ;

다음으로, 다음 URL을 사용하여 액세스할 수 있습니다:

http://localhost/app/module/action/var/value/

호환 모드 : PATHINFO를 지원하지 않는 특수 환경에서 사용됩니다. URL 주소는

http://localhost/app/?s=/module/action/var/value/입니다.

호환성 모드 조정 웹 서버 재작성 규칙의 정의는 REWRITE 모드와 동일한 URL 효과를 얻을 수 있습니다.

보기

ThinkPHP에는 기본 PHP 템플릿을 지원하는 컴파일된 템플릿 엔진이 내장되어 있으며 Smarty를 포함한 템플릿 엔진 드라이버도 제공합니다. Smarty와 달리 ThinkPHP는 템플릿을 렌더링할 때 템플릿을 지정하지 않으면 시스템의 기본 위치 지정 규칙을 사용합니다. 따라서 정의 사양은 Tpl/모듈 이름/작업 이름.html입니다. 따라서 인덱스 작업을 위한 기본 템플릿 파일은 다음과 같습니다. Index 모듈은 프로젝트 디렉토리 아래의 Tpl/Index/index.html에 있습니다.
예:

안녕하세요 {$name}

안녕하세요, {$name}님!

뷰를 출력하려면 컨트롤러 메서드 템플릿 렌더링 출력 작업, 예:

class IndexAction extends Action {

public function index(){

$this->name = 'thinkphp'; // 템플릿 변수 할당 수행

$this->display();

}

}

디스플레이에 템플릿을 지정하지 않습니다. 방식이므로 시스템에 따라 기본 규칙은 Index/index.html 템플릿 파일을 출력합니다.
다음으로 브라우저에

http://localhost/app/

을 입력하면 브라우저는
hello, thinkphp!

데이터 읽기

시작하기 전에 먼저 thinkphp 데이터베이스에 think_data 데이터 테이블을 생성합니다(mysql 데이터베이스를 예로 사용).

CREATE TABLE IF NOT EXISTS ` think_data` (

`id` int(8) unsigned NOT NULL AUTO_INCREMENT,

`data` varchar(255) NOT NULL,

PRIMARY KEY(`id`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8 ;

INSERT INTO `think_data` (`id`, `data`) VALUES

(1, 'thinkphp'),

(2, 'php'),

(3, 'framework');

데이터베이스에서 데이터를 읽어야 하는 경우 프로젝트에 추가해야 합니다. 구성 파일 다음과 같이 데이터베이스 연결 정보를 추가합니다.

// 데이터베이스 구성 정보 추가

'DB_TYPE' => 'mysql', // 데이터베이스 유형

'DB_HOST' => ; 'localhost', // 서버 주소

'DB_NAME' => 'thinkphp', // 데이터베이스 이름

'DB_USER' =>

'DB_PWD' => '', // 비밀번호

'DB_PORT' => 3306, // 포트

'DB_PREFIX' => , // 데이터베이스 테이블 접두사

또는 DB_DSN을 사용하여 정의된 다음 구성

'DB_DSN' => 'mysql://root@localhost:3306/thinkphp'

을 사용합니다. 구성 매개변수는 단순화될 수 있습니다. DSN 매개변수 형식은 데이터베이스 유형://사용자 이름:암호@데이터베이스 주소:데이터베이스 포트/데이터베이스 이름입니다. 두 구성 매개변수가 동시에 존재하는 경우 DB_DSN 구성 매개변수가 우선합니다.


다음으로 컨트롤러 메서드를 수정하고 데이터를 읽는 코드를 추가합니다.

class IndexAction extends Action {

public function index(){

       $Data = M('Data'); // 데이터 데이터 모델 인스턴스화

            $this->data = $Data->select();

                           >display() ;

}

}

여기서는 ThinkPHP에 내장된 모델 인스턴스화 방식인 M 함수를 사용하는데, 이를 사용하여 모델을 인스턴스화하는 것은 쉽지 않습니다. M 메소드는 해당 모델 클래스를 생성해야 합니다. M 메소드는 기본 Model 클래스를 직접 작동하고 Model 클래스에는 기본 CURD 작동 메소드가 있음을 이해할 수 있습니다.

M('Data')이 인스턴스화되면 think_data 데이터 테이블에서 작업(CURD 포함)을 수행할 수 있습니다(think_는 프로젝트 구성 파일에서 정의한 데이터 테이블 접두사입니다). M 함수는 다른 용도로 많이 사용됩니다. . 이에 대해서는 나중에 자세히 알아보겠습니다.
컨트롤러를 정의한 후 템플릿 파일을 수정하고 다음과 같이 데이터 출력 태그를 추가합니다.

데이터 선택

{$vo.id}--{$vo.data}

volist 태그는 내장 템플릿 엔진이 데이터 세트를 출력하는 데 사용하는 태그입니다. {$vo.id}와 {$vo.data}의 사용법은 Smarty와 유사하며, 데이터를 출력하는데 사용되는 필드인데, 여기서는 think_data 테이블의 id와 data 필드의 값을 출력한다는 뜻이다. .


http://localhost/app/

에 액세스하면

1--thinkphp

2--php

3--프레임워크

위 출력이 표시되면 축하합니다. ThinkPHP를 시작하기 위한 열쇠를 얻은 것입니다!

요약

이 글에서는 ThinkPHP의 디렉토리 구조, URL 패턴, 프로젝트 항목 파일, 컨트롤러 및 템플릿을 생성하는 방법에 대해 배웠습니다. 데이터에 대한 CURD 작업에 대해 계속해서 알아볼 것입니다. 나중에. .

위 내용은 ThinkPHP3.1 Quick Start(1)의 기본 내용입니다. 더 많은 관련 내용은 PHP 중국어 홈페이지(www.php.cn)를 참고해주세요!


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