array(
'class'=>'CProfileLogRoute',
'levels'=>'error, warning',
)
同时在db组件中加入
'enableProfiling'=>true,
同时在这种情况下,可以用CDbConnection::getStats() 查看执行了多少个语句,用了多少时间
如何知道某一个程序段运行需要的时间
配置好CProfileLogRoute后,在需要测试的地方加上
Yii::beginProfile('blockID');
//程序段
Yii::endProfile('blockID');
'enableParamLogging'=>true,的作用是?
在日志的bind的参数后边跟数的值
如何在页面底部显示所有的db相关的日志
同上,配置log组件的routes中加入
array(
'class'=>'CWebLogRoute',
'levels'=>'trace, info, error, warning',
'categories' => 'system.db.*',
//'showInFireBug' => true, 将在firebug中显示日志
),
把日志记录到数据库
array(
'class'=>'CDbLogRoute',
'logTableName'=>'applog',
'connectionID'=>'db',
),
运行时表applog会自动生成,如果不能生成,参照api自已建立
如何记录$_GET,$_SESSION等信息,在以上的routes中各个配置中加上
'filter'=>'CLogFilter',
log配置中的level设置不对,可能会得不到日志信息
另外level,category的值可以随便写,
只要在用yii::Log("","自定义level","自定义的category")时对应起来即可
如何记录更详细的信息,能记录stack?
在入口文件中加上
define('YII_TRACE_LEVEL',10);数字越大,记当的越详细,结果如下
[15:31:57.226][trace][system.db.CDbCommand] Querying SQL: SHOW
COLUMNS FROM `Bangdan` in
E:\APMServ5.2.6\www\htdocs\dayouhui.com\protected\models\Bangdan.php
(21)
in
E:\APMServ5.2.6\www\htdocs\dayouhui.com\protected\components\HotBangdan.php
(21) in E:\APMServ5.2.6
如果在调试时,终止程序运行且看到日志,不能用die及exit;
用application::end,即Yii::app()->end(),其会触发onEndRequest事件,日志就是在这个事件中记录的
如何发布一个资源文件并引用
$css=Yii::app()->getAssetManager()->publish(dirname(__FILE__)."/aa.css");
yii::app()->clientScript->registerCssFIle($css);
如果改变activelable中默认的标题
重写方法attributeLabels
过滤不良代码
$purifier=new
CHtmlPurifier;
$purifier->options=array("HTML.Allowed"=>"div");
$content=$purifier->purify($content);
或者
beginWidget('CHtmlPurifier');
?>
...display user-entered content here...
endWidget(); ?>
如何防止重复提交?
提交后
Ccontroler->refresh();
如何在成功后显示一个提示,用户刷新页时去掉提示
Cwebuser->setFlash();
getFlash();
如何防止重复提交,
并在提交成功后给出提示?
控制器中
Yii::app()->user->setFlash('submit','thanks');
$this->refresh();
view中
if(Yii::app()->user->hasFlash('submit')){
echo Yii::app()->user->getFlash('submit');
}
一般我们是跳转到列表页,或用redirect跳到编辑页,就不需要了,如果还是要显示当前页,以上就有用了,比如在当前时显示,编辑或添加新的记录
如何分页
itemCount总记录条数
CPagination代表分页信息,有多少页,每页几条记录等
CLinkPager生成分页的代码,自定义css可以给属性cssFile一个值
$criteria=new
CDbCriteria();
$pages=new CPagination("数据库中的总记录数");
$pages->pageSize=2;
$pages->applyLimit($criteria);//给$criteria->limit
offset等符值
$posts=Post::model()->findAll($criteria);
$this->widget('CLinkPager',array('pages'=>$pages));
列表如何排序
$criteria=new
CDbCriteria();
$sort = new CSort('Post');
$sort->defaultOrder=" status asc";
$sort->applyOrder($criteria);
$posts=Post::model()->findAll($criteria);
应用时用
$sort->link('字段名')
实际是生成一个带参数的url,然后在在applyOrder时应用这些参数修改$criteria,得到相应的查寻结果
如何生成并验证验证码:
基本用法
具体参数查手册
原理CCaptcha这个widget会在run时调用当前控制器的$captchaAction='captcha'方法,这个方法指到一个类CCaptchaAction
其会生成验证码图象,并记入到session中
如何显示静态页
重写actions
'help'=>array(
'class'=>'CViewAction',
'basePath'=>'help', //指定目录名
'defaultView'=>'default',
'viewParam'=>'help' //get参数
),