laravel Framework은 네트워크 서비스부터 데이터베이스 관리, HTML 생성까지 모든 것을 처리하기 때문에 "풀 스택" 프레임워크라고 합니다. 수직적으로 통합된 웹 개발 환경은 개발자에게 더 나은 경험을 제공할 수 있습니다.
일반적인 프로그래머는 명령줄 도구를 통해 Laravel과 상호 작용하여 Laravel 프로젝트 환경을 생성하고 관리합니다. Laravel에는 프레임워크 코드와 데이터베이스 스키마를 생성하는 데 사용할 수 있는 Artisan이라는 뛰어난 명령줄 도구가 함께 제공됩니다. Artisan은 데이터베이스 스키마 마이그레이션부터 리소스 및 구성 관리까지 모든 것을 처리할 수 있습니다. Laravel의 흥미로운 기능 중 하나는 웹 애플리케이션을 구축하는 방법에 몇 가지 심각한 제한 사항이 있다는 것입니다. 놀랍게도 이러한 제한으로 인해 애플리케이션을 훨씬 쉽게 만들 수 있습니다. 그 이유를 살펴보겠습니다.
Laravel은 구성보다 규칙을 더 선호한다는 점에서 다른 수직 통합 개발 환경과 다릅니다. 일부 Java, Python 또는 PHP 프레임워크에는 많은 XML 구성이 필요한 경우가 많지만 Laravel은 시작하는 데 구성이 거의 필요하지 않습니다(PHP에서는 몇 줄만 필요할 수도 있음). 이러한 구성 파일 회피는 이 파일을 매우 독특하게 만들고 인식 가능한 코드 구조는 모든 Laravel 애플리케이션에서 동일합니다. 모든 것을 지배하는 하나의 프로젝트 구조!
모든 Laravel 프로젝트는 기본적으로 동일한 디렉토리 구조를 가지고 있다는 것은 놀라운 일이 아닙니다. 모든 파일은 지정된 위치를 가지고 있습니다. 이렇게 합의된 디렉터리 결과를 통해 개발자는 "Laravel 방식"에 따라 작업할 수 있습니다.
그림 1.1은 Laravel 프로젝트 디렉토리 구조를 보여줍니다.
보시다시피, laravel에는 이 4개 폴더 아래에 일부 하위 폴더가 있습니다. 이렇게 풍부한 하위 폴더를 처음 보셨나요? 하나씩 소개하겠습니다. 대부분의 개발 작업은 app/ 폴더에서 수행됩니다.
각 폴더 및 파일에 대한 기본 소개는 다음과 같습니다. 레벨 폴더
Function
#🎜 🎜 ## 🎜🎜#
app
사이트의 컨트롤러(controllers), 모델(models), 보기(views) 및 자산( 의지). 이는 웹사이트를 실행하는 주요 코드 조각이며 대부분의 시간을 여기에 보내게 됩니다.
| bootstrap#🎜 🎜 # 사용 시스템 시작 시 필요한 파일을 저장하기 위해 이러한 파일은 index.php와 같은 파일에서 호출됩니다. |
public |
this 폴더는 외부 세계에 표시되는 유일한 폴더이며 웹 서버의 디렉터리를 가리켜야 합니다. 여기에는 laravel 프레임워크의 핵심 부팅 파일인 index.php가 포함되어 있습니다. 이 디렉터리는 CSS, Javascript, 이미지 등과 같은 공개 정적 리소스를 저장하는 데에도 사용할 수 있습니다. 일반적인 Laravel 애플리케이션에 모든 타사 코드를 수용하기 위해 여기에는 Laravel 소스 코드와 추가 사전 패키지 기능이 포함된 관련 플러그인이 포함됩니다. |
위에서 언급했듯이 /app은 모든 재미가 일어나는 곳입니다. 이 디렉토리의 구조를 더 자세히 살펴보겠습니다.
그림 1.2는 /app 폴더의 세부 정보를 보여줍니다.
그림 1.2 앱 폴더 세부 정보
다음은 자세한 소개입니다.
파일의 파일 폴더 | 기능 |
/app/config/ |
애플리케이션의 런타임 규칙, 데이터베이스, 세션 등을 구성합니다. 프레임워크의 다양한 측면을 변경하기 위한 여러 구성 파일이 포함되어 있습니다. 구성 파일에 반환된 대부분의 옵션은 PHP 배열과 연결되어 있습니다. |
/app/config/app.php |
영역, 로케일(로케일), 디버그 모드 및 고유 암호화 키와 같은 다양한 애플리케이션 수준 설정. |
/app/config/auth.php |
은 애플리케이션, 즉 인증 드라이버에서 인증이 수행되는 방식을 제어합니다. |
/app/config/cache.php |
애플리케이션이 응답 시간을 단축하기 위해 캐싱을 사용하는 경우 여기에서 해당 기능을 구성하세요. |
/app/config/compile.php |
여기에서 'artisanoptim' 명령으로 요청한 컴파일된 파일을 포함하도록 몇 가지 추가 클래스를 지정할 수 있습니다. 이는 기본적으로 애플리케이션에 대한 모든 요청에 포함되는 클래스여야 합니다. |
/app/config/database.php |
에는 데이터베이스의 관련 구성 정보, 즉 기본 데이터베이스 엔진 및 연결 정보가 포함되어 있습니다. |
/app/config/mail.php |
은 이메일 전송 엔진, 즉 SMTP 서버의 구성 파일입니다. From: 헤더 |
/app/ config/ session.php |
은 Laravel이 사용자 세션, 즉 세션 드라이버, 세션 수명을 관리하는 방법을 제어합니다. |
/app/config/view.php |
템플릿 시스템의 기타 구성. |
/app/controllers |
에는 기본 논리, 데이터 모델 상호 작용 및 애플리케이션의 보기 파일 로드를 제공하는 컨트롤러 클래스가 포함되어 있습니다. |
/app/database/migrations/ |
에는 Laravel이 현재 데이터베이스의 스키마를 업데이트하고 데이터베이스의 모든 버전을 동시에 동기화할 수 있도록 하는 일부 PHP 클래스가 포함되어 있습니다. 마이그레이션 파일은 Artisan 도구를 사용하여 생성됩니다. |
/app/database/seeds/ |
에는 Artisan 도구가 데이터베이스 테이블을 관계형 데이터로 채울 수 있도록 하는 PHP 파일이 포함되어 있습니다. |
/app/lang/ |
애플리케이션을 쉽게 지역화할 수 있게 해주는 문자열 배열이 포함된 PHP 파일입니다. 기본적으로 디렉토리에는 영어에 대한 페이징 및 양식 유효성 검사를 위한 언어 줄이 포함되어 있습니다. |
/app/models/ |
모델은 애플리케이션의 정보(데이터)와 데이터 운영 규칙을 나타내는 클래스입니다. 대부분의 경우 데이터베이스의 각 테이블은 애플리케이션의 모델에 해당합니다. 애플리케이션 비즈니스 로직의 대부분은 모델에 집중됩니다. |
/app/start/ |
Artisan 도구와 글로벌 및 로컬 컨텍스트와 관련된 사용자 정의 설정이 포함되어 있습니다. |
/app/storage/ |
이 디렉토리는 세션, 캐시, 컴파일된 뷰 템플릿과 같은 다양한 Laravel 서비스를 위한 임시 파일을 저장합니다. 이 디렉토리는 웹 서버에 쓸 수 있어야 합니다. 이 디렉토리는 Laravel에 의해 관리되며 우리는 상관하지 않습니다. |
/app/tests/ |
이 폴더는 단위 테스트를 수행하기 위한 편리한 위치를 제공합니다. PHPUnit을 사용하는 경우 Artisan 도구를 사용하여 모든 테스트를 한 번에 실행할 수 있습니다. |
/app/views/ |
이 폴더에는 컨트롤러 또는 경로에서 사용하는 HTML 템플릿이 포함되어 있습니다. 이 폴더에는 템플릿 파일만 저장할 수 있습니다. CSS, 자바스크립트, 이미지 파일과 같은 기타 정적 리소스 파일은 /public 폴더에 배치되어야 합니다. |
/app/routes.php |
이것은 들어오는 요청을 클로저, 컨트롤러 및 경로에서 처리하는 작업에 연결하는 방법을 Laravel에 알려주는 라우팅 규칙을 포함하는 애플리케이션의 라우팅 파일입니다. 파일에는 오류 페이지에 대한 선언을 포함하여 보기 작성기를 정의하는 데 사용할 수 있는 여러 이벤트 선언도 포함되어 있습니다. |
/app/filters.php |
이 파일에는 애플리케이션 결과를 변경하는 데 사용할 수 있는 다양한 애플리케이션 및 경로 필터링 방법이 포함되어 있습니다. Laravel에는 액세스 제어 및 XSS 보호를 위해 미리 정의된 필터가 있습니다.
|
폴더를 만들고 이름을 지정하는 데 많은 고민을 했고, 그 결과 파일 시스템이 좋은 애플리케이션이 탄생했습니다.
얻을 수 있는 것: MVC Laravel 애플리케이션이 작동하는 방식에 대한 높은 수준의 개요를 살펴보겠습니다. 표준 Laravel 애플리케이션 구조는 세 개의 하위 디렉터리인 models/, views/ 및 Controllers/를 포함하는 애플리케이션 디렉터리 app/로 구성되어 있음을 알 수 있습니다. 이는 Laravel이 그래픽 사용자 인터페이스(GUI)로부터 논리적 관계를 표시하기 위해 "비즈니스 로직" 입력을 분리하도록 강제하는 MVC(모델-뷰-컨트롤러) 아키텍처 패턴을 따른다는 것을 보여줍니다. Laravel 웹 애플리케이션의 경우 비즈니스 로직은 일반적으로 사용자, 블로그 게시물 등과 같은 데이터 모델로 구성됩니다. GUI는 브라우저의 웹 페이지일 뿐입니다. MVC 디자인 패턴은 웹 개발 분야에서 매우 인기가 있습니다.
MVC 패턴의 3가지 구성 요소:
model(모델)
#🎜🎜 # 보기(view)
-
Controller(controller)
-
[참고] 자세한 내용은 원저자가 여기에 있습니다. MVC의 세 가지 구성 요소를 소개하지만 지면 관계로 여기서는 소개하지 않겠습니다.
Laravel 구성 요소
일반적인 Laravel 애플리케이션에는 아래와 같이 위에서 언급한 MVC 구성 요소가 포함되어 있습니다. Laravel과 상호 작용할 때 브라우저는 요청이 있으면 웹 서버는 요청을 수신하고 이를 Laravel 라우팅 엔진에 전달합니다. Laravel 라우팅은 요청을 수신한 다음 경로의 URL 패턴을 기반으로 적절한 컨트롤러 클래스 메서드로 리디렉션합니다. 그런 다음 컨트롤러 클래스가 인계받습니다. 어떤 경우에는 컨트롤러가 HTML로 변환되어 브라우저로 다시 전송되는 템플릿인 뷰를 즉시 렌더링합니다. 동적 웹 사이트에서 더 일반적으로 컨트롤러는 애플리케이션의 요소(예: 사용자, 블로그 게시물)를 나타내고 데이터베이스와의 통신을 담당하는 PHP 개체인 모델과 상호 작용합니다. 모델을 호출한 후 컨트롤러는 최종 보기(HTML, CSS 및 이미지)를 렌더링하고 전체 웹페이지를 사용자 브라우저에 반환합니다. Laravel은 모델, 뷰, 컨트롤러가 이러한 요소를 서로 다른 디렉토리의 별도 코드 파일에 저장하여 상당히 독립적으로 유지되어야 한다는 개념을 장려합니다. 이것이 Laravel 디렉토리 구조가 작동하는 곳입니다. MVC와 같은 디자인 패턴은 개발자의 삶을 더 쉽게 만들기 위해 만들어졌습니다. 이것은 어떤 패턴도 사용하지 않는 PHP보다 Laravel이 더 나은 점입니다. 이 논의가 추상적이라면 이제 걱정하지 마세요! Laravel을 사용하여 작업을 시작하면 자신이 디자인 패턴으로 작업하고 있다는 사실조차 깨닫지 못할 것입니다. 시간이 좀 지나면 자연스러워질 거예요.
Data Model
데이터 모델은 애플리케이션의 비즈니스 로직을 설명하는 모든 애플리케이션의 기초입니다. 모든 데이터 조각은 데이터베이스 테이블로 표시됩니다. Laravel은 데이터베이스에 대한 액세스를 단순화하는 몇 가지 기술을 제공합니다. Laravel은 데이터베이스의 테이블 행을 쉽게 조작할 수 있는 PHP 객체로 변환하여 애플리케이션의 데이터 모델과 데이터베이스 테이블을 연결합니다. 또한 비즈니스 규칙을 적용하고 애플리케이션의 다양한 데이터 모델 간의 관계를 설명하는 등의 작업을 수행할 수 있습니다. 예를 들어, Laravel Eloquent OR/M을 사용하여 개인의 가족 관계를 다음과 같이 설명할 수 있습니다. 더 많은 라라벨 콘텐츠를 보려면 laravel 프레임워크 소개 튜토리얼을 참고하세요.
추천 관련 기사:
Laravel 프레임워크의 Autoloader 모듈 코드 분석
관련 강좌 추천:
2017년 최신 Laravel 비디오 튜토리얼 5개를 추천합니다
|
위 내용은 Laravel 프레임워크의 애플리케이션 아키텍처 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!