ThinkPHP3.2基础知识(三)
1、如何开启调试模式,开启调试模式有什么用处?
// 开启调试模式 建议开发阶段开启 部署阶段注释或者设为false define('APP_DEBUG',True);
开启调试模式的用处:方便及时发现隐患问题和分析、解决问题。
2.如何定义空空控制器和空操作?
空操作:
<?php namespace Home\Controller; use Think\Controller; class CityController extends Controller{ public function _empty($name){
//把所有城市的操作解析到city方法 $this->city($name); }
//注意 city方法 本身是 protected 方法 protected function city($name){
//和$name这个城市相关的处理 echo '当前城市' . $name; }
空控制器:
<?php namespace Home\Controller; use Think\Controller; class EmptyController extends Controller{ public function index(){ //根据当前控制器名来判断要执行那个城市的操作 $cityName = CONTROLLER_NAME; $this->city($cityName); } //注意 city方法 本身是 protected 方法 protected function city($name){ //和$name这个城市相关的处理 echo '当前城市' . $name; } }
3、控制器的参数的前置和后置操作如何定义?
前置操作:_before_操作名 后置操作:_after_操作名
例子:
<?php namespace Home\Controller; use Think\Controller; class IndexController extends Controller{ //前置操作方法 public function _before_index(){ echo 'before<br/>'; } public function index(){ echo 'index<br/>'; } //后置操作方法 public function _after_index(){ echo 'after<br/>'; } }
4.请写出自动验证的规则,要求在修改和新增时都校验密码字段(pwd)的规则并且不管是否为空都要进行校验,规则为:密码要含有大小写字母和数字并且长度要至少为6位;
protected $_validate=array( array('password','require','密码不能为空!'), array('password','/^[a-zA-Z0-9]{6}$/','密码不能小于六位!',0,'regex',3), )
5.3种查询方式和8种查询方法都是什么?
3种查询方式:字符串、数组、对象
8种查询方法:表达式查询、快捷查询、区间查询、组合查询、统计查询、子查询、SQL查询、动态查询
6.请写出一个组合查询中复合查询的示例代码;
$where['name'] = array('like', '%thinkphp%'); $where['title'] = array('like','%thinkphp%'); $where['_logic'] = 'or'; $map['_complex'] = $where; $map['id'] = array('gt',1);
7、请写出连贯操作中可以重复调用的操作;
where 用于查询或者更新条件的定义 字符串、数组和对象
join 用于对查询的join支持 字符串和数组
union 用于对查询的union支持 字符串、数组和对象
scope 用于命名范围 字符串、数组
bind 用于数据绑定操作 数组或多个参数
8.自动加载的原理;
通过类的命名空间自动定位到类库文件
9.I方法常用的两种过滤规则并说明其含义;
1.htmlspecialchars:把一些预定义的字符转换为 HTML 实体.
使用语法:string:必需。规定要转换的字符串。
quotestyle:可选。规定如何编码单引号和双引号。
character-set:可选,字符串值,规定要使用的字符集。
htmlspecialchars(string,quotestyle,character-set)
例子:
2.strip_tags:剥去 HTML、XML 以及 PHP 的标签。
语法:strip_tags(string,allow)
string:必需。规定要检查的字符串。
allow:可选。规定允许的标签。这些标签不会被删除。
例子:
<?php echo strip_tags("Hello <b><i>world!</i></b>"); ?>
输出:Hello world!
模型中写入的过滤方法:
$this->data($data)->filter('strip_tags')->add();
10.模版赋值的两种参数规则;
字符串:$this-assign('show',$show);
数组:$this-assign($arr);
11.如何修改模版标签的定界符?
'TMPL_L_DELIM' => '<{', 'TMPL_R_DELIM' => '>}'
12.模版变量在模版中输出,字符串、数组、对象都如何输出;
字符串:<{$name}>
数组:<{$data['name']}>
对象:<{$data:name}> 或 <{$data->name}>
13.如何开启批量验证;
protected $patchValidate = true;
14.控制器中如何获取模型类错误信息?
D('表名')->getError();
15.如何有效的防止SQL注入
1.查询条件尽量使用数组方式,这是更为安全的方式;
2.如果不得已必须使用字符串查询条件,使用预处理机制;
3.使用自动验证和自动完成机制进行针对应用的自定义过滤;
4.如果环境允许,尽量使用PDO方式,并使用参数绑定。
查询条件预处理:
Model->where("id=%d and username='%s' and xx='%f'",array($id,$username,$xx))->select();
$Model->where("id=%d and username='%s' and xx='%f'",$id,$username,$xx)->select();
16.GD库是什么?
是php处理图形的扩展库