2

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

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". 

问题是什么?

4

1 回答 1

3

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

作为旁注,您的标准存在重大安全漏洞。您对 SQL 注入攻击敞开了大门。

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

'criteria'=>array(
  'condition'=>'ci_co_id =:cid',
  'params'=>array(':cid'=>$cid),
),
于 2012-12-30T22:09:38.010 回答