-------------------------------------(写代码不孤独_小小代)
用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 (令牌验证)tokenORM 表映射到类 记录映射到对象 AR模式 ActiveRecord 一种简单的命令怎么带有PRefix就可以启用本地session管理的支持
*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_*_12_1