ThinkPHP建立應用的通常開發流程及實例

Thinkphp是免費開源的php框架,提供了建站所須要的各類組件,方便用戶快速建設部署網站。php

Thinkphp簡介:http://thinkphp.cn/Manual/16html

 

官方徹底開發手冊:http://thinkphp.cn/Manualmysql

使用 ThinkPHP 建立應用的通常開發流程是:web

 建立數據庫和數據表;(沒有數據庫操做可略過)sql

 項目命名並建立項目入口文件;thinkphp

 完成項目配置;(無需額外配置能夠忽略)數據庫

 建立控制器類;apache

 建立模型類;(若是隻是簡單的模型類能夠沒必要建立)瀏覽器

 建立模板文件;緩存

 運行和調試。

 

1. 首先在數據庫建立一個數據庫 demo ,表 think_demo ,以 MySQL 爲例

CREATE TABLE `think_demo` (  

  `id` int(11) unsigned NOT NULL auto_increment,   

  `title` varchar(255) NOT NULL default '',   

  `content` longtext NOT NULL,   

  PRIMARY KEY  (`id`)   

) ENGINE=MyISAM DEFAULT CHARSET=utf8 ;  

 

2. 建立入口文件

<?php

// +----------------------------------------------------------------------

// | ThinkPHP [ WE CAN DO IT JUST THINK IT ]

// +----------------------------------------------------------------------

// | Copyright (c) 2009 http://thinkphp.cn All rights reserved.

// +----------------------------------------------------------------------

// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )

// +----------------------------------------------------------------------

// | Author: liu21st <liu21st@gmail.com>

// +----------------------------------------------------------------------

 

// 定義 ThinkPHP 框架路徑

define('THINK_PATH', '../ThinkPHP');

// 定義項目名稱和路徑

define('APP_NAME', 'MyApp');

define('APP_PATH', '.');

// 加載框架公共入口文件

require(THINK_PATH."/ThinkPHP.php");

// 實例化一個網站應用實例

App::run();

?>

注意, APP_PATH 的路徑指的是項目目錄所在路徑,而不是項目入口文件所在的路徑。 APP_NAME 一般都必須和項目目錄名稱一致。

若是你的項目入口文件放到項目目錄下面的話,能夠無需定義 APP_NAME  APP_PATH ,系統能夠自動識別。THINK_PATH 一般也不是必須的。

3. 自動生成

ThinkPHP 具有項目目錄自動生成功能,而且不須要使用任何命令行工具。咱們只須要簡單的瀏覽器裏面訪問剛纔建立的應用入口文件。

打開瀏覽器,訪問該項目的入口文件: http://127.0.0.1/Myapp/index.php

這時能夠看到項目構建成功後的提示畫面,而且在 Myapp 目錄下,已爲您構建好了項目目錄。

注意: ThinkPHP 框架的全部文件都是採用 UTF-8 編碼保存,可是這不影響你的項目中使用其餘編碼開發和瀏覽。請注意確保文件保存的時候去掉 UTF-8  BOM 頭信息,防止因產生隱藏的輸出而致使程序運行不正常。

注意:若是你是在 Linux 環境下,要確保項目目錄的自動生成,請設置 Myapp 目錄的權限爲可寫,不然請自行建立相關目錄。而後設置 Runtime 目錄爲可寫權限(一般都是設置目錄屬性爲 777 )。

4. 項目配置

自動生成的項目目錄下面已經爲咱們建立了一個空的項目配置文件,位於項目的 Conf 目錄下面,名稱是 config.php 。咱們打開這個配置文件,加入咱們的數據庫配置信息。

<?php

return array(

       //' 配置項 '=>' 配置值 '

       'APP_DEBUG' => true, // 開啓調試模式    

       'DB_TYPE'=> 'mysql',   // 數據庫類型    

       'DB_HOST'=> 'localhost', // 數據庫服務器地址    

       'DB_NAME'=>'demo',  // 數據庫名稱    

       'DB_USER'=>'root', // 數據庫用戶名    

       'DB_PWD'=>'123456', // 數據庫密碼    

       'DB_PORT'=>'3306', // 數據庫端口    

       'DB_PREFIX'=>'think_', // 數據表前綴    

);

?>

5. 業務邏輯

接下來,咱們須要實現一個數據添加和查詢操做的簡單應用,來領略下 ThinkPHP 的快速開發。

在項目的 LibAction 目錄下面找到自動生成的 IndexAction.class.php 文件,這個文件就是 ThinkPHP 的控制器,也就是 Index 模塊的實現。刪除 IndexAction 類默認生成的 index 方法。添加新的 insert 方法和 index 方法,代碼以下:

public function insert() {   

        $Demo = new Model('Demo');   // 實例化模型類    

        $Demo->Create(); // 建立數據對象    

        $result = $Demo->add(); // 寫入數據庫    

        $this->redirect('index'); // 成功後重定向到 index 操做頁面    

}

public function index() {   

        $Demo = new Model('Demo'); // 實例化模型類    

        $list = $Demo->select(); // 查詢數據    

        $this->assign('list',$list); // 模板變量賦值    

        $this->display(); // 輸出模板    

}

以上定義後, Index 模塊就具備了 insert  index 兩個操做,操做方法的定義不須要使用任何參數,並且必須定義爲 public 類型,不然沒法訪問。

 

因爲只是簡單的數據操做應用,因此咱們根本不須要建立任何的模型類也一樣能夠進行 CURD 操做,這就是新版的魅力所在。 ^_^

6. 模版定義

控制器和操做方法已經建立完畢,接下來就是定義模板文件了。

 

項目的自動生成已經爲咱們生成了 Tpl/default 目錄,咱們只須要在 default 目錄下面建立 Index 目錄,表示存放Index 模塊的模板文件。因爲 insert 操做是後臺操做,並不涉及模板輸出,所以不須要定義模板文件,因此咱們只要爲index 操做定義模板便可,內容以下:

<form method="post"  action="__ URL __/insert" >  

標題: <input type="text" name="title"><br />  

內容: <textarea name="content" rows="5" cols="25"><textarea><br/>  

<input type="submit" value=" 新增數據 ">  

</form>

 

<volist name='list' id='vo' >  

編號 :{$vo.id}<br/>  

標題 :{$vo.title}<br/>   

內容 :{$vo.content}<hr>  

</volist> 

把上面的內容保存爲 Tpl/default/Index/index.html 便可。

action="/Admin/Manual/insert" 表示提交表單到當前模塊的 insert 操做。

7. 運行應用

模板定義完成後,咱們就能夠運行應用了。咱們在瀏覽器裏面輸入:

http://localhost/Myapp/ 就能夠看到頁面的表單輸出了。

 

因爲咱們開啓了調試模式,因此在頁面的最下面還會看到一些額外的調試信息,而且能夠很清楚的看到當前頁面的請求信息和執行時間、 SQL 日誌,最後還有加載的文件列表,事實上,頁面 Trace 信息的顯示徹底是能夠定製的,而這些內容不須要在模板裏面定義。

 

 ThinkPHP 中,咱們稱之爲頁面 Trace 信息,這是爲了在開發過程當中調試用的,關閉調試模式後,這些信息會自動消失。另外在調試模式下面,因爲開啓了日誌記錄,而且關閉了全部緩存,因此執行效率會有必定影響,可是關閉調試模式後,效率會有很是顯著的提升。

能夠嘗試在頁面新增數據,會看到頁面下面有列表數據輸出。到目前爲止,咱們已經完成了一個完整的數據操做應用了。

 

 

 

原文:http://blog.sina.com.cn/s/blog_a44e20a0010172uf.html

相關文章
相關標籤/搜索