入口文件主要完成:
- 定义框架路径、项目路径(可选)
- 定义调试模式和应用模式(可选)
- 定义系统相关常量(可选)
- 载入框架入口文件(必须)
如果你改变了项目目录(例如把Application
更改为Apps
),只需要在入口文件更改APP_PATH常量定义即可:
-
define('APP_PATH','./Apps/');
-
require './ThinkPHP/ThinkPHP.php';
如果你调整了框架核心目录的位置或者目录名,只需要这样修改:
-
define('APP_PATH','./Application/');
-
require './Think/ThinkPHP.php';
也可以单独定义一个THINK_PATH常量用于引入:
-
define('APP_PATH','./Application/');
-
define('THINK_PATH',realpath('../Think').'/');
-
require THINK_PATH.'ThinkPHP.php';
入口文件中的其他定义
一般不建议在入口文件中做过多的操作,但可以重新定义一些系统常量,入口文件中支持定义(建议)的一些系统常量包括:
常量 | 描述 |
---|---|
THINK_PATH | 框架目录 |
APP_PATH | 应用目录 |
RUNTIME_PATH | 应用运行时目录(可写) |
APP_DEBUG | 应用调试模式 (默认为false) |
STORAGE_TYPE | 存储类型(默认为File) |
APP_MODE | 应用模式(默认为common) |
注意:所有路径常量都必须以“/”结尾
例如,我们可以在入口文件中重新定义相关目录并且开启调试模式:
-
// 定义应用目录
-
define('APP_PATH','./Apps/');
-
// 定义运行时目录
-
define('RUNTIME_PATH','./Runtime/');
-
// 开启调试模式
-
define('APP_DEBUG',True);
-
// 更名框架目录名称,并载入框架入口文件
-
require './Think/ThinkPHP.php';
接下来再看原来空的Application
目录下面,已经自动生成了公共模块Common
、默认的Home
模块和Runtime
运行时目录的目录结构:
-
Application
-
├─Common 应用公共模块
-
│ ├─Common 应用公共函数目录
-
│ └─Conf 应用公共配置文件目录
-
├─Home 默认生成的Home模块
-
│ ├─Conf 模块配置文件目录
-
│ ├─Common 模块函数公共目录
-
│ ├─Controller 模块控制器目录
-
│ ├─Model 模块模型目录
-
│ └─View 模块视图文件目录
-
├─Runtime 运行时目录
-
│ ├─Cache 模版缓存目录
-
│ ├─Data 数据目录
-
│ ├─Logs 日志目录
-
│ └─Temp 缓存目录
Application
设置可写权限才能自动生成。
common~runtime.php
文件(应用编译缓存文件)。
目录安全文件
在自动生成目录结构的同时,在各个目录下面我们还看到了index.html文件,这是ThinkPHP自动生成的目录安全文件。
为了避免某些服务器开启了目录浏览权限后可以直接在浏览器输入URL地址查看目录,系统默认开启了目录安全文件机制,会在自动生成目录的时候生成空白的index.html
文件,当然安全文件的名称可以设置,例如你想给安全文件定义为default.html
可以在入口文件中添加:
-
define('DIR_SECURE_FILENAME', 'default.html');
如果你的环境足够安全,不希望生成目录安全文件,可以在入口文件里面关闭目录安全文件的生成,例如:
-
define('BUILD_DIR_SECURE', false);
新版采用模块化的设计架构,下面是一个应用目录下面的模块目录结构,每个模块可以方便的卸载和部署,并且支持公共模块。
-
Application 默认应用目录(可以设置)
-
├─Common 公共模块(不能直接访问)
-
├─Home 前台模块
-
├─Admin 后台模块
-
├─... 其他更多模块
-
├─Runtime 默认运行时目录(可以设置)
每个模块是相对独立的,其目录结构如下:
-
├─Module 模块目录
-
│ ├─Conf 配置文件目录
-
│ ├─Common 公共函数目录
-
│ ├─Controller 控制器目录
-
│ ├─Model 模型目录
-
│ ├─Logic 逻辑目录(可选)
-
│ ├─Service Service目录(可选)
-
│ ... 更多分层目录可选
-
│ └─View 视图目录
IndexController.class.php
文件,这就是默认的Index控制器文件
控制器类的命名方式是:控制器名(驼峰法,首字母大写)+Controller
Home\Controller\IndexController
类 对应的控制器文件位于应用目录下面的Home/Controller/IndexController.class.php
,如果你改变了当前的模块名,那么这个控制器类的命名空间也需要随之修改。
-
use Think\Controller;
表示引入 Think\Controller 命名空间便于直接使用。 所以,
-
use Think\Controller;
-
class IndexController extends Controller
等同于使用:
-
class IndexController extends \Think\Controller
对于3.1的用户而言,如果你习惯了使用Action定义控制器的话,可以这样定义:
-
namespace Home\Action;
-
use Think\Action;
-
class IndexAction extends Action{
-
}
然后,在配置文件中,设置:
-
'DEFAULT_C_LAYER'=>'Action'
命名规范
使用ThinkPHP开发的过程中应该尽量遵循下列命名规范:
- 类文件都是以.class.php为后缀(这里是指的ThinkPHP内部使用的类库文件,不代表外部加载的类库文件),使用驼峰法命名,并且首字母大写,例如
DbMysql.class.php
;- 类的命名空间地址和所在的路径地址一致,例如
Home\Controller\UserController
类所在的路径应该是Application/Home/Controller/UserController.class.php
;- 确保文件的命名和调用大小写一致,是由于在类Unix系统上面,对大小写是敏感的(而ThinkPHP在调试模式下面,即使在Windows平台也会严格检查大小写);
- 类名和文件名一致(包括上面说的大小写一致),例如
UserController
类的文件命名是UserController.class.php
, InfoModel类的文件名是InfoModel.class.php
, 并且不同的类库的类命名有一定的规范;- 函数、配置文件等其他类库文件之外的一般是以
.php
为后缀(第三方引入的不做要求);- 函数的命名使用小写字母和下划线的方式,例如
get_client_ip
;- 方法的命名使用驼峰法,并且首字母小写或者使用下划线“_”,例如
getUserName
,_parseType
,通常下划线开头的方法属于私有方法;- 属性的命名使用驼峰法,并且首字母小写或者使用下划线“_”,例如
tableName
、_instance
,通常下划线开头的属性属于私有属性;- 以双下划线“__”打头的函数或方法作为魔法方法,例如
__call
和__autoload
;- 常量以大写字母和下划线命名,例如
HAS_ONE
和MANY_TO_MANY
;- 配置参数以大写字母和下划线命名,例如
HTML_CACHE_ON
;- 语言变量以大写字母和下划线命名,例如
MY_LANG
,以下划线打头的语言变量通常用于系统语言变量,例如_CLASS_NOT_EXIST_
;- 对变量的命名没有强制的规范,可以根据团队规范来进行;
- ThinkPHP的模板文件默认是以
.html
为后缀(可以通过配置修改);- 数据表和字段采用小写加下划线方式命名,并注意字段名不要以下划线开头,例如
think_user
表和user_name
字段是正确写法,类似_username
这样的数据表字段可能会被过滤。
特例:在ThinkPHP里面,有一个函数命名的特例,就是单字母大写函数,这类函数通常是某些操作的快捷定义,或者有特殊的作用。例如:A、D、S、L 方法等等,他们有着特殊的含义,后面会有所了解。
由于ThinkPHP默认全部使用UTF-8编码,所以请确保你的程序文件采用UTF-8编码格式保存,并且去掉BOM信息头(去掉BOM头信息有很多方式,不同的编辑器都有设置方法,也可以用工具进行统一检测和处理),否则可能导致很多意想不到的问题。
开发建议
在使用ThinkPHP进行开发的过程中,我们给出如下建议,会让你的开发变得更轻松:
- 遵循框架的命名规范和目录规范;
- 开发过程中尽量开启调试模式,及早发现问题;
- 多看看日志文件,查找隐患问题;
- 养成使用I函数获取输入变量的好习惯;
- 更新或者环境改变后遇到问题首要问题是清空Runtime目录;