Yii如何过滤不良代码
程序员文章站
2022-04-20 09:56:54
...
Yii如何过滤不良代码?本文主要介绍了Yii净化器CHtmlPurifier用法,可实现过滤不良代码的功能,涉及在控制器、模型、过滤器及视图中的相关使用技巧,需要的朋友可以参考下,希望对大家有所帮助。
具体如下:
1. 在控制器中使用:
public function actionCreate() { $model=new News; $purifier = new CHtmlPurifier(); $purifier->options = array( 'URI.AllowedSchemes'=>array( 'http' => true, 'https' => true, ), 'HTML.Allowed'=>'p', ); if(isset($_POST['News'])) { $model->attributes=$_POST['News']; $model->attributes['content'] = $purifier->purify($model->attributes['content']); if($model->save()) $this->redirect(array('view','id'=>$model->id)); } }
2. 在模型中的使用:
protected function beforeSave() { $purifier = new CHtmlPurifier(); $purifier->options = array( 'URI.AllowedSchemes'=>array( 'http' => true, 'https' => true, ), 'HTML.Allowed'=>'p', ); if(parent::beforeSave()){ if($this->isNewRecord){ $this->create_data = date('y-m-d H:m:s'); $this->content = $purifier->purify($this->content); } return true; }else{ return false; } }
3. 在过滤器中的使用:
public function filters() { return array( 'accessControl', // perform access control for CRUD operations 'postOnly + delete', // we only allow deletion via POST request 'purifier + create', //载入插入页面时进行些过滤操作 ); } public function filterPurifier($filterChain){ $purifier = new CHtmlPurifier(); $purifier->options = array( 'URI.AllowedSchemes'=>array( 'http' => true, 'https' => true, ), 'HTML.Allowed'=>'p', ); if(isset($_POST['news']){ $_POST['news']['content'] = $purify($_POST['news']['content']); } $filterChain->run(); }
4. 在视图中的使用:
<?php $this->beginWidget('CHtmlPurifier'); ?> ...display user-entered content here... <?php $this->endWidget(); ?>
相关推荐:
yii2 modal弹窗之ActiveForm实现ajax表单异步验证
以上就是Yii如何过滤不良代码的详细内容,更多请关注其它相关文章!
推荐阅读
-
如何编写一个过滤掉HTML代码的函数?
-
记一次面试被问到的布隆过滤器(能不能叫布罗姆过滤器...) 如何代码简单实现
-
Vue0.1的过滤代码如何添加到Vue2.0直接使用
-
Yii框架中LoginForm中login方法这段代码如何理解呢?
-
PHP如何过滤GET或者POST的参数?如何样才能保证代码不被注入
-
php框架yii组件如何保证生成代码整齐、不杂乱、优雅
-
PHP如何过滤GET或者POST的参数?如何样才能保证代码不被注入
-
yii2中LinkPager如何增加总页数与总记录数的代码案例
-
YII如何给所有的Controller都设置同一个过滤器,而不是将过滤器的代码复制到一个个的controller?
-
yii2中结合gridview如何使用modal弹窗实例代码详解,yii2gridview