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!

  模型中写入的过滤方法:

  1. $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方式,并使用参数绑定

  查询条件预处理:

  1. Model->where("id=%d and username='%s' and xx='%f'",array($id,$username,$xx))->select();
  2. $Model->where("id=%d and username='%s' and xx='%f'",$id,$username,$xx)->select();

 16.GD库是什么?

  是php处理图形的扩展库

posted @ 2018-01-25 14:23  HTeroPair的博客  阅读(315)  评论(2编辑  收藏  举报