Home >Backend Development >PHP Tutorial >Onthink学习漫笔
Onthink学习随笔
-------------------------------------(写代码不孤独_小小代)
用Onthink写了一个网站暂时还没上线功能略显不全没,完全没有发挥出应有的强大拓展之处,各种地方略显蹩脚。
但是其强大的数据表控制还是显漏一角,鉴于此进军基于开发的thinphp3.2.2世界。。。
第一天 完成手册序言,基础,配置,架构,路由阅读。
第二天 完成控制器模型阅读 关于 附录阅读
下面是阅读随录
*************************************************
use 表示引入什么 命名空间便于直接引用
函数的命名方法使用小写字母和下划线的方式
方法的命名 使用的小写字母和下划线 下划线的代表的是(一般私有方法 )
双下划线 打头的函数或方法作为魔法方法 __call
养成使用I函数获取输入变量的好习惯;
更新或者环境改变后遇到问题首要问题是清空Runtime目录;
惯例配置 应用配置 模式配置 调试配置 状态配置 模块配置
惯例配置ThinkPHP/Conf/convention.php 应用配置是基于惯例配置的拓展
Application/Common/Conf/config.php调用所有模块之前都会先加载的公共配置文件
可选择的模式配置就是在应用配置文件夹新增 运行该模式才运行的文件config_应用名称.php
调试模式 开启就会加载ThinkPHP/Conf/debug.php和应用调试配置文件Application下的
状态配置就是手工分离
模块配置 Application/当前模块名/Conf/config.php
读取配置文件
定义了配置文件后,都统一使用系统提供C方法(可以借助Config)来读取或者设置
配置参数名称不能含有'.'和特殊字符,允许的字母,数字和下划线 C方法可以读取二维
配置 配置参数是全局有效的 通过c配置的参数值是当前有效地不会写入数据库
URL详情 pathinfo模式说明
serverName/index.php(或者其他应用入口文件)/模块/控制器/操作/[参数名/参数值...]
公共的配置文件config.php 公共函数文件function.php可以把路径加载到common_path中
在入口文件当中配置,如果定义过后Application下面就不需要在加载Application
3.2.2写在入口文件可以默认自动生成的模块,控制器。define('BIND_MODULE','xx')如
果想生成更多的控制器BUILD_CONTROLLER_LIST常量
// 绑定Admin模块到当前入口文件
define('BIND_MODULE','Admin');
define('BUILD_CONTROLLER_LIST','Index,User,Menu');
手动调用Think\Bulid类的方法来生成模型类\Think\Build::buildModel
('Admin','Role');
//禁止访问模块 配置禁止访问的模块列表(用于被其他模块调用或者不开放访问),默认配置中
是禁止访问Common模块和Runtime模块(Runtime目录是默认的运行时目录),我们可以增加其他的
禁止访问模块列表:
'MODULE_DENY_LIST' => array('Common','Runtime','Api'),
设置访问列表
允许访问列表和默认模块
'MODULE_ALLOW_LIST' => array('Home','Admin','User'),'DEFAULT_MODULE'
=> 'Home',
单模块设计 就是关闭多模块访问 MULTI_MODOULE=>false
多入口设计
接受参数绑定模块
// 绑定Home模块到当前入口文件$_GET['m'] = 'Home';
define('APP_PATH','./Application/');require './ThinkPHP/ThinkPHP.php';
绑定后http://serverName/index.php/Home/Index/index变成
http://serverName/home.php/Index/index(绑定后url不显示home)
URL区分大小写 URL_CASE_INSENSITIVE=>true
模型层 数据层,逻辑层,服务层,等不同的模型层 创建Model,Logic,sercive
调用的时候 用D方法很方便的调用 D('User','Logic');//实例化UserLogic D('User')则是实例化
UserModel .
更改系统默认的view层 DEFAULT_V_LAYER=>'Mobile';对于非默认视图层目录的模板获取使用T函
数获取。
控制器(Controller)层 核心控制器在系统内部的App类完成
Event/UserEvent//用于用户的事件响应操作Controller负责的事外部的响应Event负责内
部的事件响应,并且只能在内部调用A('User','Event');
CBD模型
Core(核心)+Behavior(行为)+Driver(驱动)
Driver(驱动)
3.2在架构设计上更加强化了驱动的设计,替代了之前的引擎和模式扩展,并且改进了行为的设
计,使得框架整体更加灵活,并且由于在需要写入数据的功能类库中都采用了驱动化的设计思想,
所以使得新的框架能够轻松满足分布式部署的需求,对云平台的支持可以更简单的实现了。
Behavior(行为)
行为是一个比较抽象的概念,各个位置都会有行为的产生。
有些行为是在应用执行之前,有些是在模板输出以后,我们把这些行为作为的位置成为标
签(位),也可以成为钩子, 当应用程序运行到这个标签的时候,就会被拦截下来,统一执行相关的
行为,类似于AOP编程中的“切面”的概念,给某一个标签绑定相关行为就成了一种类AOP编程的思
想。
标签位
tag函数用于设置某个标签位,可以传入并且只接受一个参数,如果需要传入多个参数,
请使用数组, \Think\Hook::listen('my_tag');
行为定义 必须定义执行入口方法run,由于行为的调用机制影响,在那调用在哪返回。
行为绑定 行为定义后需要定义到某个标签位才能生效,否则是不会执行的。 需要在应用
的行为定义文件tags.php文件中进行行为和标签的位置定义。
return array( '标签名称1'=>array('行为名1','行为名2',...), '标签名称
2'=>array('行为名1','行为名2',...), );
3.2.1版本以上的,允许设置对应类库不使用命名空间。
配置文件'APP_USE_NAMESPACE' => false(继承调用系统类的时候,仍需要)
3.2版本中实例化php内置的类库或者第三方的没有使用命名空间定义的类。
$class = new \stdClass(); $sxml = new \SimpleXmlElement($xmlstr);
自动加载 (命名空间自动加载)Library目录下面的命名空间都可以自动识别和定位。
除了library目录下的命名空间以外,我们还可以定义其他的命名空间
autoload_namespace
提高效率 类库映射多个根命名空间Think\Think::addMap($map); $map=array();
手动第三方类库导入import方法导入任何类库。
内置的缓存机制 和运行lite文件 新版本的特征 运行时生成静态的入口文件。
应用模式 应用模式就是增加自动识别区域
项目编译 应用编译缓存(首次运行的缓存)——运行Lite文件(入口静态)
-------------===========
路由定义
url不为普通模式,开启路由可以在应用(或者模块)配置文件中开启路由
// 开启路由 'URL_ROUTER_ON'=〉true, 3.2路由是针对模块 所以模块名不能被路由,路由的定义
通常也是在模块配置文件中。
路由表达式=〉路由地址和传入参数 array('路由表达式','路由地址','传入参
数')
路由表达式
正则表达式 /^blog\/(\d+)$/
规则表达式 blog/:id
完全匹配 $
公共方法
-------
控制器
如果要操作的方法是一个控制器的方法是与系统的关键字冲突,我们可以设置后缀的方法
解决 'ACTION_SUFFIX'=> 'Action', // 操作方法后缀
多级控制器 就是把控制器分组
实例化控制器 如果是内部的则在用url地址解析的时候就自动实例化了并且调用如果是跨控制器调
用的话则 实例化 然后使用快捷方法A调用(如果是多层次的话就使用A的第二个参数) 可以在实例
化的时候那方法实例化.
前置和后置操作 (仅对控制器有用)
常见的是_before_index前置方法 _after_index后置方法 如果没有定义前置后置方法,真正有模
板输出的可能仅仅是当前的操作,前置和后置操作一般情况下是没有任何输出的。调用错误成功操
作的话是没有后置操作的。
控制器也可以绑定参数规则 action参数绑定 (按变量名能绑定 实现路由功能)
伪静态
URL_HTML_SUFFIX=〉'' 静态后缀记录到常量__EXT__(可以获取当前的后缀)
URL_DENY_SUFFIX=〉不允许访问的后缀 多个用|隔开
下面的优先级高于上面的
URL大小写 'URL_CASE_INSENSITIVE' =>true 不区分大小写的时候访问控制器大写要前加_
系统提供U方法可以为你自动生成相关的URL地址
U 类似的(redirect) (URL生成)
为了配合所使用的URL模式,我们需要能够动态的根据当前的URL设置生成对应的URL地址,为此,
ThinkPHP内置提供了U方法,用于URL的动态生成,可以确保项目在移植过程中不受环境的影响。
U('地址表达式',['参数'],['伪静态后缀'],['显示域名'])
[[email protected]]?参数1=值1&参数2=值2...
ajax返回 ajaxReturn
可以接受 变量 数组 返回的数据可以治 JSON、JSONP、XML和EVAL 可以配置采用什么方
式返回DEFAULT_AJAX_RETURN 进行返回 eval可以输出$data数据
JSON和JSONP虽然只有一个字母的差别,但其实他们根本不是一回事儿:JSON是一种数
据交换格式,而JSONP是一种非官方跨域数据交互协议。一个是描述信息的格式,一个
是信息传递的
约定方法。
跳转和重定向
$this->success(提示信息,地址,秒数)
----==--=-=
输入变量
可以通过 I 函数进行变量获取和过滤
I('变量类型.变量名',['默认值'],['过滤方法'],['额外数据源'])
I函数自带就有DEFAULT_FILTER默认的是htmlspecialchars (变量的过滤)
判断请求类型 (请求类型)
is_XXX 如果是自定义的AJAX则需要添加隐藏域告诉后台是ajax提交的 如果是jquery的
话则不需要。 可以通过VAR_AJAX_SUBMI配置
空操作
自动调用_empty(实现错误页面和一些url优化)
空控制器系统尝试定到EmptyController
操作绑定到类 ACTION_BIND_CLASS=〉‘true’分的更加细致不能省略
前置后置操作需要提前定义
-=-=-=-=-=-=-=-=-=-=-=-
模型 大小写和_转换
模型类直接实例化一般都继承model类 model一般有3个值 模型名数据表前缀数
据库连接信息
如果要写原生的sql代码 则只需要实例化空就好M();
D (数据模型的实例化操作)
方法的参数就是模型的名称,并且和模型类的大小写定义是一致的.
类不存在的时候,D函数会尝试实例化公共模块下面的,还可以跨模块使用
M(仅仅是对数据表进行基本的CURD操作)不需要加载具体的模型类,所以性能更高.
不支持自己的业务逻辑
我们在实例化的过程中,经常使用D方法和M方法,这两个方法的区别在于M方法实例化模
型无需用户为每个数据表定义模型类,如果D方法没有找到定义的模型类,则会自动用M
方法。
字段缓存包括字段里面的字段信息 可以通过设置DB_FIELDS_CACHE来关闭字段自动缓存在项目配置
文件中增加该字段
获取数据表的所有字段信息 getDbFields(); field(''/*);获取要调用所有字段field
(true).
切换数据表用table(); 连接数据库的时候可以为连接加上标识
系统默认规则,必须用模型execute 写操作 query 读操作
连贯操作 (链式操作)
where可以和where连用
data方法 是针对数据库写入的也可以用于更新(save)可以判断是否有主键 对象可以是数
组,对象和字符串。可以进行读操作.
field 获取字段,字段的排除filed(array('user_id','content'),true);就是user_id和
content之外的字段。 用于写入 (安全性的控制)不允许其他的写入 $model->field('name')-
>create();即表示表单中的合法字段只有name字段,无论用户通过什么手段更改或者添加了浏览器
的提交字段,都会直接屏蔽。因为,其他是所有字段我们都不希望由用户提交来决定,你可以通过
自动完成功能定义额外的字段写入。
filert(字段内容的过滤)有点类似I的判断 $User->data($data)->filter
('strip_tags')->add();过滤掉HTML标签 (支持回调类型的函数 可以是函数或者是闭包
定义)
having方法是为了配合group方法从分组的结果中再次查询。
cache s
comment 注释
Create方法创建的数据对象是保存在内存中,并没有实际写入到数据库中,直到使用add
或者save方法才会真正写入数据库。add或者save之后才被写入数据库,因此在没有改变之前都可
以改变create对象.
----
find(读取一条字段) select(读取字段集) getField(读取字段值)[数字的更新setInc setDec]
delete() [在没有任何的条件传入的时候是不会进行删除的类似于seve]
表单映射 数据获取的时候自动处理设置开启 'READ_DATA_MAP'=>true
也可以使用parseFieldsMap进行格式上的转换
查询方式
数组 '_logic'='OR' 使用对象方式查询 stdClass
$map['b'] =array('notlike',array('%thinkphp%','%tp'),'AND');
exp 表达式查询(exp查询的条件不会被当成字符串) 所有后面的查询条件可以使用任何的
sql支持的语法,包括使用函数和字段名称。查询表达式不仅可以用于查询条件,也可以用于数。
据更新。
$data['score'] = array('exp','score+1');// 用户的积分加1
$User->where('id=5')->save($data); // 根据条件保存修改的数据
多语言包的支持 L
*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_12_1
????????????????????????????????????????
多级控制器
实例化控制器
distinct
(令牌验证)token
ORM 表映射到类 记录映射到对象
AR模式 ActiveRecord 一种简单的命令
怎么带有prefix就可以启用本地session管理的支持
*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_12_1