>  기사  >  백엔드 개발  >  Magento용 맞춤형 모듈 개발

Magento용 맞춤형 모듈 개발

WBOY
WBOY원래의
2023-08-31 21:49:07876검색

Magento 사용자 정의 모듈 개발은 모든 단계에서 자체 기능/모듈을 기존 Magento 프로젝트에 통합할 수 있으므로 모든 Magento 개발 또는 Magento 프로젝트의 핵심 부분입니다.

이번 시리즈에서는 Magento 커스텀 모듈 개발에 대해 자세히 다루겠습니다.

Magento를 더욱 발전시키고 싶다면 Envato Market에서 다양하고 유용한 Magento 확장 기능을 확인해 보세요.

为 Magento 开发自定义模块

이 시리즈에서는 비록 맞춤형 버전이지만 Magento Community Edition 1.7을 언급하고 있습니다. 모듈 구조는 모든 Magento 버전에서 동일합니다. 실제 모듈 개발을 시작하기에 앞서 Magento의 기본 구조를 빠르게 이해해 보도록 하겠습니다.

새로운 Magento를 설치할 때마다 다음과 같은 Magento 디렉토리 구조를 볼 수 있습니다:

为 Magento 开发自定义模块

Magento MVC 구조 소개

Joomla, CakePHP, CodeIgniter 등과 같은 다른 주요 프레임워크와 마찬가지로 Magento도 MVC 기반 아키텍처를 따르지만 이는 핵심 PHP MVC 아키텍처와 약간 다릅니다. 여기에서는 Magento 아키텍처를 간단한 PHP MVC 아키텍처와 비교하여 차이점을 설명하겠습니다.

PHP MVC 아키텍처

일반적인 MVC 패턴에서 애플리케이션의 흐름은 다음과 같습니다.

  1. 전체 애플리케이션 라우팅 메커니즘이 결정되는 하나의 주요 진입점이 index.php 있습니다.
  2. 이 라우팅 메커니즘과 요청된 URL 패턴을 기반으로 앱은 적절한 컨트롤러를 호출합니다.
  3. 그런 다음 컨트롤러는 적절한 뷰를 호출합니다.
  4. 마지막으로 뷰 파일은 모델 파일에서 데이터를 수집하여 표시합니다.

마젠토 MVC 아키텍처

Magento의 MVC 아키텍처는 MVC 패턴에 몇 가지 레이어를 추가하지만 애플리케이션의 기본 제어 흐름은 다음과 같습니다.

  1. 전체 애플리케이션이 초기화되는 하나의 주요 진입점이 index.php 있습니다.
  2. 요청된 URL에 따라 적절한 컨트롤러가 호출됩니다.
  3. 컨트롤러는 페이지를 정의하고 해당 페이지에 대한 레이아웃 파일을 로드합니다.
  4. 레이아웃 파일은 사용할 블록 파일을 컨트롤러에 알려줍니다.
  5. 블록 파일은 모델 및 도우미 파일에서 데이터를 수집하여 템플릿 파일에 전달합니다.
  6. 템플릿 파일은 데이터를 수신하고 HTML을 렌더링합니다.

처음에는 추가 레이어가 포함되어 있어 이해하기 어려울 수 있습니다. 제어 흐름에 더 익숙해지기 위해 사용자 정의 "Hello World" 모듈을 개발해 보겠습니다.

모듈 사용을 시작하기 전에

  • 나는 당신이 이미 버전 1.7 또는 1.7+의 Magento 작업 복사본을 가지고 있다고 가정합니다(그렇지 않으면 이 단계에서 버전은 중요하지 않습니다)
  • 캐싱을 비활성화합니다. 캐싱을 비활성화하려면 Magento 관리자 패널 > 시스템 > 캐시 관리 > 왼쪽 확인란에서 모든 캐시 유형 선택 > 오른쪽 상단 드롭다운에서 작업 선택: 비활성화 > 제출을 클릭하세요.

Magento 모듈 구조

코드 풀

Magento에는 Magento의 모든 사용자 정의 모듈과 핵심 모듈이 상주하는 세 가지 유형의 코드 풀이 포함되어 있습니다.

  1. Core Pool에는 기본적으로 Magento 설치와 함께 제공되는 모든 핵심 모듈이 포함되어 있습니다. 이 모듈은 Magento 개발자가 작성했습니다. Magento 설치를 업그레이드할 때마다 모든 핵심 모듈을 덮어쓰고 수정 사항이 손실되므로 이러한 모듈을 수정하지 않는 것이 좋습니다.
  2. 커뮤니티 풀에는 타사 프로그래머가 개발하고 Magento Connect를 통해 설치한 모든 모듈(예: 맞춤형 모듈)이 포함되어 있습니다. 이러한 모듈은 일반적으로 핵심 모듈을 확장하고 일반적으로 Magento의 어느 곳에서나 사용할 수 있는 자체 기능을 제공합니다.
  3. 로컬 풀에는 특정 프로젝트에서 사용되지만 Magento Connect에서는 읽을 수 없는 모든 사용자 정의 모듈이 포함되어 있습니다

커뮤니티 수영장과 로컬 수영장이라는 두 가지 수영장 옵션이 있습니다. 저희는 자체 프로젝트를 개발하고 있기 때문에 로컬 풀을 사용하게 되지만, 커뮤니티 풀 이용에 제한은 없습니다.

구조

Magento 모듈은 다음 구성 요소로 구성됩니다.

  • Blocks에는 템플릿에 데이터를 표시하는 기능이 포함되어 있습니다.
  • Model에는 모듈의 비즈니스 로직이 포함되어 있습니다.
  • 리소스 모델에는 데이터베이스 상호 작용을 위한 기능이 포함되어 있습니다.
  • Controller 페이지 레이아웃을 정의하고 파일을 차단하고 URL이 요청되면 로드합니다.
  • etc모듈에 포함된 파일 수와 모듈이 상호 작용하는 방식을 Magento에 알려주는 XML 형식의 구성 파일이 포함되어 있습니다.
  • Helpers일반적인 비즈니스 로직(예: 이미지 크기 조정, 유효성 검사)을 정의하는 기능이 포함되어 있습니다. 이 기능은 Magento 애플리케이션 어디에서나 사용할 수 있습니다
  • sqlSQL 테이블을 생성, 수정 또는 삭제하기 위한 SQL 스크립트가 포함되어 있습니다.

모듈 이름 지정

모듈 이름을 지정해야 합니다. 일반적으로 Magento 모듈 이름은 _ 두 부분으로 구성됩니다. Magento 모듈의 이름을 지정하는 가장 좋은 방법은 작성자 또는 회사 이름으로 <code class="inline"><namespace></namespace> 作为作者或公司名称,并选择 <module></module>을 선택하고 실제 모듈 이름으로

을 선택하는 것입니다. 🎜

이러한 명명 규칙에 따라 모듈 이름을 Chiragdodia_Mymodule으로 지정했습니다. 우리는 이 시리즈 전체에서 이 이름을 언급할 것입니다.

코드 설정 및 구성

위의 구조를 바탕으로 디렉터리를 생성해 보겠습니다. Magento 설치 디렉터리로 이동하여 app/code/local 로 이동하여 아래와 같이 디렉터리를 생성합니다.

为 Magento 开发自定义模块

다음으로 Chiragdodia_Mymodule.xml 구성 파일을 생성하여 모듈을 구성하고 활성화하겠습니다. app/etc/modules 目录中创建配置文件 Chiragdodia_Mymodule.xml이 디렉터리에는 모든 모듈에 대한 구성 파일이 포함되어 있습니다. 으아아아

이 파일은 Magento에게 모듈의 위치를 ​​알려줍니다.

모듈을 활성화합니다. 지금까지 모든 것이 정확했다면 active 标签中,我们指定了 trueMagento 관리자 패널 > 시스템 > 구성 > 고급 > 고급 > 모듈 출력 비활성화 목록에서 모듈을 찾을 수 있습니다. 여기에서 모듈을 활성화 및 비활성화할 수 있습니다.

시작하기: 개발

다음으로 모듈 구성 파일을 생성하겠습니다. 이 파일은 Magento에 모듈에 대한 모든 정보를 알려줍니다. 여기에는 모듈에 포함된 파일 수, 파일 유형(모델, 도우미, 데이터베이스 클래스) 등이 포함됩니다.

app/code/local/Chiragdodia/Mymodule/etc

app/code/local/Chiragdodia/Mymodule/etc  并创建一个 config.xml로 이동하여 config.xml 을 생성하세요. 다음 내용이 포함될 파일

으아아아

각 태그를 한 줄씩 살펴보겠습니다. 여기서 첫 번째 태그는 모듈의 이름과 버전을 포함하는 <module></module> 입니다. 버전 번호는 모듈을 업데이트할 때 매우 중요합니다.

<frontend></frontend> 标签将告诉 Magento 有关调度的控制器的信息。在 <frontend></frontend> 标记内,我们定义了 <routers></routers> 이는 Magento에게 라우팅 메커니즘을 통해 컨트롤러에 액세스하는 방법을 알려줍니다.

<mymodule></mymodule> 태그에서 모듈 이름 i><mymodule></mymodule> 标签中,我们在 <module></module> <frontname></frontname> 中的标签和前端名称。通过使用前端名称,我们可以在前端访问我们的模块,例如 yoursitename.com/index.php/mymodule/index<frontname></frontname> 태그와 프런트엔드 이름을 . yoursitename.com/index.php/mymodule/index와 같은 프런트엔드 이름을 사용하여 프런트엔드에서 모듈에 액세스할 수 있습니다.

호출하여 yoursitename.com/index.php/mymoduleyoursitename.com/index.php/mymodule/index Magento는 모듈 컨트롤러의 인덱스 액션 파일을 찾습니다. 따라서 컨트롤러 파일을 생성해야 합니다.

app/code/local/Chiragdodia/Mymodule/controllersapp/code/local/Chiragdodia/Mymodule/controllers  并创建文件 IndexController.php 로 이동하여 IndexController.php 파일을 만듭니다.

다음 내용이 포함되어 있습니다.

Magento에서는 각 파일 이름과 클래스 이름이 대소문자를 구분한다는 점에 유의하세요. 파일과 클래스를 생성할 때 생성된 항목의 이름을 지정할 때 주의하는 것이 중요합니다.

으아아아 yoursite.com/index.php/mymodule/index이제 URL을 엽니다 이렇게 하면 "Hello tuts+ World"가 인쇄됩니다.

멋져요 - 드디어 첫 번째 Hello World 모듈을 마쳤습니다.

컨트롤러 스케줄링

여기서 URL 라우팅에 사용되는 모든 메서드가 포함된 Mage_Core_Controller_Front_Action ,其中包含在URL路由中使用的所有方法。 Magento 类名反映了类文件的位置。因此,类 Mage_Core_Controller_Front_ActionMage_Core_Controller_Front_Action 클래스를 확장합니다. Magento 클래스 이름은 클래스 파일의 위치를 ​​반영합니다. 따라서 Mage_Core_Controller_Front_Action 클래스는

Mage > Core > Controller > Front > Action.php

Chiragdodia_Mymodule_IndexController。 Magento 控制器的命名方式应反映 (<module>tag)_(Action Controllername)(keyword Controller).</module>에 있습니다.

컨트롤러의 클래스 이름이
  • 인지 확인하세요. 이 태그는 Chiragdodia_Mymodule(我们已在 config.xmltag = ) b>
  • 에 정의되어 있습니다. 控制器名称
  • 작업
  • = 인덱스 Controller
  • 액션 컨트롤러 뒤에
키워드

가 옵니다. Chiragdodia_Mymodule_IndexController

이 모드에 따르면 우리 컨트롤러의 이름은

입니다. yoursite.com/index.php/frontendname/actionControllername/actionmethod

이제 아래 라우팅 패턴을 따르는 URL 패턴을 확인하세요🎜🎜
  • 前端名称 = mymodule
  • actionControllername = 索引
  • actionmethodname = 索引

根据此网址模式,我们模块的网址为 yoursite.com/index.php/mymodule/index/index。您还可以使用 yoursite.com/index.php/mymodule 访问它,因为只要您未指定 actionControlleractionmethod 名称,Magento 就会加载默认情况下的索引控制器和索引操作。

现在让我们再创建一个操作:testAction 。

<?php
class Chiragdodia_Mymodule_IndexController extends Mage_Core_Controller_Front_Action
{
    public function indexAction()
    {
        echo "Hello tuts+ World";
    }
    public function testAction()
    {
        echo "test action";
    }
}

我们可以使用 URL yoursite.com/index.php/mymodule/index/test 访问 testAction。 如前所述

  • 前端名称 = mymodule
  • actionControllername = 索引
  • actionmethodname = 测试

这就是控制器在 Magento 中的工作原理。

一开始,一次理解所有内容可能很困难,因此我已将所有源代码包含到此模块中,以便您可以在将其用作指南的同时查看它并实现自己的工作。

下一步是什么?

在下一部分中,我们将通过创建布局和块文件来填充模块中的一些布局。我们将了解布局文件在 Magento 中如何工作以及块在 Magento 上下文中扮演什么角色。

在此之前,请创建您自己的模块,并让我知道任何给您带来麻烦的事情。

위 내용은 Magento용 맞춤형 모듈 개발의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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