Thinkphp学习之路(微博:闲的蛋腾)
简介
ThinkPHP是一个快速、简单的基于MVC和面向对象的轻量级PHP开发框架,遵循Apache2开源协议发布,从诞生以来一直秉承简洁实用的设计原则,在保持出色的性能和至简的代码的同时,尤其注重开发体验和易用性,并且拥有众多的原创功能和特性,为WEB应用开发提供了强有力的支持。
下载
ThinkPHP最新版本可以在官方网站(http://thinkphp.cn/down/framework.html)下载。
最新的3.2.3版本下载地址:http://www.thinkphp.cn/down/610.html。
如果你希望保持最新的更新,可以通过github获取当前最新的版本(完整版)。
Git获取地址列表(你可以选择一个最快的地址):
Github: https://github.com/liu21st/thinkphp
Oschina: http://git.oschina.net/liu21st/thinkphp.git
Code: https://code.csdn.net/topthink2011/ThinkPHP
Coding: https://git.coding.net/liu21st/thinkphp.git
目录结构
把下载后的压缩文件解压到你的WEB目录(或者任何子目录都可以),框架的目录结构为:
www WEB部署目录(或者子目录)
├─index.php 入口文件
├─README.md README文件
├─composer.json Composer定义文件
├─Application 应用目录
├─Public 资源文件目录
└─ThinkPHP 框架目录
3.2版本开始相比之前的版本自带了一个完整的应用目录结构(Application)和默认的应用入口文件(index.php),开发人员可以在这个基础之上灵活调整(目录名称和位置)。其中,Application和Public目录下面都是空的,而README.md和composer.josn文件仅用于说明,实际部署的时候可以删除。
其中,ThinkPHP为框架核心目录,其目录结构如下:
├─ThinkPHP 框架系统目录(可以部署在非web目录下面)
│ ├─Common 核心公共函数目录
│ ├─Conf 核心配置目录
│ ├─Lang 核心语言包目录
│ ├─Library 框架类库目录
│ │ ├─Think 核心Think类库包目录
│ │ ├─Behavior 行为类库目录
│ │ ├─Org Org类库包目录
│ │ ├─Vendor 第三方类库目录
│ │ ├─ … 更多类库目录
│ ├─Mode 框架应用模式目录
│ ├─Tpl 系统模板目录
│ ├─LICENSE.txt 框架授权协议文件
│ ├─logo.png 框架LOGO文件
│ ├─README.txt 框架README文件
│ └─index.php 框架入口文件
框架核心目录的结构无需改变,但框架的目录名称(ThinkPHP)可以在应用入口文件中随意更改。
入口文件
在开始之前,你需要一个Web服务器和PHP运行环境,如果你暂时还没有,我们推荐使用集成开发环境WAMPServer(是一个集成了Apache、PHP和MySQL的开发套件,而且支持多个PHP版本、MySQL版本和Apache版本的切换)来使用ThinkPHP进行本地开发和测试。
3.2版本开始框架自带了一个应用入口文件,默认内容如下:
define(‘APP_PATH’,’./Application/’); require ‘./ThinkPHP/ThinkPHP.php’;
这段代码的作用就是定义应用目录和加载ThinkPHP框架的入口文件,这是所有基于ThinkPHP开发应用的第一步。
然后,在浏览器中访问运行后我们会看到欢迎页面:
2015-04-28/553f2b7a6573c
当你看到这个欢迎页面的时候,系统已经在Application目录下面自动生成了公共模块Common、默认模块Home和Runtime运行时目录,如下所示:
Application
├─Common 应用公共模块
│ ├─Common 应用公共函数目录
│ └─Conf 应用公共配置文件目录
├─Home 默认生成的Home模块
│ ├─Conf 模块配置文件目录
│ ├─Common 模块函数公共目录
│ ├─Controller 模块控制器目录
│ ├─Model 模块模型目录
│ └─View 模块视图文件目录
├─Runtime 运行时目录
│ ├─Cache 模版缓存目录
│ ├─Data 数据目录
│ ├─Logs 日志目录
│ └─Temp 缓存目录模块设计
3.2版本采用模块化的设计架构,下面是一个典型的模块目录结构,每个模块可以方便的卸载和部署,并且支持公共模块(Runtime目录非模块目录)。
Application 默认应用目录(可以设置)
├─Common 公共模块(不能直接访问)
├─Home 前台模块
├─Admin 后台模块
├─… 其他更多模块
├─Runtime 默认运行时目录(可以设置)每个模块是相对独立的,其目录结构如下:
├─Module 模块目录
│ ├─Conf 配置文件目录
│ ├─Common 公共函数目录
│ ├─Controller 控制器目录
│ ├─Model 模型目录
│ ├─Logic 逻辑目录(可选)
│ ├─Service 服务目录(可选)
│ … 更多分层目录可选
│ └─View 视图目录
由于采用多层的MVC机制,除了Conf和Common目录外,每个模块下面的目录结构可以根据需要灵活设置和添加,所以并不拘泥于上面展现的目录。
如果我要添加新的模块,有没有快速生成模块目录结构的办法呢?只需要在入口文件中添加如下定义(假设要生成Admin模块):
define(‘APP_PATH’,’./Application/’); // 绑定入口文件到Admin模块访问 define(‘BIND_MODULE’,’Admin’); require ‘./ThinkPHP/ThinkPHP.php’;
BIND_MODULE常量定义表示绑定入口文件到某个模块,由于并不存在Admin模块,所以会在第一次访问的时候自动生成。重新访问入口文件后,就会再次看到欢迎页面,这个时候在Application下面已经自动生成了Admin模块及其目录结构。
注意:生成以后,你需要删除(或者注释掉)刚才添加的那段常量定义才能正常访问Home模块,否则就只能访问Admin模块(因为应用入口中已经绑定了Admin模块)。
define(‘APP_PATH’,’./Application/’); // 注释掉绑定模块的定义
// define(‘BIND_MODULE’,’Admin’); require ‘./ThinkPHP/ThinkPHP.php’;
有些情况下,我们需要更改应用目录、运行时目录和框架的位置,那么可以修改入口文件如下:
// 定义应用目录 define(‘APP_PATH’,’./Apps/’); // 定义运行时目录 define(‘RUNTIME_PATH’,’./Runtime/’); // 更名框架目录名称,并载入框架入口文件 require ‘./Think/ThinkPHP.php’;
这样最终的应用目录结构如下:
www WEB部署目录(或者子目录)
├─index.php 应用入口文件
├─Apps 应用目录
├─Public 资源文件目录
├─Runtime 运行时目录
└─Think 框架目录
调试模式
ThinkPHP支持调试模式,默认情况下是运行在部署模式下面。部署模式下面性能优先,并且尽可能少地抛出错误信息,调试模式则以除错方便优先,关闭任何缓存,而且尽可能多的抛出错误信息,所以对性能有一定的影响。
部署模式采用了项目编译机制,第一次运行会对核心和项目相关文件进行编译缓存,由于编译后会影响开发过程中对配置文件、函数文件和数据库修改的生效(除非你修改后手动清空Runtime下面的缓存文件)。因此为了避免以上问题,我们强烈建议新手在使用ThinkPHP开发的过程中使用调试模式,这样可以更好的获取错误提示和避免一些不必要的问题和烦恼。
开启调试模式很简单,我们只需要在入口文件的开头加上一行常量定义代码:
define(‘APP_DEBUG’, true); // 开启调试模式 define(‘APP_PATH’,’./Application/’); require ‘./ThinkPHP/ThinkPHP.php’;
开发完成后,我们实际进行项目部署的时候,删除这行常量定义代码即可,或者改成:
define(‘APP_DEBUG’,false); // 关闭调试模式 define(‘APP_PATH’,’./Application/’); require ‘./ThinkPHP/ThinkPHP.php’;
为了安全考虑,避免泄露你的服务器WEB目录信息等资料,一定记得正式部署的时候关闭调试模式。
配置
每个应用模块都有独立的配置文件(位于模块目录的Conf/config.php),配置文件的定义格式支持PHP/JSON/YAML/INI/XML等方式,默认采用PHP数组定义,例如:
// 配置文件 return array( ‘配置参数’ => ‘配置值’, // 更多配置参数 //… );
如果你需要为各个模块定义公共的配置文件,可以在公共模块中定义(通常位于 Common/Conf/config.php),定义格式是一样。
一旦有需要,我们就可以在配置文件中添加相关配置项目。通常我们提到的添加配置项目,就是指在项目配置文件中添加:
‘配置参数’=>’配置值’,
配置值可以支持包括字符串、数字、布尔值和数组在内的数据,通常我们建议配置参数均使用大写定义。
如果有需要,我们还可以为项目定义其他类型的配置文件,如果要使用其他格式的配置文件,可以在入口文件中定义CONF_EXT常量即可,例如:
define(‘CONF_EXT’,’.ini’);
这样,模块的配置文件就变成了 Conf/config.ini,定义格式如下:
DEFAULT_MODULE = Index ;默认模块 URL_MODEL = 2 ;URL模式
更多的配置定义请参考后续的内容。
控制器
需要为每个控制器定义一个控制器类,控制器类的命名规范是:
控制器名+Controller.class.php (模块名采用驼峰法并且首字母大写)
系统的默认控制器是Index,对应的控制器就是模块目录下面的Controller/IndexController.class.php,类名和文件名一致。默认操作是index,也就是控制器的一个public方法。初次生成项目目录结构的时候,系统已经默认生成了一个默认控制器(就是之前看到的欢迎页面),我们把index方法改成下面的代码:
title> head> hello, {$name}! body> html>
要输出视图,必须在控制器方法中进行模板渲染输出操作,例如:
title> head> {result.id}--{result.data} body> html>
模板标签的用法和Smarty类似,就是用于输出数据的字段,这里就表示输出think_data表的id和data字段的值。
我们访问会输出:
1–thinkphp
如果发生错误,检查你是否开启了调试模式或者清空Runtime目录下面的缓存文件。
总结
1.1首要是配置thinkphp开发环境
1.2 了解目录结构, 应用目录结构(Application)和默认的应用入口文件(index.php),Application和Public目录下面都是空的,而README.md和composer.josn文件仅用于说明。
1.3 模块增加, define(‘EIND_MODUIE’,’名称’);
1.4 模板配置 (1)单独配置文件 (2)公共配置文件
1.5 控制器 ,命名方式