Quy trình hoạt động Zend Framework
Hai dòng này cho phép bạn có bật tính năng báo lỗi của Zend
Framework hay không, nếu có bạn sẽ sửa giá trị thành 1.
1 bootstrap.path = APPLICATION_PATH "/Bootstrap.php"
2 bootstrap.class = "Bootstrap"
10 trang |
Chia sẻ: hao_hao | Lượt xem: 2068 | Lượt tải: 0
Bạn đang xem nội dung tài liệu Quy trình hoạt động Zend Framework, để tải tài liệu về máy bạn click vào nút DOWNLOAD ở trên
Quy trình hoạt động
Zend Framework
Quy trình hoạt động Zend Framework
Trong bài này, tôi sẽ nói đến hướng hoạt động và giúp các bạn phân tích
cũng như tìm hiểu về quy trình xử lý trong Zend Framework. Để qua đó có
thể mở rộng và tùy chọn trong ứng dụng của mình.
Ở phần trước chúng ta đã cùng tìm hiểu về cài đặt và cấu hình Zend
framework trên Netbeans.
1.Zend Framework làm việc như thế nào?:
Zend Framework vận hành theo mô hình MVC. Vì thế bạn sẽ công cảm
thấy ngạc nhiên khi tiếp xúc với quy trình này.
Ví dụ:
Từ ví dụ trên ta thấy Computer được xem là một controller và Product List
được xem là một action của controller đó. Khi hoạt động, trong controller
bạn sẽ khởi tạo những action như mong muốn thông qua việc thiết lập
phương thức một cách cụ thể.
Ví dụ:
1 ?php
2 class IndexController extends Zend_Controller_Action{
3 public function indexAction(){
4 }
5 }
class IndexController cho ta Controller mang tên index() và indexAction()
thì cho ta action là index.
Khi đó bạn bắt buộc phải khởi tạo trong views một thư mục ứng với
controller là index trong scripts. Và file index.phml ứng với action là index.
Xét ví dụ khác:
1 ?php
2 class ComputerController extends Zend_Controller_Action{
3 public function indexAction(){
4 }
5 public function productlistAction(){
6 }
7 }
Ở ví dụ này cho ta biết Controller là Computer, 2 action là index và
productlist.
Như vậy, để chạy được ứng dụng. Bạn cần tạo thư mục Computer trong
views ứng với controller và file index.phtml, productlist.phtml.
Cụ thể:
application
_controller
_computerController.php
application
_views
_scripts
_computer
_index.phtml
application
_views
_scripts
_computer
_productlist.phtml
2.File index.php và application.ini trong Zend Framework có những
gì?:
Nội dung đầy đủ file index.php
01 ?php
02 defined('APPLICATION_PATH')
03 || define('APPLICATION_PATH',
04 realpath(dirname(__FILE__) . '/../application'));
05 defined('APPLICATION_ENV')
06 || define('APPLICATION_ENV',
07
(getenv('APPLICATION_ENV')
? getenv('APPLICATION_ENV')
08 : 'production'));
09 set_include_path(implode(PATH_SEPARATOR, array(
10 dirname(dirname(__FILE__)) . '/library',
11 get_include_path(),
12 )));
13 require_once 'Zend/Application.php' ;
14 $application = new Zend_Application(
15 APPLICATION_ENV,
16 APPLICATION_PATH . '/configs/application.ini'
17 );
18 $application->bootstrap()->run();
Tiếp theo chúng ta sẽ tìm hiểu xem bên trong file index.php này có những
điểm gì cần lưu ý.
1 defined('APPLICATION_PATH')
2 || define('APPLICATION_PATH',
3 realpath(dirname(__FILE__) . '/../application'));
Dòng này khai báo cho Zend Framework biết bạn đang đặt thư mục
application ở đâu thông qua một hằng APPLICATION_PATH. Đây là hằng
mà bạn sẽ dùng rất nhiều trong các khai báo cấu hình sau này.
1 defined('APPLICATION_ENV')
2 || define('APPLICATION_ENV',
3
(getenv('APPLICATION_ENV')
? getenv('APPLICATION_ENV')
4 : 'production'));
Dòng này cho phép đọc thông tin phân đoạn có tên production ở file
application.ini ở bên dưới. Và ta đưa chữ production vào một hằng là
APPLICATION_ENV.
1 set_include_path(implode(PATH_SEPARATOR, array(
2 dirname(dirname(__FILE__)) . '/library',
3 get_include_path(),
4 )));
Dòng này làm nhiệm vụ load nội dung của thư viện library nơi mà bạn chứa
thư viện của zend. Nôm na có thể hiểu là, nếu bạn sử dụng dòng này. Thì ở
phần dưới và những trang khác, thay vì bạn phải gõ: require_once
'Library/Zend/Application.php' Thì giờ bạn chỉ cần gõ: require_once
'Zend/Application.php' . Vì mặc định thư viện đã được nạp vào rồi.
1 require_once 'Zend/Application.php' ;
2 $application = new Zend_Application(
3 APPLICATION_ENV,
4 APPLICATION_PATH . '/configs/application.ini
5 );
Tiếp tới, chúng ta nạp nội dung trang Application.php và tiếp tục gọi trang
application.ini ở thư mục config. Và nếu bạn chú ý, sẽ thấy chúng ta sử dụng
2 hằng vừa khởi tạo là APPLICATION_ENV và APPLICATION_PATH để
lấy thông tin.
1 $application->bootstrap()->run();
Và cuối cùng là việc thực thi lệnh bằng hàm run().
Khi chúng ta đã hiểu được vấn đề, thì chúng ta có thể viết chúng gọn lại theo
cách mà ta hiểu.
01 ?php
02 define('APPLICATION_PATH',
03 realpath(dirname(__FILE__) . '/../application'));
04 define('APPLICATION_ENV','production');
05 set_include_path(dirname(dirname(__FILE__)) . '/library');
06 require_once 'Zend/Application.php' ;
07 $application = new Zend_Application(
08 APPLICATION_ENV,
09 APPLICATION_PATH . '/configs/application.ini'
10 );
11 $application->bootstrap()->run();
Tiếp tới ta tìm hiểu file application.ini để xem nó thể hiện thông tin gì:
1 [production]
2 phpSettings.display_startup_errors = 0
3 phpSettings.display_errors = 0
4 bootstrap.path = APPLICATION_PATH "/Bootstrap.php"
5 bootstrap.class = "Bootstrap"
6
resources.frontController.controllerDirectory =
APPLICATION_PATH"/controllers"
Dòng đầu tiên có chức năng khởi tạo phân đoạn mang giá trị [production].
Bởi vì trong file này chúng ta chia làm nhiều phân đoạn một cách rõ ràng. Ví
dụ phân đoạn chứa cơ sở dữ liệu, phân đoạn chứa thông tin layout, kết nối
CSDL,….
1 [production]
2 phpSettings.display_startup_errors = 0
3 phpSettings.display_errors = 0
Hai dòng này cho phép bạn có bật tính năng báo lỗi của Zend
Framework hay không, nếu có bạn sẽ sửa giá trị thành 1.
1 bootstrap.path = APPLICATION_PATH "/Bootstrap.php"
2 bootstrap.class = "Bootstrap"
Hai dòng này cho phép bạn tìm tới file bootstrap.php để thông qua nó tương
tác các thư viện hàm trong Zend Framework. Đồng thời chỉ định tên gọi
của class là Bootstrap. Ở đây bạn cũng cần lưu ý là tên class trong file
Bootstrap.php phải cùng tên với Bootstrap mà bạn đã khai báo ở
application.ini.
1
resources.frontController.controllerDirectory =
APPLICATION_PATH"/controllers"
Dòng này chỉ ra đường dẫn tới thư mục controllers trong thư mục
application của chúng ta.
Các file đính kèm theo tài liệu này:
- 1_4948.pdf