PHP全栈学习笔记20

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项目运行时目录


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创建项目流程:

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

 true, // 开启调式模式
 'DB_TYPE' => 'mysql', // 数据库类型
 'DB_HOST' => 'localhost', // 数据库服务器地址
 'DB_NAME' => 'db_database', // 数据库名称
 'DB_USER' => 'root', // 数据库用户名
 'DB_PWD' => 'root', // 数据库命名
 'DB_PORT' => '3306', // 数据库端口
 'DB_PREFIX' => 'think_', // 数据表前缀
);
?>
 select(); // 查询数据
  $this -> assign('select', $select); // 模板变量赋值
  $this -> dispaly('index.html'); // 输出模板
 }
}
?>

模板文件:



id:{$uer.id}
用户名:{$user.user}
地址:{$user.address}

thinkphp配置

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

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

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


进行二维数组进行配置

 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操作方法
select(); // 查询数据
  $this -> assign("select", $select); // 模板变量赋值
  $this -> dispaly(); // 输出模板
 }
}
?>
 Create(); // 创建数据对象
  $result = $ins -> add(); // 写入数据库
  $this -> redirect('Index/index', '', 5, '页面跳转中'); // 页面重定向
 }
}
?>
 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');
 find(1);
echo $User -> name;
$User -> name = 'ThinkPHP';
?>
操作方法是通过返回数组的方式:
find(1);
echo $type['name']; // 获取type属性的值
$type['name'] = 'ThinkPHP'; // 设置type属性的值
?>

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

 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:[email protected]: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'] = '[email protected]';
$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();
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']='[email protected]';
$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()

什么是单一入口?

自动生成项目目录:


项目流程:


config.php

 true, 		// 开启调试模式
	'DB_TYPE'=> 'mysql',        // 数据库类型
	'DB_HOST'=> 'localhost', 	// 数据库服务器地址
	'DB_NAME'=>'db_database',  		// 数据库名称
	'DB_USER'=>'root', 			// 数据库用户名
	'DB_PWD'=>'rot', 				// 数据库密码
	'DB_PORT'=>'3306', 			// 数据库端口
	'DB_PREFIX'=>'think_', 		// 数据表前缀
);
?>
select(); // 查询数据
		$this->assign('select',$select); // 模板变量赋值
		$this->display(); // 输出模板
	}
}
?>




ThinkPHP开发流程



 



ID:{$user.id}
用户名:{$user.user}
地址:{$user.address}

smarty模板技术

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

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

结言

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

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

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

你可能感兴趣的:(其他分类)