ThinkPHP 3.2.3快速入门
【目录列表】简单一些大概内容如下:
- index.php文件的了解;
- 调试模式;
- 配置;
- 控制器;
- Url请求;
- 视图;
- 读取数。
- 学习参考资料: ThinkPHP3.2.3快速入门;
- 本内容属于方便自己复习的以及得瑟的记录。
- 建议学习方式: 大脑CPU无法超负荷运作,上帝倒是想给你灵感,问题是你给淌出休息的时间啊。
I 、入口文件index.php
首先是index.php(入口文件)的代码内容:
<?php
/* 应用入口文件 */
// 检测PHP环境
if(version_compare(PHP_VERSION,'5.3.0','<')) die('require PHP > 5.3.0 !');
// 开启调试模式 建议开发阶段开启 部署阶段注释或者设为false
define('APP_DEBUG',True);
// 定义应用目录
define('APP_PATH','./Application/');
// 引入ThinkPHP入口文件
require './ThinkPHP/ThinkPHP.php';
// 亲^_^ 后面不需要任何代码了 就是如此简单
ThinkPHP默认目录结构: --+
Direcotry:
Application (应用目录)
Public (资源目录)
ThinkPHP (框架目录)
Files:
.htaccess((略))
.composer.json (略)
ReadMe.md (略)
index.php (入口文件)
3.2版本开始相比之前的版本自带了一个完整的应用目录结构(Application)和默认的应用入口文件(index.php),开发人员可以在这个基础之上灵活调整(目录名称和位置)。
其中,Application和Public目录下面都是空的,而README.md和composer.josn文件仅用于说明,实际部署的时候可以删除。
框架核心目录的结构无需改变,但框架的目录名称(ThinkPHP)可以在应用入口文件中随意更改。
3.2 版本开始框架自带了一个应用入口文件,默认内容如下(可以参考上面的index.php):
// 代码的作用就是定义应用目录和加载ThinkPHP框架的入口文件,这是所有基于ThinkPHP开发应用的第一步。
define('APP_PATH','./Application/');
require './ThinkPHP/ThinkPHP.php';
先不要去管上面这些内容!打开浏览器 ```http://locahost/thinkphp/index.php`` ,会出现下面的内容:
忘记说了,之前Application是没有任何内容的,当运行了在浏览器运行了index.php,Application就自动生成了一些内容:
Application
├─Common 应用公共模块
│ ├─Common 应用公共函数目录
│ └─Conf 应用公共配置文件目录
├─Home 默认生成的Home模块
│ ├─Conf 模块配置文件目录
│ ├─Common 模块函数公共目录
│ ├─Controller 模块控制器目录
│ ├─Model 模块模型目录
│ └─View 模块视图文件目录
├─Runtime 运行时目录
│ ├─Cache 模版缓存目录
│ ├─Data 数据目录
│ ├─Logs 日志目录
│ └─Temp 缓存目录模块设计
- 由于采用多层的MVC机制,除了Conf和Common目录外,每个模块下面的目录结构可以根据需要灵活设置和添加,所以并不拘泥于上面展现的目录。
如果我要添加新的模块,有没有快速生成模块目录结构的办法呢?只需要在入口文件中添加如下定义(假设要生成Admin模块):
define('APP_PATH','./Application/'); //绑定入口文件到Admin模块访问
define('BIND_MODULE','Admin');//如果有需要请将代码注释掉,具体理由见下2注意。
require './ThinkPHP/ThinkPHP.php'
- BIND_MODULE常量定义表示绑定入口文件到某个模块,由于并不存在Admin模块,所以会在第一次访问的时候自动生成。重新访问入口文件后,就会再次看到欢迎页面,这个时候在Application下面已经自动生成了Admin模块及其目录结构。
- 注意:生成以后,你需要删除(或者注释掉)刚才添加的那段常量定义才能正常访问Home模块,否则就只能访问Admin模块(因为应用入口中已经绑定了Admin模块)。
有些情况下,我们需要更改应用目录、运行时目录和框架的位置,那么可以修改入口文件如下:
define('APP_PATH','./Apps/'); //定义应用目录
define('RUNTIME_PATH','./Runtime/'); //定义运行时目录
require './Think/ThinkPHP.php'; //更名框架目录名称,并载入框架入口文件
以及该段代码产生的效果:
WWW WEB部署目录(或者子目录)
├─index.php 应用入口文件
├─Apps 应用目录
├─Public 资源文件目录
├─Runtime 运行时目录
└─Think 框架目录
II、调试模式 :
ThinkPHP支持调试模式,默认情况下是运行在部署模式下面。部署模式下面性能优先,并且尽可能少地抛出错误信息,调试模式则以除错方便优先,关闭任何缓存,而且尽可能多的抛出错误信息,所以对性能有一定的影响。
部署模式采用了项目编译机制,第一次运行会对核心和项目相关文件进行编译缓存,由于编译后会影响开发过程中对配置文件、函数文件和数据库修改的生效(除非你修改后手动清空Runtime下面的缓存文件)。因此为了避免以上问题,我们强烈建议新手在使用ThinkPHP开发的过程中使用调试模式,这样可以更好的获取错误提示和避免一些不必要的问题和烦恼。
开启调试模式很简单,我们只需要在入口文件(index.php)的开头加上一行常量定义代码:
define('APP_DEBUG', true); // 开启调试模式
define('APP_PATH','./Application/');
require './ThinkPHP/ThinkPHP.php';
1). 开发完成后,我们实际进行项目部署的时候,删除这行常量定义代码即可,或者改成:define('APP_DEBUG', false);
。
2). 为了安全考虑,避免泄露你的服务器WEB目录信息等资料,一定记得正式部署的时候关闭调试模式。