Funciona: - Usuario - Empresa git-svn-id: https://192.168.0.254/svn/Proyectos.Incam_PROFIND_Web/trunk@2 3fe1ab16-cfe0-e34b-8c9f-7d8c168d430d
83 lines
2.4 KiB
PHP
83 lines
2.4 KiB
PHP
<?php
|
|
/**
|
|
* CHtmlPurifier class file.
|
|
*
|
|
* @author Qiang Xue <qiang.xue@gmail.com>
|
|
* @link http://www.yiiframework.com/
|
|
* @copyright Copyright © 2008-2011 Yii Software LLC
|
|
* @license http://www.yiiframework.com/license/
|
|
*/
|
|
|
|
if(!class_exists('HTMLPurifier_Bootstrap',false))
|
|
{
|
|
require_once(Yii::getPathOfAlias('system.vendors.htmlpurifier').DIRECTORY_SEPARATOR.'HTMLPurifier.standalone.php');
|
|
HTMLPurifier_Bootstrap::registerAutoload();
|
|
}
|
|
|
|
/**
|
|
* CHtmlPurifier is wrapper of {@link http://htmlpurifier.org HTML Purifier}.
|
|
*
|
|
* CHtmlPurifier removes all malicious code (better known as XSS) with a thoroughly audited,
|
|
* secure yet permissive whitelist. It will also make sure the resulting code
|
|
* is standard-compliant.
|
|
*
|
|
* CHtmlPurifier can be used as either a widget or a controller filter.
|
|
*
|
|
* Note: since HTML Purifier is a big package, its performance is not very good.
|
|
* You should consider either caching the purification result or purifying the user input
|
|
* before saving to database.
|
|
*
|
|
* Usage as a class:
|
|
* <pre>
|
|
* $p = new CHtmlPurifier();
|
|
* $p->options = array('URI.AllowedSchemes'=>array(
|
|
* 'http' => true,
|
|
* 'https' => true,
|
|
* ));
|
|
* $text = $p->purify($text);
|
|
* </pre>
|
|
*
|
|
* Usage as validation rule:
|
|
* <pre>
|
|
* array('text','filter','filter'=>array($obj=new CHtmlPurifier(),'purify')),
|
|
* </pre>
|
|
*
|
|
* @author Qiang Xue <qiang.xue@gmail.com>
|
|
* @version $Id$
|
|
* @package system.web.widgets
|
|
* @since 1.0
|
|
*/
|
|
class CHtmlPurifier extends COutputProcessor
|
|
{
|
|
/**
|
|
* @var mixed the options to be passed to HTML Purifier instance.
|
|
* This can be a HTMLPurifier_Config object, an array of directives (Namespace.Directive => Value)
|
|
* or the filename of an ini file.
|
|
* @see http://htmlpurifier.org/live/configdoc/plain.html
|
|
*/
|
|
public $options=null;
|
|
|
|
/**
|
|
* Processes the captured output.
|
|
* This method purifies the output using {@link http://htmlpurifier.org HTML Purifier}.
|
|
* @param string $output the captured output to be processed
|
|
*/
|
|
public function processOutput($output)
|
|
{
|
|
$output=$this->purify($output);
|
|
parent::processOutput($output);
|
|
}
|
|
|
|
/**
|
|
* Purifies the HTML content by removing malicious code.
|
|
* @param string $content the content to be purified.
|
|
* @return string the purified content
|
|
*/
|
|
public function purify($content)
|
|
{
|
|
$purifier=new HTMLPurifier($this->options);
|
|
$purifier->config->set('Cache.SerializerPath',Yii::app()->getRuntimePath());
|
|
return $purifier->purify($content);
|
|
}
|
|
}
|