您的位置:首页 > 编程语言 > PHP开发

ThinkPHP基础

2016-05-19 20:37 387 查看
First

什么是ThinkPHP?

ThinkPHP是一个快速、兼容而且简单的轻量级国产PHP开发框架,诞生于2006年初,原名FCS,2007年元旦正式更名为ThinkPHP,遵循Apache2开源协议发布,从Struts结构移植过来并做了改进和完善,同时也借鉴了国外很多优秀的框架和模式,使用面向对象的开发结构和MVC模式,融合了Struts的思想和TagLib(标签库)、RoR的ORM映射和ActiveRecord模式。

什么是MVC模式呢?

MVC全名是Model View Controller,是模型(model)-视图(view)-控制器(controller)的缩写,一种软件设计典范,用一种业务逻辑、数据、界面显示分离的方法组织代码,将业务逻辑聚集到一个部件里面,在改进和个性化定制界面及用户交互的同时,不需要重新编写业务逻辑。MVC被独特的发展起来用于映射传统的输入、处理和输出功能在一个逻辑的图形化用户界面的结构中。

为什么要使用ThinkPHP,他到底有什么好处呢?

对于个人开发来说:

够安全:大家在自己写项目的时候,几乎所有的内容都需要自己去写,过程繁琐漫长,而且个人写出来的项目之中,必定是漏洞百出。可能自己看不出来,但是如果放在网上,就极易被人发现漏洞。然后框架作为一套已经在市面上成熟运用很久的解决方案,其间的安全性是很有保障的。

效率高:因为框架已经把很多工具帮你做好了,到时需要的时候只需拿起用就好,大大提高了项目开发的效率,如果自己做架构,所有的东西都需要你自己来写。

当然有人会说,我以前写过,可以直接拿过来用,但是自己写的东西可能通用性并不高,甚至可能最后会出现很多无法找到根源的bug,这是特别拖项目进度的。

够稳定:各部件之间有条不紊,在不同程度上都能够流畅运行。相比于自己的架构,可以在更多情况时保持稳定运行。

对于公司来说:

团队协作能力强:提供统一的编码规范和模式,团队协作很方便。

低培训成本:使用通用的框架,可以直接关注业务逻辑,不需要培训就可以直接去公司上手工作。

去技术人员化:防止某些核心技术人员离职导致项目开发停滞。

学习ThinkPHP的要求:有上进心,可以努力的学习原生PHP。越熟悉原生,那么就可以越灵活的使用框架做开发。而且当你需要一些TP所不支持的功能时,你完全可以自己写上。

Second

这玩意该怎么玩

一、获取Thinkphp

登陆官方网站:http://www.thinkphp.cn/ 获取。



**这个网站中也有许多教程和代码,大家可以自行查看。**


下完之后,就会发现期内有这几个文件。

www  WEB部署目录(或者子目录)
├─index.php       入口文件
├─README.md       README文件
├─composer.json   Composer定义文件
├─Application     应用目录
├─Public          资源文件目录
└─ThinkPHP        框架目录


入口文件

在开始之前,你需要一个Web服务器和PHP运行环境,如果你暂时还没有,我们推荐使用集成开发环境WAMPServer(是一个集成了Apache、PHP和MySQL的开发套件,而且支持多个PHP版本、MySQL版本和Apache版本的切换)来使用ThinkPHP进行本地开发和测试。

3.2版本开始框架自带了一个应用入口文件,默认内容如下:

define('APP_PATH','./Application/');
require './ThinkPHP/ThinkPHP.php';


打开入口文件之后就会出现一个界面,这就说明Thinkphp安装成功了。



打开之后在目录下会智能的生成目录:

Application
├─Common         应用公共模块
│  ├─Common      应用公共函数目录
│  └─Conf        应用公共配置文件目录
├─Home           默认生成的Home模块
│  ├─Conf        模块配置文件目录
│  ├─Common      模块函数公共目录
│  ├─Controller  模块控制器目录
│  ├─Model       模块模型目录
│  └─View        模块视图文件目录
├─Runtime        运行时目录
│  ├─Cache       模版缓存目录
│  ├─Data        数据目录
│  ├─Logs        日志目录
│  └─Temp        缓存目录模块设计


配置

配置

每个应用模块都有独立的配置文件(位于模块目录的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模式


URL请求

ThinkPHP采用单一入口模式访问应用,对应用的所有请求都定向到应用的入口文件,系统会从URL参数中解析当前请求的模块、控制器和操作,下面是一个标准的URL访问格式:

http://serverName/index.php/模块/控制器/操作


如果我们直接访问入口文件的话,由于URL中没有模块、控制器和操作,因此系统会访问默认模块(Home)下面的默认控制器(Index)的默认操作(index),因此下面的访问是等效的:

http://serverName/index.php http://serverName/index.php/Home/Index/index[/code] 
这种URL模式就是系统默认的PATHINFO模式,不同的URL模式获取模块和操作的方法不同,ThinkPHP支持的URL模式有四种:普通模式、PATHINFO、REWRITE和兼容模式。

1 普通模式

普通模式也就是使用传统的GET传参方式来指定当前访问的模块、控制器和操作,例如:

http://localhost/?m=home&c=index&a=hello&name=thinkphp


m参数表示模块,c表示控制器,a表示操作(当然,这些参数名是可以配置的),后面的表示其他GET参数。

默认值可以不传,因此下面的URL访问是和上面的等效:

http://localhost/?a=hello&name=thinkphp


2 PATHINFO模式

PATHINFO模式是系统的默认URL模式,提供了最好的SEO支持,系统内部已经做了环境的兼容处理,所以能够支持大多数的主机环境。

对应上面的URL模式,PATHINFO模式下面的URL访问地址是:

http://localhost/index.php/home/index/hello/name/thinkphp/


PATHINFO地址的前三个参数分别表示模块/控制器/操作。

PATHINFO模式下面,也可以用普通模式的参数方式传入参数,例如:

http://localhost/index.php/home/index/hello?name=thinkphp


PATHINFO模式下面,URL参数分隔符是可定制的,例如,通过下面的配置:

'URL_PATHINFO_DEPR'=>'-',// 更改PATHINFO参数分隔符


我们可以支持下面的URL访问:

http://localhost/index.php/home-index-hello-name-thinkphp


3 REWRITE模式

REWRITE模式是在PATHINFO模式的基础上添加了重写规则的支持,可以去掉URL地址里面的入口文件index.php,但是需要额外配置WEB服务器的重写规则。

如果是Apache则需要在入口文件的同级添加.htaccess文件,内容如下:

<IfModule mod_rewrite.c>
RewriteEngine on
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^(.*)$ index.php/$1 [QSA,PT,L]
</IfModule>


接下来就可以使用下面的URL地址访问了

http://localhost/home/index/hello/name/thinkphp/


4 兼容模式

兼容模式是用于不支持PATHINFO的特殊环境,URL地址是:

http://localhost/?s=/home/index/hello/name/thinkphp


兼容模式配合Web服务器重写规则的定义,可以达到和REWRITE模式一样的URL效果。

视图

ThinkPHP内置了一个编译型模板引擎,也支持原生的PHP模板,并且还提供了包括Smarty在内的模板引擎驱动。和Smarty不同,ThinkPHP在渲染模板的时候如果不指定模板,则会采用系统默认的定位规则,其定义规范默认是模块目录下面的 View/控制器名/操作名.html,所以,Index模块的hello操作的默认模板文件位于Home模块目录下面的
View/Index/hello.html
,我们添加模板内容如下:

<html>
<head>
<title>hello {$name}</title>
</head>
<body>
hello, {$name}!
</body>
</html>


要输出视图,必须在控制器方法中进行模板渲染输出操作,例如:

<?php
namespace Home\Controller;
use Think\Controller;
class IndexController extends Controller {
public function hello($name='thinkphp'){
$this->assign('name',$name);
$this->display();
}
}


display方法中我们没有指定任何模板,所以按照系统默认的规则输出了
Index/hello.html
模板文件。

接下来,我们在浏览器访问输出:

hello,thinkphp!


读取数据

在开始之前,我们首先在数据库thinkphp中创建一个think_data数据表(以mysql数据库为例):

CREATE TABLE IF NOT EXISTS `think_data`(
`id`int(8)unsigned NOT NULL AUTO_INCREMENT,
`data` varchar(255) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM  DEFAULT CHARSET=utf8 ;
INSERT INTO `think_data`(`id`,`data`) VALUES
(1,'thinkphp'),
(2,'php'),
(3,'framework');


也可以直接在phpmyadmin中添加。

如果我们需要读取数据库中的数据,就需要在模块配置文件中添加数据库连接信息如下:

// 添加数据库配置信息
'DB_TYPE'=>'mysql',// 数据库类型
'DB_HOST'=>'127.0.0.1',// 服务器地址
'DB_NAME'=>'thinkphp',// 数据库名
'DB_USER'=>'root',// 用户名
'DB_PWD'=>'',// 密码
'DB_PORT'=>3306,// 端口
'DB_PREFIX'=>'think_',// 数据库表前缀
'DB_CHARSET'=>'utf8',// 数据库字符集


接下来,我们修改下控制器方法,添加读取数据的代码:

namespace Home\Controller;
use Think\Controller;
class IndexController extends Controller{
public function index(){
$Data     = M('Data');// 实例化Data数据模型
$result     = $Data->find(1);
$this->assign('result',$result);
$this->display();
}
}


这里用到了M函数,是ThinkPHP内置的实例化模型的方法,而且用M方法实例化模型不需要创建对应的模型类,你可以理解为M方法是直接在操作底层的Model类,而Model类具备基本的CURD操作方法。

M(‘Data’) 实例化后,就可以对think_data数据表(think_ 是我们在项目配置文件中定义的数据表前缀)进行操作(包括CURD)了,M函数的用法还有很多,我们以后会深入了解。

定义好控制器后,我们修改模板文件,添加数据输出标签如下:

<html>
<head>
<title></title>
</head>
<body>
{$result.id}--{$result.data}
</body>
</html>


模板标签的用法和Smarty类似,就是用于输出数据的字段,这里就表示输出think_data表的id和data字段的值。

我们访问会输出:

1--thinkphp


如果发生错误,检查你是否开启了调试模式或者清空Runtime目录下面的缓存文件。

综上,就是ThinkPHP比较基础的内容了。

最后,有问题,又不会的查手册,看视频。

http://www.kancloud.cn/thinkphp/thinkphp_quickstart/2138
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  thinkphp