이 글은 Zend Framework의 입문 지식 포인트를 요약하고 분석한 것입니다. 참고할 수 있도록 모든 사람과 공유하세요. 자세한 내용은 다음과 같습니다.
zend 프레임워크는 MVC 패턴을 구현한 것입니다. 빠르게 시작하려면 Zend_Controller Zend_View 부분을 살펴보세요.
1.Zend_Controller 부분. 가장 중요한 클래스는 Zend_Controller_Front입니다. 이를 사용하는 클래식 코드는 매우 간단합니다.
$front=Zend_Controller_Front::getInstance(); $front-> setControllerDirectory("./app/controllers"); $front->dispatch();
Zend_Controller_Front는 인스턴스를 반환하기 위해 getInstance 메서드만 호출할 수 있습니다(제 zend_framework는 1.01을 사용합니다). 여기서 지정한 컨트롤러 디렉터리는 www 문서 루트 디렉터리 아래의 app 폴더 아래에 있습니다. 일반적으로 앱을 문서 루트 디렉터리에 배치하면 안 됩니다. 소위 보안 문제입니다. 구성이 엄격하지 않으면 www 문서 루트 디렉터리의 파일이 방문자에게 표시될 수 있습니다. 일반적으로 다른 디렉토리에 배치해야 합니다. 예를 들어 문서 루트 디렉토리와 동일한 수준에 배치하는 경우
$front->setControllerDirectory("../app/controllers")"." 하나 더 여기에는 상대 경로가 사용됩니다. 전체 경로 이름을 사용하여 다른 디렉터리를 지정할 수 있습니다. 예:
$front->setControllerDirectory("E: /server/app/controllers")이 부분이 색인에 포함됩니다. PHP에서. 올바른 구성에서 모든 요청은 재작성 기능에 의해 프런트엔드 컨트롤러 Zend_Controller_Front 인스턴스인 이 $front로 리디렉션됩니다. 모든 인증 및 기타 처리는 발송 전에 처리되어야 합니다. 2. Zend_View에서 일반적으로 사용되는 코드는 다음과 같습니다.
$view=new Zend_View(); Zend_Registry::set("view".$view);Zend_Framework에서 권장하는 디렉터리 구조를 기본으로 채택합니다. 즉, 동일한 수준의 뷰와 컨트롤러 모델은 모두 애플리케이션 디렉터리에 있습니다. 보기 아래에는 scrīpts 도우미 필터라는 세 가지 형제 디렉터리가 있습니다. 이런 방식으로 컨트롤러를 정의할 때 컨트롤러에 종속된 템플릿을 저장하기 위해 스크립트 아래에 새 디렉터리를 만들어야 합니다. 예를 들어 간단히
Class IndexController extends Zend_Controller_Action { function IndexAction() { } }그에 맞게 인덱스 디렉터리를 만들고 인덱스 디렉터리에 index.phtml 템플릿을 만들어야 합니다. . IndexController 아래에 다른 함수 addAction()을 생성하는 경우 index에 새 add.phtml을 생성해야 합니다. 다른 UserController가 있는 경우 스크립트 아래에 해당 사용자 디렉터리가 있어야 합니다. 이러한 *.phtml 파일은 html 파일과 유사하며 출력하는 콘텐츠가 표시되는 방식을 정의합니다. 그냥 비워두시면 됩니다. 하지만 생략할 수 없습니다. 그렇지 않으면 잘못된 컨트롤러에 "오류" 메시지가 표시됩니다. 이는 기본 ErrorController가 이미 등록되었기 때문입니다. 프런트엔드 컨트롤러가 해당 컨트롤러 배포를 찾을 수 없으면 기본 ErrorController가 호출됩니다. 때로는 기본 디렉토리 구조나 기본 phtml 유형 보기 템플릿을 사용하고 싶지 않을 때가 있습니다. 이때
$view->setParam ("noViewRanderer",true);을 사용하여 기본 phtml 유형 디렉터리 설정을 취소할 수 있습니다. 기본 ErrorController를 작성하려면
$view->setParam ("noErrorHandler",true);을 사용하세요. 템플릿 위치를 설정하려면
$view->setscrīptPath ("./app/views");을 사용하세요. 이는 스마트한 템플릿을 사용할 때 유용합니다. 은 다음과 같이 작성할 수 있습니다.
$view=new Zend_View_Smarty(); $view->setParam("noViewRanderer",true); $view->setParam("noErrorHandler",true); $view->setscrīptPath("./app/views"); Zend_Registry::set("view".$view);은 다음을 사용하여 다음과 같이 얻을 수 있습니다.
$view=Zend_Registry::get("view");3. 모델을 처음 접하면 간단히 데이터 객체로 이해하면 됩니다. 데이터베이스 작업의 경우 일반적으로 직접 상속할 수 있습니다. Zend_Db_Table 클래스는 매우 잘 캡슐화되어 있으며 일반적으로 사용됩니다.
class data extends Zend_Db_Table { protected $_name="data"; }테이블 이름만 지정하면 됩니다. 물론, 이 경우 zendf는 데이터베이스에서 테이블을 찾기 위해 기본적으로 클래스 이름을 지정할 필요가 없습니다. Zend_Db_Table에 대해 defaultAdapter를 지정하는 것을 잊지 마십시오:
$config = new Zend_Config_Ini('./application/config.ini', 'general'); $db = Zend_Db::factory($config->db->adapter, $config->db->config->toArray()); Zend_Db_Table::setDefaultAdapter($db);config.ini는 [general]과 유사합니다.
db.adapter = PDO_MYSQL db.config.host = localhost db.config.username = rob db.config.password = 123456 db.config.dbname = zftest이 글이 Zend Framework 프레임워크 기반의 모든 PHP 프로그래밍에 도움이 되기를 바랍니다. Zend Framework 입문 지식 포인트와 관련된 더 많은 기사를 보려면 PHP 중국어 웹사이트를 주목하세요!