美文网首页
test(这个仅仅只是测试文档)

test(这个仅仅只是测试文档)

作者: __没几句话 | 来源:发表于2017-09-10 13:53 被阅读0次

ThinkPHP 3.2.3快速入门

【目录列表】简单一些大概内容如下:

  1. index.php文件的了解;
  2. 调试模式;
  3. 配置;
  4. 控制器;
  5. Url请求;
  6. 视图;
  7. 读取数
  • 学习参考资料: 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`` ,会出现下面的内容:

hello.png

忘记说了,之前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'
  1. BIND_MODULE常量定义表示绑定入口文件到某个模块,由于并不存在Admin模块,所以会在第一次访问的时候自动生成。重新访问入口文件后,就会再次看到欢迎页面,这个时候在Application下面已经自动生成了Admin模块及其目录结构。
  2. 注意:生成以后,你需要删除(或者注释掉)刚才添加的那段常量定义才能正常访问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目录信息等资料,一定记得正式部署的时候关闭调试模式。

相关文章

网友评论

      本文标题:test(这个仅仅只是测试文档)

      本文链接:https://www.haomeiwen.com/subject/iznzjxtx.html