在CGridView中过滤和CActiveDataProvider

时间:2012-12-30 19:23:00

标签: filter yii cgridview

我在控制器的索引操作中有这些代码:

public function actionIndex()
{ 
  $cid = @$_GET['cid'];
  $country = Country::model()->findByPk($cid);

  if($cid)
    $dataProvider=new CActiveDataProvider('City', array(
      'criteria'=>array(
        'condition'=>'ci_co_id ='.$cid,
      ),
    ));
  else
     $dataProvider=new CActiveDataProvider('City'); 
  $this->render('index',array(
 'dataProvider'=>$dataProvider,
     'country' => $country
    ));
  }

和view / index.php文件中的这些:

<?php 
$this->widget('zii.widgets.grid.CGridView', array(
  'id'=>'city-grid',
  'dataProvider'=>$dataProvider,
  'filter' => $dataProvider,
  'columns'=>array(
    array(
        'name' => ' ',
        'value' => '$row + 1',
    ),  
    'ci_name',
    'ci_pcode',
    array(
        'class'=>'CButtonColumn',
    ),
   )
));

?>

但是Yii给了我这个错误:

CActiveDataProvider and its behaviors do not have a method or closure named "getValidators". 

有什么问题?

1 个答案:

答案 0 :(得分:3)

过滤器必须是扩展CModel的类。但是,您似乎没有进行任何实际过滤,因此您可以只注释CGridView的filter行。

作为旁注,您的标准中存在重大安全漏洞。你对SQL注入攻击持开放态度。

指定您的条件如下,让数据库处理程序正确地转义输入:

'criteria'=>array(
  'condition'=>'ci_co_id =:cid',
  'params'=>array(':cid'=>$cid),
),