FuelPHP - Tam Çalışma Örneği
Bu bölümde, FuelPHP'de eksiksiz bir MVC tabanlı BookStore uygulamasının nasıl oluşturulacağını öğreneceğiz.
1. Adım: Bir proje oluşturun
Aşağıdaki komutu kullanarak FuelPHP'de “BookStore” adlı yeni bir proje oluşturun.
oil create bookstore
2. Adım: Bir düzen oluşturun
Uygulamamız için yeni bir düzen oluşturun. Fuel / app / views / layout.php konumunda layout.php dosyası oluşturun. Kod aşağıdaki gibidir,
fuel / app / views / layout.php
<!DOCTYPE html>
<html lang = "en">
<head>
<meta charset = "utf-8">
<meta http-equiv = "X-UA-Compatible" content = "IE = edge">
<meta name = "viewport" content = "width = device-width, initial-scale = 1">
<title><?php echo $title; ?></title>
<!-- Bootstrap core CSS -->
<link href = "/assets/css/bootstrap.min.css" rel = "stylesheet">
<script src = "https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js">
</script>
<script src = "/assets/js/bootstrap.min.js"></script>
</head>
<body>
<nav class = "navbar navbar-inverse navbar-fixed-top">
<div class = "container">
<div class = "navbar-header">
<button type = "button" class = "navbar-toggle collapsed"
datatoggle = "collapse" data-target = "#navbar"
aria-expanded = "false" ariacontrols = "navbar">
<span class= "sr-only">Toggle navigation</span>
<span class = "icon-bar"></span>
<span class = "icon-bar"></span>
<span class = "icon-bar"></span>
</button>
<a class = "navbar-brand" href = "#">FuelPHP Sample</a>
</div>
<div id = "navbar" class = "collapse navbar-collapse">
<ul class = "nav navbar-nav">
<li class = "active"><a href = "/book/index">Home</a></li>
<li><a href = "/book/add">Add book</a></li>
</ul>
</div><!--/.nav-collapse -->
</div>
</nav>
<div class = "container">
<div class = "starter-template" style = "padding: 50px 0 0 0;">
<?php echo $content; ?>
</div>
</div><!-- /.container -->
</body>
</html>
Burada bootstrap şablonunu kullanıyoruz. FuelPHP, önyükleme şablonları için birinci sınıf desteğe sahiptir. Başlık ve içerik olmak üzere iki değişken oluşturduk. başlık, geçerli sayfanın başlığını belirtmek için kullanılır ve içerik, geçerli sayfa ayrıntılarını belirtmek için kullanılır.
3. Adım: Bir Denetleyici Oluşturun
Kitabı göstermek, eklemek, düzenlemek ve silmek için yeni bir Controller_Book oluşturun. Yeni bir dosya, fuel / app / classes / controller / book.php oluşturun ve aşağıdaki kodu yerleştirin.
fuel / app / classes / controller / book.php
<?php
class Controller_Book extends Controller_Template {
public $template = 'layout';
public function action_index() {
// Create the view object
$view = View::forge('book/index');
// set the template variables
$this->template->title = "Book index page";
$this->template->content = $view;
}
}
Burada, şablon denetleyicisini devralarak kitap denetleyicisini oluşturduk ve varsayılan şablonu fuel / app / views / layout.php olarak ayarladık.
4. adım: Dizin görünümünü oluşturun
Fuel / app / views klasörü altında bir klasör oluşturun, görünümler dizininde kitap. Ardından, kitap klasörünün içinde bir index.php dosyası oluşturun ve aşağıdaki kodu ekleyin,
fuel / app / views / index.php
<h3>index page</h3>
Şu an itibariyle, temel bir kitap denetleyicisi oluşturduk.
5.Adım: Varsayılan yolu değiştirin
Uygulamanın ana sayfasını kitap denetleyicisine ayarlamak için varsayılan yolu güncelleyin. Varsayılan yönlendirme yapılandırma dosyası olan fuel / app / config / route.php dosyasını açın ve aşağıdaki gibi değiştirin.
fuel / app / config / route.php
<?php
return array (
'_root_' => 'book/index', // The default route
'_404_' => 'welcome/404', // The main 404 route
'hello(/:name)?' => array('welcome/hello', 'name' => 'hello'),
);
Şimdi, http: // localhost: 8080 / URL'sini istemek, kitap denetleyicisinin dizin sayfasını aşağıdaki gibi döndürecektir,
6. Adım: Veritabanı oluşturun
Aşağıdaki komutu kullanarak MySQL sunucusunda yeni bir veritabanı oluşturun,
create database tutorialspoint_bookdb
Ardından, aşağıdaki komutu kullanarak veritabanının içinde bir tablo oluşturun,
CREATE TABLE book (
id INT PRIMARY KEY AUTO_INCREMENT,
title VARCHAR(80) NOT NULL,
author VARCHAR(80) NOT NULL,
price DECIMAL(10, 2) NOT NULL
);
Aşağıdaki SQL ifadesini kullanarak tabloya örnek kayıt ekleyin.
INSERT
INTO
book(title,
author,
price)
VALUES(
'The C Programming Language',
'Dennie Ritchie',
25.00
),(
'The C++ Programming Language',
'Bjarne Stroustrup',
80.00
),(
'C Primer Plus (5th Edition)',
'Stephen Prata',
45.00
),('Modern PHP', 'Josh Lockhart', 10.00),(
'Learning PHP, MySQL & JavaScript, 4th Edition',
'Robin Nixon',
30.00
)
7. Adım: Veritabanını yapılandırın
Veritabanını, fuel / app / config'de bulunan db.php veritabanı yapılandırma dosyasını kullanarak yapılandırın.
fuel / app / config / db.php
<?php
return array (
'development' => array (
'type' => 'mysqli',
'connection' => array (
'hostname' => 'localhost',
'port' => '3306',
'database' => 'tutorialspoint_bookdb',
'username' => 'root',
'password' => 'password',
'persistent' => false,
'compress' => false,
),
'identifier' => '`',
'table_prefix' => '',
'charset' => 'utf8',
'enable_cache' => true,
'profiling' => false,
'readonly' => false,
),
'production' => array (
'type' => 'mysqli',
'connection' => array (
'hostname' => 'localhost',
'port' => '3306',
'database' => 'tutorialspoint_bookdb',
'username' => 'root',
'password' => 'password',
'persistent' => false,
'compress' => false,
),
'identifier' => '`',
'table_prefix' => '',
'charset' => 'utf8',
'enable_cache' => true,
'profiling' => false,
'readonly' => false,
),
);
8. Adım: Orm paketini dahil edin
ORM paketini içerecek şekilde ana yapılandırma dosyasını güncelleyin. "Fuel / app / config /" adresinde bulunur.
fuel / app / config / config.php
'always_load' => array (
'packages' => array (
'orm'
),
),
9. Adım: Bir model oluşturun
"Fuel / app / classes / model" konumunda bulunan book.php'de bir kitap modeli oluşturun. Aşağıdaki gibi tanımlanır -
fuel / app / sınıflar / model / book.php
<?php
class Model_Book extends Orm\Model {
protected static $_connection = 'production';
protected static $_table_name = 'book';
protected static $_primary_key = array('id');
protected static $_properties = array (
'id',
'title' => array (
'data_type' => 'varchar',
'label' => 'Book title',
'validation' => array (
'required',
'min_length' => array(3),
'max_length' => array(80)
),
'form' => array (
'type' => 'text'
),
),
'author' => array (
'data_type' => 'varchar',
'label' => 'Book author',
'validation' => array (
'required',
),
'form' => array (
'type' => 'text'
),
),
'price' => array (
'data_type' => 'decimal',
'label' => 'Book price',
'validation' => array (
'required',
),
'form' => array (
'type' => 'text'
),
),
);
protected static $_observers = array('Orm\\Observer_Validation' => array (
'events' => array('before_save')
));
}
Burada veritabanı detaylarını modelin özellikleri olarak belirledik. Doğrulama ayrıntılarına da sahiptir.
10.Adım: Kitapları görüntüleyin
Veritabanındaki mevcut kitapları listelemek için kitap denetleyicisindeki dizin eylemini güncelleyin.
fuel / app / classes / controller / book.php
<?php
class Controller_Book extends Controller_Template {
public $template = 'layout';
public function action_index() {
// Create the view object
$view = View::forge('book/index');
// fetch the book from database and set it to the view
$books = Model_Book::find('all');
$view->set('books', $books);
// set the template variables
$this->template->title = "Book index page";
$this->template->content = $view;
}
}
Burada kullandık orm kitap ayrıntılarını veritabanından almak ve ardından kitap ayrıntılarını görüntülemelere aktarmak için.
11. adım: Dizin görünümünü güncelleyin
"Fuel / app / views / book" konumunda bulunan index.php görüntüleme dosyasını güncelleyin. Güncellenen kodun tamamı aşağıdaki gibidir,
fuel / app / views / book / index.php
<table class = "table">
<thead>
<tr>
<th>#</th>
<th>Title</th>
<th>Author</th>
<th>Price</th>
<th></th>
</tr>
</thead>
<tbody>
<?php
foreach($books as $book) {
?>
<tr>
<td><?php echo $book['id']; ?></td>
<td><?php echo $book['title']; ?></td>
<td><?php echo $book['author']; ?></td>
<td><?php echo $book['price']; ?></td>
<td>
<a href = "/book/edit/<?php echo $book['id']; ?>">Edit</a>
<a href = "/book/delete/<?php echo $book['id']; ?>">Delete</a>
</td>
</tr>
<?php
}
?>
</tbody>
</table>
<ul>
</ul>
Şimdi, http: // localhost: 8080 / URL'sini istemek, sayfayı aşağıdaki gibi gösterecektir -
Adım 12: Kitap eklemek için eylem oluşturun
Kitapçıya yeni bir kitap eklemek için işlevselliği oluşturun. Kitap denetleyicisinde aşağıdaki gibi yeni bir eylem oluşturun, action_add,
public function action_add() {
// create a new fieldset and add book model
$fieldset = Fieldset::forge('book')->add_model('Model_Book');
// get form from fieldset
$form = $fieldset->form();
// add submit button to the form
$form->add('Submit', '', array('type' => 'submit', 'value' => 'Submit'));
// build the form and set the current page as action
$formHtml = $fieldset->build(Uri::create('book/add'));
$view = View::forge('book/add');
$view->set('form', $formHtml, false);
if (Input::param() != array()) {
try {
$book = Model_Book::forge();
$book->title = Input::param('title');
$book->author = Input::param('author');
$book->price = Input::param('price');
$book->save();
Response::redirect('book');
} catch (Orm\ValidationFailed $e) {
$view->set('errors', $e->getMessage(), false);
}
}
$this->template->title = "Book add page";
$this->template->content = $view; }
Burada aşağıdaki iki işlem gerçekleştirilmektedir,
Fieldset yöntemlerini ve Kitap modelini kullanarak kitap eklemek için kitap formu oluşturma.
Kullanıcı kitap bilgilerini girip formu geri gönderdiğinde kitap formunun işlenmesi. Gönderilen herhangi bir veri için Input :: param () yöntemini kontrol ederek bulunabilir. Formun işlenmesi aşağıdaki adımları içerir -
Kitap bilgilerini toplayın.
Kitap bilgilerini doğrulayın. Doğrulamayı kaydetme yönteminden önce çağrılacak şekilde zaten ayarladık. Doğrulama başarısız olursa, Orm \ ValidationFailed istisnası atar .
Kitap bilgilerini veritabanında saklayın.
Başarılı olursa, kullanıcıyı sayfayı dizine yönlendirin. Aksi takdirde formu tekrar gösterin.
İkisini de yapıyoruz, hem formu gösteriyoruz hem de aynı eylemde formu işliyoruz. Kullanıcı eylemi ilk kez çağırdığında, formu gösterecektir. Kullanıcı kitap bilgilerini girip verileri gönderdiğinde formu işleyecektir.
13. adım: Kitap ekleme işlemi için görünümü oluşturun
Kitap ekleme işlemi için görünümü oluşturun. Yeni bir dosya, fuel / app / views / book / add.php oluşturun ve aşağıdaki kodu girin,
<style>
#form table {
width: 90%;
}
#form table tr {
width: 90%
}
#form table tr td {
width: 50%
}
#form input[type = text], select {
width: 100%;
padding: 12px 20px;
margin: 8px 0;
display: inline-block;
border: 1px solid #ccc;
border-radius: 4px;
box-sizing: border-box;
}
#form input[type = submit] {
width: 100%;
background-color: #3c3c3c;
color: white;
padding: 14px 20px;
margin: 8px 0;
border: none;
border-radius: 4px;
cursor: pointer;
}
#form div {
border-radius: 5px;
background-color: #f2f2f2;
padding: 20px;
}
</style>
<div id = "form">
<h2>Book form</h2>
<?php
if(isset($errors)) {
echo $errors;
}
echo $form;
?>
</div>
Burada sadece eylem yönteminde oluşturulan formu gösteriyoruz. Ayrıca varsa hataları da gösteriyoruz.
adım 14: Kitap ekle eylemini kontrol etme
URL'yi istemek, http: // localhost: 8080 / book / add veya Kitap gezinme ekle bağlantısını tıklamak, formu aşağıdaki gibi gösterecektir,
Form
Veri içeren form
Kitap bilgileri girilip sayfa gönderildikten sonra kitap bilgileri veri tabanına kaydedilecek ve sayfa aşağıdaki şekilde indeks sayfasına yönlendirilecektir.
Yeni eklenen kitapla kitap listesi
adım 15: Kitabı düzenlemek için eylem oluşturma
Mevcut kitap bilgilerini düzenlemek ve güncellemek için işlevselliği oluşturun. Kitap denetleyicisinde aşağıdaki gibi yeni bir eylem, action_edit oluşturun.
public function action_edit($id = false) {
if(!($book = Model_Book::find($id))) {
throw new HttpNotFoundException();
}
// create a new fieldset and add book model
$fieldset = Fieldset::forge('book')->add_model('Model_Book');
$fieldset->populate($book);
// get form from fieldset
$form = $fieldset->form();
// add submit button to the form
$form->add('Submit', '', array('type' => 'submit', 'value' => 'Submit'));
// build the form and set the current page as action
$formHtml = $fieldset->build(Uri::create('book/edit/' . $id));
$view = View::forge('book/add');
$view->set('form', $formHtml, false);
if (Input::param() != array()) {
try {
$book->title = Input::param('title');
$book->author = Input::param('author');
$book->price = Input::param('price');
$book->save();
Response::redirect('book');
} catch (Orm\ValidationFailed $e) {
$view->set('errors', $e->getMessage(), false);
}
}
$this->template->title = "Book edit page";
$this->template->content = $view;
}
Sayfayı işlemeden önce istenen kitabı id ile araması dışında, ekleme işlemine benzer. Veritabanında herhangi bir kitap bilgisi bulunursa, devam edecek ve kitap bilgilerini formda gösterecektir. Aksi takdirde, istisna bulunmayan dosyayı atar ve çıkar.
16. adım: Düzenleme eylemi için görünümü oluşturun
Kitap düzenleme eylemi için görünümü oluşturun. Burada, ekleme eylemi için kullanılan aynı görünümü kullanıyoruz.
adım 17: Kitap düzenleme eylemini kontrol etme.
Kitap listeleme sayfasındaki herhangi bir kitabın düzenle bağlantısını tıklayın, ilgili kitap formunu aşağıdaki gibi gösterecektir -
Kitap ayrıntılarını içeren form
adım 18: Kitabı silmek için eylem oluşturun
Kitabı kitapçıdan silmek için işlevselliği oluşturun. Kitap denetleyicisinde aşağıdaki gibi yeni bir eylem oluşturun, action_delete,
public function action_delete($id = null) {
if ( ! ($book = Model_Book::find($id))) {
throw new HttpNotFoundException();
} else {
$book->delete();
}
Response::redirect('book');
}
Burada, sağlanan kitap kimliğini kullanarak veritabanında kitabın varlığını kontrol ediyoruz. Kitap bulunursa silinir ve indeks sayfasına yönlendirilir. Aksi takdirde, bulunmayan bir sayfa bilgisi gösterilecektir.
adım 19: Silme eylemini kontrol etme
Kitap listesi sayfasındaki sil bağlantısını tıklayarak silme eylemini kontrol edin. İstenen kitabı silecek ve ardından tekrar indeks sayfasına yönlendirilecektir.
Son olarak, kitap bilgilerini eklemek, düzenlemek, silmek ve listelemek için tüm işlevler oluşturulur.
FuelPHP, diğer MVC tabanlı PHP çerçevelerine kıyasla basit, esnek, ölçeklenebilir ve kolayca yapılandırılabilir. Modern MVC çerçevesinin tüm özelliklerini sağlar. Olduğu gibi kullanılabilir veya ihtiyaçlarımıza göre tamamen değiştirilebilir. Her şeyden önce, web geliştirme için harika bir seçimdir.