您好,欢迎访问一九零五行业门户网

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('地址表达式',['参数'],['伪静态后缀'],['显示域名'])
    [模块/控制器/操作#锚点@域名]?参数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
以上就介绍了onthink学习随笔,包括了方面的内容,希望对php教程有兴趣的朋友有所帮助。
其它类似信息

推荐信息