thinkphp概述,thinkphp项目构建流程,thinkphp项目结构,thinkphp配置,thinkphp控制器,thinkphp模型,thinkphp视图,thinkphp的内置模板引擎。

thinkphp是一个免费开源的,快速,简单的面向对象的轻量级PHP开发框架,遵循Apache2开源协议发布,是为了web应用开发和简化企业级引用开发而诞生的。

thinkPHP的特点,环境要求等。

官方网址:

http://thinkphp.cn

svn的下载地址:

完整版:

http://thinkphp.googlecode.com/svn/trunk

核心版本:

http://thinkphp.googlecode.com/svn/trunk/ThinkPHP

thinkphp遵循简单实用的设计原则,thinkphp框架思想和结构体系进行详细的介绍:

thinkphp的目录结构,自动生成目录,项目目录部署方案,命名规范,项目构建流程。

thinkphp的目录结构:

系统目录和项目目录

系统目录:

common包含框架的一些公共文件,系统定义和惯例配置等。

lang目录语言文件。

lib系统的基类库目录。

tpl系统的模板目录。

mode框架模式扩展目录。

vendor第三方类库目录。

项目目录:

index.php项目入口文件

common项目公共目录

lang项目语言包目录

conf项目配置目录

lib项目基目录

tpl项目模板目录

runtime项目运行时目录

<?php
define('THINK_PATH','ThinkPHP'); // 定义thinkphp框架路径
define('APP_NAME', 'test'); // 定义项目名称
define('APP_PATH', '.'); // 定义项目路径
require(THINK_PATH."/ThinkPHP.php"); // 加载框架入口文件
App::run(); // 实例化一个网站应用实例
?>

thinkphp自动生成的目录:

common, conf, lang, lib, runtime, tpl;

项目目录:

admin:admin后台管理项目目录

home:home项目目录

common:项目公共目录,放置项目公共函数

conf:项目配置目录,放置配置文件

lang:项目语言包目录

lib:项目基目录,通常包括action和model目录

runtime:项目运行时目录,包括cache,temp,data和log

tpl:项目模板目录

thinkphp: thinkPHP系统目录

admin.php: admin.php网站的后台入口文件

index.php: index.php网站的入口文件

分组模块:

app: app项目目录

common: 项目公共目录

conf: 项目配置目录

lang: 项目语言包目录

lib: 项目基目录

runtime: 项目运行时目录

tpl: 项目模板目录

public: public网站公共目录

css: css样式文件夹

images: 图片文件夹

js: js脚本文件夹

thinkphp系统目录

index.php网站入口文件

thinkphp创建项目流程:

创建数据库,数据表,项目命名创建入口文件,项目配置,创建控制类,创建模型类,创建模板文件,运行测试。

<?php
return array(
'APP_DEBUG' => true, // 开启调式模式
'DB_TYPE' => 'mysql', // 数据库类型
'DB_HOST' => 'localhost', // 数据库服务器地址
'DB_NAME' => 'db_database', // 数据库名称
'DB_USER' => 'root', // 数据库用户名
'DB_PWD' => 'root', // 数据库命名
'DB_PORT' => '3306', // 数据库端口
'DB_PREFIX' => 'think_', // 数据表前缀
);
?>
<?php
class IndexAction extends Action{
public function index(){
$db = new Model('user'); // 实例化模型类,参数数据表名称,不包含前缀
$select = $db -> select(); // 查询数据
$this -> assign('select', $select); // 模板变量赋值
$this -> dispaly('index.html'); // 输出模板
}
}
?>

模板文件:

<body>
<volist name="select" id="user">
id:{$uer.id}<br/>
用户名:{$user.user}<br/>
地址:{$user.address}<hr>
</volist>
</body>

thinkphp配置

配置文件时thinkphp框架程序得以运行的基础文件。

惯例配置,项目配置,调式配置,分组配置,模块配置,动态操作配置。

返回PHP数组的方式,所有配置文件的定义格式

<?php
return array(
);
?>

进行二维数组进行配置

<?php
return array(
'APP_DEBUG' => true,
'USER_CONFIG' =>array(
'USER_AUTH' => true,
...
),
);
?>

调试配置

配置文件位于 think\common\debug.php

配置文件存储位置,调式配置文件位于项目配置目录下

系统默认的调试配置文件:

开启日志记录

关闭模板缓存

记录sql日志

关闭字段缓存

开启运行时间详细显示

开启页面trace信息展示

严格检查文件大小写

thinkPHP的控制器

模块类,存储于lib\action目录下:

控制器类必须继承系统的action基础类

跨模块调用

$User = A("User"); // 实例化UserAction控制器对象
$User -> insert(); // 调用User模块的importUser操作方法
A("User")是一个快捷方法
等效于:
import("@.Action.UserAction");
$User = new UserAction();
还有比A更好的方法为:
R("User","insert"); // 远程调用UserAction控制器的insert操作方法
$User = A("User","Admin"); // 实例化Admin项目的UserAction控制器对象
$User -> insert(); // 调用Admin项目UserAction控制器的insert操作方法
R("User", "insert", "Admin"); // 远程调用admin项目的useraction控制器的insert操作方法
<?php
header("Content-Type:text/html; charset=uft-8"); // 设置页面编码格式
class IndexAction extends Action {
public function index() {
$db = new Model('user'); // 实例化模型类,参数数据表名称,不包括前缀
$select = $db->select(); // 查询数据
$this -> assign("select", $select); // 模板变量赋值
$this -> dispaly(); // 输出模板
}
}
?>
<?php
header("Content-Type:text/html; charset=utf-8"); // 设置页面编码格式
class UserAction extends Action{
public function insert(){
$ins = new Model("user"); // 实例化模型类,传递参数为没有前缀的数据表名称
$ins -> Create(); // 创建数据对象
$result = $ins -> add(); // 写入数据库
$this -> redirect('Index/index', '', 5, '页面跳转中'); // 页面重定向
}
}
?>
<?php
header("Content-Type:text/html; charset=utf-8"); // 设置页面编码格式
class IndexAction extends Action{
public function index() {
$db = new Model('user'); // 实例化模型类,参数数据表名称,不包含前缀
$select = $db -> select(); // 查询数据
$this->assign('select',$select);//模板变量赋值
$this->display(); // 输出模板
}
public function insert(){
$ins = R("User", "insert", "Admin"); // 远程调用admin项目useraction控制器的insert操作方法
$ins->Create(); // 创建数据对象
$result = $ins->add(); // 写入数据库
}
}
?>

thinkphp的模型

模型是按照某一个形状进行操作的代名词。

模型的主要作用就是封装数据库的相关逻辑。

主要内容:

模型的命名

实例化模型

属性访问

连接数据库

创建数据

连贯操作

curd操作

实例化基础模型类

$User = new Model('User');
$User -> select();
$User = M('User');
$User -> select();

m方法默认是实例化model类,如果需要实例化其他模型类:

$User = M('User', 'CommonModel');
$User = new CommonModel('User');

实例化用户定义的模型类

// 定义的模型类放到项目lib\model目录下面
class UserModel extends Model{
public function myfun() {
// 。。。
}
}

实例化自定义模型类的方式:

$User = new UserModel();
$User->select(); // 进行其他的数据操作
$User = D('User');
$User -> select(); // 进行其他的数据操作

D方法可以自动检测模型类,不存在时系统会抛出异常,同时对于实例化过的模型,不会重复去实例化。

$User = D('User','Admin'); // 实例化admin项目下面的User模型
$User->select();
如果启动模块分组功能,还能使用:
$User=D('Admin.User');

实例化空模型类

$Model = new Model();
// $Model = M();
$Model -> query('SELECT *FROM think_user where status=1');
<?php
$User = new Model('User');
$User -> find(1);
echo $User -> name;
$User -> name = 'ThinkPHP';
?>
操作方法是通过返回数组的方式:
<?php
$Type=D('Type'); // 返回的type数据是一个数组
$type= $Type->find(1);
echo $type['name']; // 获取type属性的值
$type['name'] = 'ThinkPHP'; // 设置type属性的值
?>

连接数据库:

thinkphp内置抽象数据库访问层,把不同的数据库操作封装起来,只需要使用公共的Db类进行操作。

<?php
return array(
'APP_DEBUG' => false, // 关闭调用模式
'DB_TYPE' => 'mysql', // 数据库类型
'DB_HOST' => 'localhost', // 数据库服务器地址
'DB_NAME' => ‘db_database’, // 数据库名称
'DB_USER' => 'root', // 数据库用户名
'DB_PWD' => 'root', // 数据库密码
'DB_PORT' => '3306'; // 数据库端口
'DB_PREFIX' => 'think_',
);
?>

连接数据库

使用dsn方式在初始化db类的时候传参数。

$db_dsn="mysql://root:admin@127.0.0.1:3306/db_database";//定义dsn
$db = new Db();// 执行类的实例化
$conn=$db->getInstance($db_dsn);// 连接数据库
数组传参
$dsn = array(
'dbms' => 'mysql',
'username' => 'username',
'password' => 'password',
'hostname' => 'localhost',
'hostport' => '3306',
'database' => 'dbname'
);
$db = new Db();
$conn = $db->getInstance($dsn); // 连接数据库,返回数据库驱动类

模型类里面定义参数:

protected $connection = array(
'dbms' => 'mysql',
'username' => 'username',
'password' => 'password',
'hostname' => 'localhost',
'hostport' => '3306',
'database' => 'dbname'
);
//或者使用下面的方式:
protected $connection = "mysql://username:password@localhost:3306/DbName";

使用pdo方式连接数据库:

return array(
'DB_TYPE' => 'pdo',
'DB_DSN'=>'mysql:host=localhost;dbname=db_database',
'DB_USER'=>'root',
'DB_PWD'=>'root',
'DB_PREFIX'=>'think_',
'APP_DEBUG' => false, // 关闭调试模式
);

自动根据表单数据创建数据对象

class UserAction extends Action { // 定义类,继承基础类
public function insert() { // 定义方法
$ins = new Model('user'); // 实例化模型类
$ins -> Create(); // 创建数据库
$result = $ins -> add(); // 写入数据库
$this-> redirect('Index/index', '', 5, '页面跳转中'); // 页面重定向
}
}

curd操作

thinkphp提供了灵活和方便的数据库操作方法,curd创建,更新,读取,和删除。

$User = M("User"); // 实例化对象
$data['name'] = 'ThinkPHP';
$data['email'] = 'ThinkPHP@gamil.com';
$User -> add($data);
$User->data($data)->add();

读取数据的方法:

读取字段的值使用getField方法

读取数据使用find方法

读取数据集使用select方法

getField方法读取某个字段的值

$User = M('User');
$nickname = $User->where('id=3') -> getFielde(‘nickname’);
$list = $User->getField('id, nickname');

select 方法的返回值是一个二维数组,如果没有查询到如何结果的话,返回一个空的数组

$User=M('User');
$list = $User->where('status=1') -> order('create_time') -> limit(10) -> select();

find()方法

$User = M("User");
$User->where('status=1 and name="think" ')->find();
<?php
header("Content-Type: text/html; charset=utf-8"); // 设置页面编码格式
class IndexAction extends Action{
public function index(){
$db=M('User');
$select = $db->where('user="mr"')->order('id desc')->limit(3)->select();
$this->assign('select',$select); // 模板变量赋值
$this->display(); // 指定模板页
}
public function insert() {
$dba = M('User');
$data['user'] = 'fs';
$data['pass'] = md5('gdsoft');
$data['address'] = 'dashu';
$result = $dba -> add($data);
if($result) {
$this->redirect('Index/index', '', 2, '页面跳转中');//页面重定向
}
}
?>
$User = M("User");
$data['name'] = 'ThinkPHP';
$data['email']='ThinkPHP@mail.com';
$User -> where('id=5') -> save('data');
$User = M('User');
$User -> where('id=5') -> delete(); $User = M('User');
$User -> where('status=0') ->order('create_time')->limit('5')->delete();

thinkphp框架的特点

什么是mvc?

mvc是一种经典的程序设计理念,分3部分:

模型层,视图层,控制层。

什么是模型层?

模型层是应用程序的核心部分,可以是一个实体对象或一种业务逻辑。

视图层提供应用程序与用户之间的交互界面。

控制层用于对程序中的请求进行控制。

什么是CURD?

C为创建,U为更新,R为读取,D为删除。

thinkphp使用add(),save(),select(),和delete()

什么是单一入口?

自动生成项目目录:

<?php
define('THINK_PATH','ThinkPHP'); // 定义ThinkPHP框架路径
define('APP_NAME', '1'); // 定义项目名称
define('APP_PATH', '.'); // 定义项目路径
require(THINK_PATH."/ThinkPHP.php"); // 加载框架入口文件
App::run(); // 实例化一个网站应用实例
?>

项目流程:

<?php
define('THINK_PATH', '../ThinkPHP/'); // 定义ThinkPHP框架路径
define('APP_NAME', '2'); // 定义项目名称和路径
define('APP_PATH', '.'); // 定义项目名称和路径
require(THINK_PATH."/ThinkPHP.php"); // 加载框架入口文件
App::run(); // 实例化一个网站应用实例
?>

config.php

<?php
return array(
'APP_DEBUG' => true, // 开启调试模式
'DB_TYPE'=> 'mysql', // 数据库类型
'DB_HOST'=> 'localhost', // 数据库服务器地址
'DB_NAME'=>'db_database', // 数据库名称
'DB_USER'=>'root', // 数据库用户名
'DB_PWD'=>'rot', // 数据库密码
'DB_PORT'=>'3306', // 数据库端口
'DB_PREFIX'=>'think_', // 数据表前缀
);
?>
<?php
class IndexAction extends Action{
public function index() {
$db = new Model('user'); // 实例化模型类,参数数据表名称,不包含前缀
$select = $db->select(); // 查询数据
$this->assign('select',$select); // 模板变量赋值
$this->display(); // 输出模板
}
}
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>ThinkPHP开发流程</title>
</head> <body>
<!--循环输出查询结果数据集--> <volist name='select' id='user' > ID:{$user.id}<br/> 用户名:{$user.user}<br/> 地址:{$user.address}<hr> </volist> </body>
</html>
<?php
define('THINK_PATH', '../ThinkPHP'); //定义ThinkPHP框架路径(相对于入口文件)
define('APP_NAME', '3'); //定义项目名称
define('APP_PATH', '.'); //定义项目路径
require(THINK_PATH."/ThinkPHP.php"); //加载框架入口文件
App::run(); //实例化一个网站应用实例
?>

smarty模板技术

什么是smarty,特点,模板的安装和配置的方法,设计方法等

<?php
include_once("../config.php");
$arr = array('computerbook','name' => 'PHP','unit_price' => array('price' => '¥65.00','unit' => '本'));
$smarty->assign('title','使用Smarty读取数组');
$smarty->assign('arr',$arr);
$smarty->display('02/index.html');
?>
<?php
include '../config.php';
$smarty->assign('title','Smarty保留变量');
$smarty->display('03/index.html');
?>
<?php
include_once '../config.php';
$smarty->display('04/index.html');
?>
<?php
include_once "../config.php";
$smarty->assign("title","if条件判断语句");
$smarty->display("06/index.html");
?>

结言

好了,欢迎在留言区留言,与大家分享你的经验和心得。

感谢你学习今天的内容,如果你觉得这篇文章对你有帮助的话,也欢迎把它分享给更多的朋友,感谢。

感谢!承蒙关照!您真诚的赞赏是我前进的最大动力!

PHP全栈学习笔记20的更多相关文章

  1. PHP全栈学习笔记12

    php简介,php历史,php后端工程师职业前景,php技术方向,php后端工程师职业体系介绍. php是世界上使用最广泛的web开发语言,是超文本预处理器,是一种通用的开源脚本语言,语法吸收了c语言 ...

  2. PHP全栈学习笔记14

    一.搭建PHP开发环境 Apahce服务器 Dreamwear创建站点 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitiona ...

  3. PHP全栈学习笔记11

    连接MySQL mysql_connect(servername,username,password); 面向对象: <?php $servername = "localhost&qu ...

  4. PHP全栈学习笔记8

    面向对象的基本概念,面向对象编程,oop,面向对象,面向对象的分析,面向对象的设计,面向对象的编程,什么是类. 类,属性和方法,类,对象,面向对象编程的三大特点.特点,封装性,继承性,多态性. 封装性 ...

  5. PHP全栈学习笔记7

    图形图像处理技术,gd库的强大支持,PHP的图像可以是PHP的强项,PHP图形化类库,jpgraph是一款非常好用的强大的图形处理工具. 在PHP中加载GD库 gd官方网址下载: http://www ...

  6. PHP全栈学习笔记4

    php和JavaScript,掌握JavaScript基础,自定义函数,流程控制语句,事件,调用JavaScript脚本,在PHP中使用JavaScript. JavaScript是网景公司开发的,是 ...

  7. PHP全栈学习笔记3

    trim()函数,用于去除字符串首尾空格和特殊字符 返回的是去掉的空格和特殊字符后的字符串 string trim(string str [,string charlist]); str 要操作的字符 ...

  8. PHP全栈学习笔记18

    php基础知识,JavaScript,jQuery,ajax基础知识 linux基础知识,mysql数据库的基础与优化 程序设计,PHP框架基础知识,算法,逻辑思维,高并发 PHP基础知识 引用变量, ...

  9. python全栈学习笔记(一)网络基础之网络协议篇

    阅读目录 一.操作系统基础 二.网络通信原理 2.1 互联网的本质就是一系列的网络协议 2.2 osi七层协议 2.3 tcp/ip五层模型讲解 2.3.1 物理层 2.3.2 数据链路层 2.3.3 ...

随机推荐

  1. mysql全面整理(用于复习、查阅)--正在更新

    Mysql学习 1. 关键字与函数名称全部大写 2. 数据库名称.表名称.字段名称全部小写 3. SQL语句必须以分号结尾 一.数据库基本操作 1. 创建.查看数据库 CREATE {DATABASE ...

  2. 解决warning: Clock skew detected. Your build may be incomplete

    原因:机器系统时间与文件时间不一致 解决:更新所有文件的时间后重新编译 find . -type f | xargs -n 5 touch make clean make xargs  -n num ...

  3. git 如何取消add操作

    可以直接使用命令    git reset HEAD 这个是整体回到上次一次操作 绿字变红字(撤销add) 如果是某个文件回滚到上一次操作:  git reset HEAD  文件名 红字变无 (撤销 ...

  4. chrome网页中打开exe

    Windows Registry Editor Version 5.00 [HKEY_CLASSES_ROOT\VMS] @="URL:VMS" "URL Protoco ...

  5. 【转载】 Sqlserver使用Left函数从最左边开始截取固定长度字符串

    在Sqlserver数据库的字符串操作中,截取字符串是最常见的操作,sql server提供了3个常用截取字符串方法,LEFT().RIGHT().SUBSTRING(),如果从第一个字符即最左边位置 ...

  6. shell 函数的高级用法

    函数介绍 linux shell中的函数和大多数编程语言中的函数一样 将相似的任务或者代码封装到函数中,供其他地方调用 语法格式 如何调用函数 shell终端中定义函数 [root@master da ...

  7. linux 安装mysql(rpm文件安装)

    三 卸载旧版本的MySql (没有的话,则跳过此步骤)       1.查看旧版本MySql       rpm -qa | grep mysql       将会列出旧版本MySql的组件列表,如: ...

  8. Android笔记(三十) Android中线程之间的通信(二)Handler消息传递机制

    什么是Handler 之前说过了,Android不允许主线程(MainThread)外的线程(WorkerThread)去修改UI组件,但是又不能把所有的更新UI的操作都放在主线程中去(会造成ANR) ...

  9. scrapy框架介绍

    一,介绍 Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用框架,非常出名,非常强悍.所谓的框架就是一个已经被集成了各种功能(高性能异步下载,队列,分布式,解析,持久化等)的具有很强通用性 ...

  10. Vue框架之组件与过滤器的使用

    一.组件的使用 局部组件的使用 ​ 打油诗: 1.声子 2.挂子 3.用 var App = { tempalte:` <div class='app'></div>` }; ...