{"id":202188,"date":"2013-11-18T13:01:03","date_gmt":"2013-11-18T09:01:03","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=202188"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=202188","title":{"rendered":"<span class=\"post_title\">HTML Purifier. \u0420\u0430\u0441\u0448\u0438\u0440\u044f\u0435\u043c \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0438<\/span>"},"content":{"rendered":"<div class=\"content html_format\">   \t<img decoding=\"async\" src=\"http:\/\/habr.habrastorage.org\/post_images\/7b4\/44e\/925\/7b444e9250e31a0f845e8e5f54936935.jpg\"\/><br \/>  <i>\u0411\u0443\u043a\u0432\u0430\u043b\u044c\u043d\u043e \u043f\u0430\u0440\u0443 \u0430\u0431\u0437\u0430\u0446\u0435\u0432 \u044f \u0443\u0434\u0435\u043b\u044e \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e\u0441\u0442\u044f\u043c \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u044d\u0442\u043e\u0439 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 \u0441 \u0444\u0440\u0435\u0439\u043c\u0432\u043e\u0440\u043a\u043e\u043c Yii, \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u043e\u0435 \u0436\u0435 \u0432 \u043f\u043e\u043b\u043d\u043e\u0439 \u043c\u0435\u0440\u0435 \u0443\u043d\u0438\u0432\u0435\u0440\u0441\u0430\u043b\u044c\u043d\u043e \u0438 \u0431\u0443\u0434\u0435\u0442 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e \u0432\u0441\u0435\u043c, \u043a\u0442\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u0438\u043b\u0438 \u043f\u043b\u0430\u043d\u0438\u0440\u0443\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u044d\u0442\u0443 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0443<\/i><\/p>\n<p>  <i>\u0415\u0441\u043b\u0438 \u0432\u044b \u0443\u0436\u0435 \u0445\u043e\u0440\u043e\u0448\u043e \u0437\u043d\u0430\u043a\u043e\u043c\u044b \u0441 Purifier \u0442\u043e \u043c\u043e\u0436\u0435\u0442\u0435 \u0441\u043c\u0435\u043b\u043e \u043d\u0430\u0447\u0438\u043d\u0430\u0442\u044c \u0447\u0438\u0442\u0430\u0442\u044c <a href=\"#pearl_buttons\">\u043e\u0442\u0441\u044e\u0434\u0430<\/a><\/i><\/p>\n<h5>\u041d\u0435\u043c\u043d\u043e\u0433\u043e \u043e HTML Purifier<\/h5>\n<p>  \u0415\u0441\u043b\u0438 \u0432\u044b \u043d\u0435 \u0441\u043b\u044b\u0448\u0430\u043b\u0438 \u043e \u0442\u0430\u043a\u043e\u0439 \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u043e\u0439 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0435 (\u0430 \u043f\u043e\u0438\u0441\u043a \u043d\u0430 \u0425\u0430\u0431\u0440\u0435 \u0433\u043e\u0432\u043e\u0440\u0438\u0442 \u043e \u043d\u0435 \u0442\u0430\u043a\u043e\u0439 \u0443\u0436 \u0431\u043e\u043b\u044c\u0448\u043e\u0439 \u043f\u043e\u043f\u0443\u043b\u044f\u0440\u043d\u043e\u0441\u0442\u0438) \u043a\u0430\u043a <a href=\"http:\/\/htmlpurifier.org\/\">HTML Purifier<\/a>, \u0442\u043e \u0441\u043e\u0432\u0435\u0442\u0443\u044e \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u043e \u043a \u043d\u0435\u0439 \u043f\u0440\u0438\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c\u0441\u044f, \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e \u0435\u0441\u043b\u0438 \u0432\u0430\u0448\u0438 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0438 \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u0443\u044e\u0442 \u043a\u043e\u043d\u0442\u0435\u043d\u0442 \u0432 html \u0444\u043e\u0440\u043c\u0430\u0442\u0435. \u042d\u0442\u043e \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u0440\u044f\u0434\u043e\u0432\u043e\u0439 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c, \u043c\u043e\u0434\u0435\u0440\u0430\u0442\u043e\u0440 \u0438\u043b\u0438 \u0434\u0430\u0436\u0435 \u0430\u0434\u043c\u0438\u043d\u0438\u0441\u0442\u0440\u0430\u0442\u043e\u0440.<br \/>  \u0427\u0442\u043e \u0436\u0435 \u0434\u0435\u043b\u0430\u0435\u0442 \u044d\u0442\u0430 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430?<br \/>  \u0421\u043e\u0433\u043b\u0430\u0441\u043d\u043e \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u0438 \u043e\u043d\u0430 \u043e\u0447\u0438\u0449\u0430\u0435\u0442 \u043b\u044e\u0431\u043e\u0439 html \u043a\u043e\u0434 \u043e\u0442 \u0432\u0441\u0435\u0445 \u0432\u0440\u0435\u0434\u043e\u043d\u043e\u0441\u043d\u044b\u0445, \u043d\u0435\u0432\u0430\u043b\u0438\u0434\u043d\u044b\u0445, \u0437\u0430\u043f\u0440\u0435\u0449\u0435\u043d\u043d\u044b\u0445 (\u0432\u0430\u0448\u0435\u0439 \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u0435\u0439) \u0447\u0430\u0441\u0442\u0435\u0439 \u043a\u043e\u0434\u0430, \u0432 \u0442\u043e\u043c \u0447\u0438\u0441\u043b\u0435 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0435 \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u044b.<br \/>  <a name=\"habracut\"><\/a>  <\/p>\n<h5>\u041c\u0435\u043d\u044c\u0448\u0435 \u0441\u043b\u043e\u0432, \u0431\u043e\u043b\u044c\u0448\u0435 \u043a\u043e\u0434\u0430<\/h5>\n<p>  \u0414\u0443\u043c\u0430\u044e \u043f\u0430\u0440\u0443 \u043f\u0440\u0438\u043c\u0435\u0440\u043e\u0432 \u0441\u043a\u0430\u0436\u0443\u0442 \u0441\u0430\u043c\u0438 \u0437\u0430 \u0441\u0435\u0431\u044f.  <\/p>\n<pre><code class=\"php\">        $config = HTMLPurifier_Config::createDefault();         $config-&gt;set('Attr.AllowedClasses',array('header')); \/\/ \u0438\u043b\u0438 Attr.ForbiddenClasses \u0438\u043c\u0435\u044e\u0442\u0441\u044f \u0432\u0432\u0438\u0434\u0443 CSS \u043a\u043b\u0430\u0441\u0441\u044b         $config-&gt;set('AutoFormat.AutoParagraph',true); \/\/ \u0430\u0432\u0442\u043e \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u0438\u0435 &lt;p&gt; \u0432 \u0442\u0435\u043a\u0441\u0442\u0435 \u043f\u0440\u0438 \u043f\u0435\u0440\u0435\u043d\u043e\u0441\u0435         $config-&gt;set('AutoFormat.RemoveEmpty',true); \/\/ \u0443\u0434\u0430\u043b\u044f\u0435\u0442 \u043f\u0443\u0441\u0442\u044b\u0435 \u0442\u0435\u0433\u0438, \u0435\u0441\u0442\u044c \u0438\u0441\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f*         $config-&gt;set('HTML.Doctype','HTML 4.01 Strict'); \/\/ \u043e\u0431\u0440\u0430\u0442\u0438\u0442\u0435 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u043a\u0430\u043a \u0437\u0430\u043c\u0435\u043d\u0438\u043b\u0441\u044f \u0442\u0435\u0433 &lt;strike&gt;         $purifier = new HTMLPurifier($config);         $clean_html = $purifier-&gt;purify($html); <\/code><\/pre>\n<p>  <i>* \u2014 <a href=\"http:\/\/htmlpurifier.org\/live\/configdoc\/plain.html#AutoFormat.RemoveEmpty\">\u0418\u0441\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f RemoveEmpty<\/a><\/i><\/p>\n<p>  <b>\u0418\u0441\u0445\u043e\u0434\u043d\u044b\u0439 html:<\/b>  <\/p>\n<pre><code class=\"html\">        &lt;p invalidAttribute=&quot;value&quot;&gt;\u041e, \u044f \u0445\u043e\u0447\u0443 \u0431\u0435\u0437\u0443\u043c\u043d\u043e &lt;strike&gt;\u0436\u0438\u0442\u044c&lt;\/strike&gt;:&lt;\/p&gt;         &lt;p&gt;\u0412\u0441\u0451 \u0441\u0443\u0449\u0435\u0435 - &lt;invalidTag&gt;\u0443\u0432\u0435\u043a\u043e\u0432\u0435\u0447\u0438\u0442\u044c&lt;\/invalidTag&gt;,&lt;\/p&gt;         &lt;p class=&quot;header error&quot;&gt;\u0411\u0435\u0437\u043b\u0438\u0447\u043d\u043e\u0435 - \u0432\u043e\u0447\u0435\u043b\u043e\u0432\u0435\u0447\u0438\u0442\u044c,&lt;\/p&gt;         \u041d\u0435\u0441\u0431\u044b\u0432\u0448\u0435\u0435\u0441\u044f - \u0432\u043e\u043f\u043b\u043e\u0442\u0438\u0442\u044c!         &lt;script type=&quot;text\/javascript&quot;&gt;alert(&quot;hacked by Alexander Blok&quot;);&lt;\/script&gt; <\/code><\/pre>\n<p>  <b>\u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u043f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u0444\u0443\u043d\u043a\u0446\u0438\u0438 <i>purify<\/i><\/b>  <\/p>\n<pre><code class=\"html\">        &lt;p&gt;\u041e, \u044f \u0445\u043e\u0447\u0443 \u0431\u0435\u0437\u0443\u043c\u043d\u043e &lt;span style=&quot;text-decoration:line-through;&quot;&gt;\u0436\u0438\u0442\u044c&lt;\/span&gt;:&lt;\/p&gt;         &lt;p&gt;\u0412\u0441\u0451 \u0441\u0443\u0449\u0435\u0435 - \u0443\u0432\u0435\u043a\u043e\u0432\u0435\u0447\u0438\u0442\u044c,&lt;\/p&gt;         &lt;p class=&quot;header&quot;&gt;\u0411\u0435\u0437\u043b\u0438\u0447\u043d\u043e\u0435 - \u0432\u043e\u0447\u0435\u043b\u043e\u0432\u0435\u0447\u0438\u0442\u044c,&lt;\/p&gt;         &lt;p&gt;\u041d\u0435\u0441\u0431\u044b\u0432\u0448\u0435\u0435\u0441\u044f - \u0432\u043e\u043f\u043b\u043e\u0442\u0438\u0442\u044c!&lt;\/p&gt; <\/code><\/pre>\n<p>  <a href=\"http:\/\/htmlpurifier.org\/live\/configdoc\/plain.html\">\u041a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u043d\u0430\u0441\u0442\u0440\u043e\u0435\u043a<\/a> \u0432\u043f\u0435\u0447\u0430\u0442\u043b\u044f\u0435\u0442 \u0438 \u0434\u0430\u0435\u0442 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u0438\u0437 \u043a\u043e\u0440\u043e\u0431\u043a\u0438 \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u0442\u0435 \u043f\u043b\u044e\u0448\u043a\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0443\u0436\u043d\u044b \u0438\u043c\u0435\u043d\u043d\u043e \u0432\u0430\u043c.<\/p>\n<p>  <a name=\"pearl_buttons\"><\/a>  <\/p>\n<h5>\u00ab\u041f\u0435\u0440\u043b\u0430\u043c\u0443\u0442\u0440\u043e\u0432\u044b\u0435 \u043f\u0443\u0433\u043e\u0432\u0438\u0446\u044b\u00bb<\/h5>\n<p>  \u041d\u043e \u043d\u0435 \u0431\u044b\u043b\u043e \u0431\u044b \u044d\u0442\u043e\u0433\u043e \u043f\u043e\u0441\u0442\u0430, \u0435\u0441\u043b\u0438 \u0431\u044b \u043a\u0430\u043a \u043e\u0431\u044b\u0447\u043d\u043e, \u043d\u0430\u043c \u043d\u0435 \u0437\u0430\u0445\u043e\u0442\u0435\u043b\u043e\u0441\u044c \u0447\u0435\u0433\u043e \u0442\u043e \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e\u0433\u043e, \u0430 \u0438\u043c\u0435\u043d\u043d\u043e \u0434\u0432\u0435 \u0432\u0435\u0449\u0438:  <\/p>\n<ol>\n<li>\u0417\u0430\u043c\u0435\u043d\u0438\u0442\u044c \u0432\u0441\u0435 \u0441\u0441\u044b\u043b\u043a\u0438 \u043d\u0430 \u0432\u043d\u0435\u0448\u043d\u0438\u0435 \u0441\u0430\u0439\u0442\u044b \u043d\u0430\u0448\u0435\u0439 \u0441\u0441\u044b\u043b\u043a\u043e\u0439 \u0432\u0438\u0434\u0430 site.ru\/redirect?url=link<\/li>\n<li>\u0414\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u043a\u043e \u0432\u0441\u0435\u043c \u0441\u0441\u044b\u043b\u043a\u0430\u043c \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u0439 \u0430\u0442\u0440\u0438\u0431\u0443\u0442 target=_blank<\/li>\n<\/ol>\n<p>  \u0417\u0430\u0434\u0430\u0447\u0438 \u043d\u0435 \u043f\u043e\u043a\u0430\u0437\u0430\u043b\u0438\u0441\u044c \u0441\u043b\u0438\u0448\u043a\u043e\u043c \u0441\u043b\u043e\u0436\u043d\u044b\u043c\u0438, \u043f\u043e \u043f\u0435\u0440\u0432\u043e\u0439 \u0435\u0441\u0442\u044c \u043d\u0435\u043f\u043b\u043e\u0445\u0430\u044f <a href=\"http:\/\/htmlpurifier.org\/docs\/enduser-uri-filter.html\">\u0441\u0442\u0430\u0442\u044c\u044f<\/a> \u0432 \u0434\u043e\u043a\u0430\u0445, \u0430 \u0432\u0442\u043e\u0440\u0430\u044f \u0432\u043e\u043e\u0431\u0449\u0435 \u043f\u043b\u0435\u0432\u0430\u044f \u2014 \u043a\u043e\u043d\u0444\u0438\u0433 HTML.TargetBlank \u0434\u0435\u043b\u0430\u0435\u0442 \u0440\u0430\u0431\u043e\u0442\u0443 \u0437\u0430 \u043d\u0430\u0441.<\/p>\n<h5>\u0417\u0430\u0434\u0430\u0447\u0430 1 \u2014 \u0437\u0430\u043c\u0435\u043d\u0430 \u0432\u043d\u0435\u0448\u043d\u0438\u0445 \u0441\u0441\u044b\u043b\u043e\u043a<\/h5>\n<p>  \u0423 Purifier \u0435\u0441\u0442\u044c \u0437\u0430\u043c\u0435\u0447\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u0439 \u043a\u043b\u0430\u0441\u0441 HTMLPurifier_URIFilter \u0438 \u043d\u0435 \u043c\u0435\u043d\u0435\u0435 \u0437\u0430\u043c\u0435\u0447\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u0435 <a href=\"http:\/\/repo.or.cz\/w\/htmlpurifier.git?a=tree;hb=HEAD;f=library\/HTMLPurifier\/URIFilter\">\u043f\u0440\u0438\u043c\u0435\u0440\u044b<\/a> \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0435\u0439 \u044d\u0442\u043e\u0433\u043e \u0444\u0438\u043b\u044c\u0442\u0440\u0430<br \/>  \u042f \u0432\u0437\u044f\u043b \u0437\u0430 \u043e\u0441\u043d\u043e\u0432\u0443 \u0444\u0430\u0439\u043b DisableExternalResources \u0438 \u0431\u044b\u0441\u0442\u0440\u043e \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u0430\u043b \u0435\u0433\u043e \u043f\u043e\u0434 \u0441\u0432\u043e\u0438 \u043d\u0443\u0436\u0434\u044b, \u0430 \u0438\u043c\u0435\u043d\u043d\u043e \u0437\u0430\u043c\u0435\u043d\u0430 \u0432\u043d\u0435\u0448\u043d\u0435\u0439 \u0441\u0441\u044b\u043b\u043a\u0438 \u043d\u0430 \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u044e\u044e.  <\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">\u0424\u0430\u0439\u043b \u0444\u0438\u043b\u044c\u0442\u0440\u0430<\/b><\/p>\n<div class=\"spoiler_text\">\u041d\u0435\u0431\u043e\u043b\u044c\u0448\u043e\u0435 \u043e\u043f\u0438\u0441\u0430\u043d\u0438\u0435:<br \/>  \u0412 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 <i>prepare<\/i> \u043c\u044b \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u043c \u0445\u043e\u0441\u0442 \u043d\u0430\u0448\u0435\u0433\u043e \u0441\u0430\u0439\u0442\u0430, \u0434\u0435\u043b\u0438\u043c \u043f\u043e \u0442\u043e\u0447\u043a\u0430\u043c, \u0438 \u0440\u0430\u0437\u0432\u043e\u0440\u0430\u0447\u0438\u0432\u0430\u0435\u043c \u043c\u0430\u0441\u0441\u0438\u0432.<br \/>  \u0412 \u0438\u0442\u043e\u0433\u0435 \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442 array(&#8216;ru&#8217;, &#8216;site&#8217;, &#8216;subdomen&#8217;).<br \/>  \u0412 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 <i>filter<\/i> \u043c\u044b \u0434\u0435\u043b\u0430\u0435\u043c \u0442\u043e \u0436\u0435 \u0441\u0430\u043c\u043e\u0435 \u0441 \u0441\u0441\u044b\u043b\u043a\u043e\u0439 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044f \u0438 \u0441\u0440\u0430\u0432\u043d\u0438\u0432\u0430\u0435\u043c \u0445\u043e\u0441\u0442, \u0435\u0441\u043b\u0438 \u043e\u043d \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u044b\u0439, \u0442\u043e \u043d\u0438\u0447\u0435\u0433\u043e \u043d\u0435 \u043c\u0435\u043d\u044f\u0435\u043c \u0438 \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u043c true, \u0435\u0441\u043b\u0438 \u0436\u0435 \u043d\u0435\u0442, \u0442\u043e \u0441\u043e\u0437\u0434\u0430\u0435\u043c \u043d\u043e\u0432\u044b\u0439 \u043e\u0431\u044a\u0435\u043a\u0442 URI, \u0441 \u043d\u0430\u0448\u0438\u043c \u0430\u0434\u0440\u0435\u0441\u043e\u043c \u0438 \u0432\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u043c \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u0441\u043a\u0443\u044e \u0441\u0441\u044b\u043b\u043a\u0443 \u0432 GET \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440.<br \/>  <b>\u0412\u0430\u0436\u043d\u043e<\/b> \u041c\u0435\u0442\u043e\u0434 filter \u043d\u0435 \u0434\u043e\u043b\u0436\u0435\u043d \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0442\u044c \u043d\u0438\u0447\u0435\u0433\u043e, \u043a\u0440\u043e\u043c\u0435 true \u0438\u043b\u0438 false. \u041d\u0435 \u043f\u044b\u0442\u0430\u0439\u0442\u0435\u0441\u044c \u0437\u0430\u043c\u0435\u043d\u0438\u0442\u044c \u0441\u0441\u044b\u043b\u043a\u0443 \u0432\u0435\u0440\u043d\u0443\u0432 \u0435\u0451 \u0447\u0435\u0440\u0435\u0437 return.  <\/p>\n<pre><code class=\"php\">&lt;?php class HTMLPurifier_URIFilter_MakeRedirect extends HTMLPurifier_URIFilter {     \/**      * @type string      *\/     public $name = 'MakeRedirect';      \/**      * @type array      *\/     protected $ourHostParts = false;      \/**      * @param HTMLPurifier_Config $config      * @return void      *\/     public function prepare($config)     {         $our_host = $config-&gt;getDefinition('URI')-&gt;host;         if ($our_host !== null) {             $this-&gt;ourHostParts = array_reverse(explode('.', $our_host));         }     }      \/**      * @param HTMLPurifier_URI $uri Reference      * @param HTMLPurifier_Config $config      * @param HTMLPurifier_Context $context      * @return bool      *\/     public function filter(&$uri, $config, $context)     {         if (is_null($uri-&gt;host)) {             return true;         }         if ($this-&gt;ourHostParts === false) {             return false;         }         $host_parts = array_reverse(explode('.', $uri-&gt;host));         foreach ($this-&gt;ourHostParts as $i =&gt; $x) {             if (!isset($host_parts[$i]) || $host_parts[$i] != $this-&gt;ourHostParts[$i]) {                 $path = Yii::app()-&gt;createUrl('site\/redirect'); \/\/ \u041d\u0435\u043c\u043d\u043e\u0433\u043e Yii, \u043c\u043e\u0436\u043d\u043e \u0437\u0430\u043c\u0435\u043d\u0438\u0442\u044c \u043d\u0430 \u043b\u044e\u0431\u043e\u0439 \u0432\u0430\u0448 url manager \u0438\u043b\u0438 \u043f\u0440\u043e\u0441\u0442\u043e \u0432\u043f\u0438\u0441\u0430\u0442\u044c \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0439 \u043f\u0443\u0442\u044c \u0434\u043e \u0444\u0430\u0439\u043b\u0430\/action, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u0442\u0441\u044f \u0440\u0435\u0434\u0438\u0440\u0435\u043a\u0442\u043e\u043c                 $query = 'url='.urlencode($uri-&gt;toString());                 $uri = new HTMLPurifier_URI('http',                                                null,                                                Yii::app()-&gt;request-&gt;getServerName(), \/\/ return $_SERVER['SERVER_NAME']                                               null,                                                $path,                                                $query,                                                null);                 break;             }         }         return true;     } } <\/code><\/pre>\n<p>  <\/div>\n<\/div>\n<p>  <\/p>\n<h5>\u041f\u0440\u0438\u043c\u0435\u043d\u0438\u043c \u0444\u0438\u043b\u044c\u0442\u0440<\/h5>\n<p>  \u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043a\u0430\u043a \u043f\u043e\u0434\u0441\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u044f \u043d\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u043e\u0431\u0440\u0430\u0442\u0438\u0442\u0441\u044f \u043a \u043e\u0431\u044a\u0435\u043a\u0442\u0443 HTMLPurifier_Config.  <\/p>\n<pre><code class=\"php\">        $config = HTMLPurifier_Config::createDefault();         $uri = $config-&gt;getDefinition('URI');         $uri-&gt;addFilter(new HTMLPurifier_URIFilter_MakeRedirect(), $config);         $purifier = new HTMLPurifier($config);         $clean_html = $purifier-&gt;purify($html); <\/code><\/pre>\n<p>  <\/p>\n<h6>\u0410\u0431\u0437\u0430\u0446 \u0434\u043b\u044f \u0441\u0447\u0430\u0441\u0442\u043b\u0438\u0432\u044b\u0445 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u0439 Yii<\/h6>\n<p>  \u042f \u043e\u0434\u0438\u043d \u0438\u0437 \u043d\u0438\u0445 (<s>\u0438 \u043d\u0438\u0447\u0443\u0442\u044c \u043d\u0435 \u0436\u0430\u043b\u0435\u044e<\/s>). Yii <a href=\"http:\/\/www.yiiframework.com\/doc\/api\/1.1\/CHtmlPurifier\">\u0438\u0437 \u043a\u043e\u0440\u043e\u0431\u043a\u0438<\/a> \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u0442 Purifier, \u043d\u043e \u043d\u0435 \u0432\u0441\u0435 \u0442\u0430\u043a \u0433\u043b\u0430\u0434\u043a\u043e.<br \/>  <i>\u041f\u0440\u0438\u043c\u0435\u0440 \u0438\u0437 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438:<\/i>  <\/p>\n<pre><code class=\"php\">$p = new CHtmlPurifier(); \/\/ \u043e\u0431\u0435\u0440\u0442\u043a\u0430 \u043e\u0442 Yii $p-&gt;options = array('URI.AllowedSchemes'=&gt;array('http' =&gt; true, 'https' =&gt; true,)); \/\/ \u041f\u0435\u0440\u0435\u0434\u0430\u0447\u0430 \u043a\u043e\u043d\u0444\u0438\u0433\u0430 \u0432 \u0444\u043e\u0440\u043c\u0430\u0442\u0435 \u043c\u0430\u0441\u0441\u0438\u0432\u0430 $text = $p-&gt;purify($text);  <\/code><\/pre>\n<p>  \u041e\u0442\u0442\u0443\u0434\u0430 \u0436\u0435 \u043c\u044b \u0443\u0437\u043d\u0430\u0435\u043c:  <\/p>\n<pre><code class=\"php\">         \/** \t * @var mixed the options to be passed to HTML Purifier instance. \t * This can be a HTMLPurifier_Config object,  an array of directives (Namespace.Directive =&gt; Value) \t * or the filename of an ini file. \t * @see http:\/\/htmlpurifier.org\/live\/configdoc\/plain.html \t *\/ \tprivate $_options=null; <\/code><\/pre>\n<p>  \u0412\u0440\u043e\u0434\u0435 \u0431\u044b \u0432\u0441\u0435 \u043e\u0442\u043b\u0438\u0447\u043d\u043e, \u043c\u043e\u0436\u043d\u043e \u043f\u0435\u0440\u0435\u0434\u0430\u0442\u044c \u0432\u043c\u0435\u0441\u0442\u043e \u043c\u0430\u0441\u0441\u0438\u0432\u0430 \u043e\u0431\u044a\u0435\u043a\u0442 HTMLPurifier_Config, \u043f\u0440\u043e\u0431\u0443\u0435\u043c:  <\/p>\n<pre><code class=\"php\">        $purifier = new CHtmlPurifier();         $config = HTMLPurifier_Config::createDefault();         $config-&gt;set('AutoFormat.RemoveEmpty', true);         $uri = $config-&gt;getDefinition('URI');         $uri-&gt;addFilter(new HTMLPurifier_URIFilter_MakeRedirect(), $config);         $purifier-&gt;options = $config;         $clean_html = $purifier-&gt;purify($html); <\/code><\/pre>\n<p>  <\/p>\n<pre><code class=\"php\">        Warning         Base directory \/framework\/vendors\/htmlpurifier\/standalone\/HTMLPurifier\/DefinitionCache\/Serializer does not exist,         please create or change using %Cache.SerializerPath <\/code><\/pre>\n<p>  \u0422\u0443\u0442 \u043c\u044b \u043d\u0435 \u0440\u0430\u0441\u0441\u0442\u0440\u0430\u0438\u0432\u0430\u0435\u043c\u0441\u044f \u0438 \u043b\u0435\u0437\u0435\u043c \u0432 <s>\u043c\u0430\u043d\u044b<\/s> <s>Goggle<\/s> CHtmlPurifier \u0438 \u0443\u0437\u043d\u0430\u0435\u043c \u0447\u0442\u043e \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u044c \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440 Cache.SerializerPath \u0441\u043e \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435\u043c Yii::app()-&gt;getRuntimePath(), \u044d\u0442\u043e \u0434\u0430\u0441\u0442 \u043f\u0443\u0440\u0438\u0444\u0435\u0440\u0443 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u044d\u0442\u0443 \u043f\u0430\u043f\u043a\u0443 \u0434\u043b\u044f \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u044f \u043a\u0435\u0448\u0430<br \/>  \u0414\u0435\u043b\u0430\u0435\u043c:  <\/p>\n<pre><code class=\"php\">$purifier = new CHtmlPurifier();         $config = HTMLPurifier_Config::createDefault();         $config-&gt;set('AutoFormat.RemoveEmpty', true);         $config-&gt;set('Cache.SerializerPath',Yii::app()-&gt;getRuntimePath()); \/\/ &lt;--         $uri = $config-&gt;getDefinition('URI');         $uri-&gt;addFilter(new HTMLPurifier_URIFilter_MakeRedirect(), $config);         $purifier-&gt;options = $config;         $clean_html = $purifier-&gt;purify($html); <\/code><\/pre>\n<p>  <\/p>\n<pre><code class=\"php\">Cannot set directive after finalization invoked on line 127 in file \/framework\/web\/widgets\/CHtmlPurifier.php <\/code><\/pre>\n<p>  \u0422\u0435\u043f\u0435\u0440\u044c \u043f\u0443\u0440\u0438\u0444\u0435\u0440\u0443 \u043d\u0435 \u043d\u0440\u0430\u0432\u0438\u0442\u0441\u044f, \u0447\u0442\u043e \u043c\u044b \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u0435\u043c \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440 \u0434\u0432\u0430\u0436\u0434\u044b. \u0410 \u0434\u0435\u043b\u0430\u0435\u0442 \u044d\u0442\u043e \u0441\u0430\u043c CHtmlPurifier \u0432 \u043c\u0435\u0442\u043e\u0434\u0435 createNewHtmlPurifierInstance()  <\/p>\n<pre><code class=\"php\">protected function createNewHtmlPurifierInstance() \t{ \t\t$this-&gt;_purifier=new HTMLPurifier($this-&gt;getOptions()); \t\t$this-&gt;_purifier-&gt;config-&gt;set('Cache.SerializerPath',Yii::app()-&gt;getRuntimePath()); \t\treturn $this-&gt;_purifier; \t} <\/code><\/pre>\n<p>  \u0422\u0443\u0442, \u043f\u0440\u0438\u0437\u043d\u0430\u044e\u0441\u044c, \u044f \u043f\u043e\u0442\u0440\u0430\u0442\u0438\u043b \u043d\u0435 \u043c\u0430\u043b\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0432 \u043f\u043e\u0438\u0441\u043a\u0430\u0445 \u043a\u0440\u0430\u0441\u0438\u0432\u043e\u0433\u043e \u0440\u0435\u0448\u0435\u043d\u0438\u044f, \u043d\u043e \u0443\u0432\u044b. \u041d\u0438\u0447\u0435\u0433\u043e \u0431\u043e\u043b\u0435\u0435 \u043a\u0440\u0430\u0441\u0438\u0432\u043e\u0433\u043e, \u043a\u0440\u043e\u043c\u0435 \u043a\u0430\u043a \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u043a\u043b\u0430\u0441\u0441 GHtmlPurifier \u0438 \u0443\u043d\u0430\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u044c \u0435\u0433\u043e \u043e\u0442 \u043a\u043b\u0430\u0441\u0441\u0430 CHtmlPurifier, \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u0430\u0432 \u043c\u0435\u0442\u043e\u0434 createNewHtmlPurifierInstance(), \u044f \u043d\u0435 \u043d\u0430\u0448\u0435\u043b.<br \/>  \u041d\u043e\u0432\u044b\u0439 \u0444\u0430\u0439\u043b \u043f\u043e\u043b\u043e\u0436\u0438\u043b \u0432 \u043f\u0430\u043f\u043a\u0443 <i>protected\/components\/<\/i> \u0438 \u043a\u043e\u0434 \u043d\u0430\u043a\u043e\u043d\u0435\u0446 \u0437\u0430\u0440\u0430\u0431\u043e\u0442\u0430\u043b.  <\/p>\n<pre><code class=\"php\">        $htmlpurifier = new GHtmlPurifier();         $config = HTMLPurifier_Config::createDefault();         $config-&gt;set('Cache.SerializerPath',Yii::app()-&gt;getRuntimePath());         $uri = $config-&gt;getDefinition('URI');         $uri-&gt;addFilter(new HTMLPurifier_URIFilter_MakeRedirect(), $config);         $htmlpurifier-&gt;options = $config;         return $htmlpurifier-&gt;purify($text); <\/code><\/pre>\n<p>  <\/p>\n<h5>\u0417\u0430\u0434\u0430\u0447\u0430 2 \u2014 \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u0438\u0435 target=_blank<\/h5>\n<p>  \u041d\u0435 \u0431\u0443\u0434\u0443 \u0443\u0442\u0440\u0443\u0436\u0434\u0430\u0442\u044c \u0432\u0430\u0441 \u043f\u0440\u0438\u043c\u0435\u0440\u0430\u043c\u0438 \u043d\u0435\u0440\u0430\u0431\u043e\u0447\u0435\u0433\u043e \u043a\u043e\u0434\u0430 \u0438 \u0441\u043a\u0430\u0436\u0443 \u0441\u0440\u0430\u0437\u0443, \u0447\u0442\u043e <a href=\"http:\/\/htmlpurifier.org\/live\/configdoc\/plain.html#HTML.TargetBlank\">HTML.TargetBlank<\/a> \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u0441 \u0432\u043d\u0435\u0448\u043d\u0438\u043c\u0438 \u0441\u0441\u044b\u043b\u043a\u0430\u043c\u0438 \u0438 \u0435\u0433\u043e \u043f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u0435 \u043e\u0442\u043f\u0430\u0434\u0430\u0435\u0442. \u0410 URI \u0444\u0438\u043b\u044c\u0442\u0440\u044b \u043d\u0435 \u043c\u043e\u0433\u0443\u0442 \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u0434\u043e\u0441\u0442\u0443\u043f \u043a \u0442\u0435\u0433\u0443 \u0438 \u0435\u0433\u043e \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u0430\u043c.<br \/>  \u0423\u0436\u0435 \u043f\u0440\u0438\u0432\u044b\u043a\u0448\u0438\u0439 \u043a \u0445\u043e\u0440\u043e\u0448\u0435\u0439 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438 \u043f\u043e \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0435, \u043f\u043e\u043b\u0435\u0437 \u0432 \u043c\u0430\u043d\u044b, \u043d\u043e \u0443\u0432\u044b, \u043d\u0443\u0436\u043d\u044b\u0439 \u0440\u0430\u0437\u0434\u0435\u043b <a href=\"http:\/\/htmlpurifier.org\/docs\/dev-advanced-api.html\">Advanced API<\/a> \u0431\u044b\u043b \u043f\u0443\u0441\u0442 \u0438 \u0442\u0430\u043c \u043a\u0440\u0430\u0441\u043e\u0432\u0430\u043b\u0430\u0441\u044c \u043d\u0430\u0434\u043f\u0438\u0441\u044c <i>\u00abFiled under Development\u00bb<\/i>.<br \/>  \u041d\u0438\u0447\u0435\u0433\u043e \u043d\u0435 \u043e\u0441\u0442\u0430\u0432\u0430\u043b\u043e\u0441\u044c, \u043a\u0430\u043a \u043f\u043e\u0433\u0440\u0443\u0437\u0438\u0442\u0441\u044f \u0432 \u0438\u0441\u0445\u043e\u0434\u043d\u0438\u043a\u0438 \u0438 \u043d\u0430\u0439\u0442\u0438 \u043a\u0430\u043a \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d \u043c\u043e\u0434\u0443\u043b\u044c HTML.TargetBlank.<br \/>  \u0412\u043e\u0442 \u043e\u043d:  <\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">HTMLPurifier_AttrTransform_TargetBlank<\/b><\/p>\n<div class=\"spoiler_text\">\n<pre><code class=\"php\">\/**  * Adds target=&quot;blank&quot; to all outbound links.  This transform is  * only attached if Attr.TargetBlank is TRUE.  This works regardless  * of whether or not Attr.AllowedFrameTargets  *\/ class HTMLPurifier_AttrTransform_TargetBlank extends HTMLPurifier_AttrTransform {     private $parser;      public function __construct() {         $this-&gt;parser = new HTMLPurifier_URIParser();     }      public function transform($attr, $config, $context) {          if (!isset($attr['href'])) {             return $attr;         }          \/\/ XXX Kind of inefficient         $url = $this-&gt;parser-&gt;parse($attr['href']);         $scheme = $url-&gt;getSchemeObj($config, $context);          if ($scheme-&gt;browsable && !$url-&gt;isBenign($config, $context)) {             $attr['target'] = '_blank';         }          return $attr;      }  } <\/code><\/pre>\n<p>  <\/div>\n<\/div>\n<p>  \u0411\u044b\u043b\u043e \u0440\u0435\u0448\u0435\u043d\u043e \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0439 \u043c\u043e\u0434\u0443\u043b\u044c, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043d\u0435 \u0431\u0443\u0434\u0435\u0442 \u0432\u043a\u043b\u044e\u0447\u0430\u0442\u044c \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0443 \u043d\u0430 \u0432\u043d\u0435\u0448\u043d\u0438\u0439 \u0430\u0434\u0440\u0435\u0441, \u0430 \u0434\u043e\u0431\u0430\u0432\u0438\u0442 target=_blank \u0432\u0441\u0435\u043c \u0441\u0441\u044b\u043b\u043a\u0430\u043c, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0430\u0439\u0434\u0435\u0442.<br \/>  \u0414\u0443\u043c\u0430\u044e \u0441 \u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435\u043c \u0438 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u0435\u043c \u043f\u0430\u0440\u044b \u0441\u0442\u0440\u043e\u043a \u0432 \u043c\u0435\u0442\u043e\u0434\u0435 transform \u0441\u043f\u0440\u0430\u0432\u0438\u0442\u0441\u044f \u043a\u0430\u0436\u0434\u044b\u0439. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u043b\u0438\u0441\u0442\u0438\u043d\u0433 \u043f\u0440\u0438\u0432\u043e\u0434\u0438\u0442\u044c \u043d\u0435 \u0431\u0443\u0434\u0443. \u0412\u0430\u0436\u043d\u043e \u043d\u0435 \u0437\u0430\u0431\u044b\u0442\u044c \u043f\u043e\u043c\u0435\u043d\u044f\u0442\u044c \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u0435 \u0432\u0430\u0448\u0435\u0433\u043e \u043c\u043e\u0434\u0443\u043b\u044f, \u044f \u043d\u0430\u0437\u0432\u0430\u043b \u0435\u0433\u043e <i>HTMLPurifier_AttrTransform_TargetBlankAll<\/i> \u0438 \u043f\u043e\u043b\u043e\u0436\u0438\u043b \u0432 \u0442\u0443 \u0436\u0435 \u043f\u0430\u043f\u043a\u0443 \/protected\/components\/.<br \/>  \u041d\u043e \u044d\u0442\u043e\u0433\u043e \u043e\u043a\u0430\u0437\u0430\u043b\u043e\u0441\u044c \u043d\u0435 \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e, \u043c\u043e\u0434\u0443\u043b\u044c \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043d\u0435 \u043f\u043e\u0434\u0446\u0435\u043f\u043b\u044f\u0435\u0442\u0441\u044f, \u0438 \u043d\u0430\u043c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u043a\u043b\u0430\u0441\u0441, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0434\u043e\u0431\u0430\u0432\u0438\u0442 \u043c\u043e\u0434\u0443\u043b\u044c \u0432 \u043d\u0430\u0448\u0443 \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u044e. \u0412 \u043a\u043e\u0434\u0435 \u044f \u0434\u043e\u0431\u0430\u0432\u0438\u043b \u043f\u0430\u0440\u0443 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u0435\u0432, \u0447\u0442\u043e \u0431\u044b\u043b\u043e \u043f\u043e\u043d\u044f\u0442\u043d\u043e, \u0447\u0442\u043e \u043d\u0443\u0436\u043d\u043e \u0438\u0437\u043c\u0435\u043d\u0438\u0442\u044c, \u0435\u0441\u043b\u0438 \u0432\u044b \u0437\u0430\u0445\u043e\u0442\u0438\u0442\u0435 \u043d\u0430\u043f\u0438\u0441\u0430\u0442\u044c \u0441\u0432\u043e\u0439 \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0439 \u043c\u043e\u0434\u0443\u043b\u044c.  <\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">HTMLPurifier_HTMLModule_TargetBlankAll.php<\/b><\/p>\n<div class=\"spoiler_text\">\n<pre><code class=\"php\">class HTMLPurifier_HTMLModule_TargetBlankAll extends HTMLPurifier_HTMLModule {      public $name = 'TargetBlankAll'; \/\/ \u042d\u0442\u043e \u0438\u043c\u044f \u0431\u0443\u0434\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u0432 \u043a\u043e\u043d\u0444\u0438\u0433\u0435. \u041d\u0435 \u0437\u0430\u0431\u0443\u0434\u044c\u0442\u0435 \u0435\u0433\u043e \u043f\u043e\u043c\u0435\u043d\u044f\u0442\u044c      public function setup($config) {         $a = $this-&gt;addBlankElement('a'); \/\/ \u0423\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u043c, \u0447\u0442\u043e \u043c\u043e\u0434\u0443\u043b\u044c \u0434\u043e\u043b\u0436\u0435\u043d \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u0442\u044c\u0441\u044f \u043a\u043e \u0432\u0441\u0435\u043c \u0442\u0435\u0433\u0430\u043c A         $a-&gt;attr_transform_post[] = new HTMLPurifier_AttrTransform_TargetBlankAll(); \/\/ \u0417\u0430\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u043c \u043d\u0430\u0448 \u043a\u043e\u043d\u0444\u0438\u0433 \u0432 \u043c\u0430\u0441\u0441\u0438\u0432 \u041f\u041e\u0421\u0422\u0444\u0438\u043b\u044c\u0442\u0440\u043e\u0432         \/\/ \u0422\u0430\u043a \u0436\u0435 \u0435\u0441\u0442\u044c \u043c\u0430\u0441\u0441\u0438\u0432 \u041f\u0420\u0415\u0444\u0438\u043b\u044c\u0442\u0440\u043e\u0432 $a-&gt;attr_transform_pre[]     }  } <\/code><\/pre>\n<p>  <\/div>\n<\/div>\n<p>  \u042d\u0442\u043e\u0442 \u0444\u0430\u0439\u043b \u044f \u0442\u0430\u043a \u0436\u0435 \u0441\u043b\u043e\u0436\u0438\u043b \u0432 \u043f\u0430\u043f\u043a\u0443 \/protected\/components.<br \/>  \u0422\u0435\u043f\u0435\u0440\u044c \u043e\u0441\u0442\u0430\u043b\u043e\u0441\u044c \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u044d\u0442\u043e\u0442 \u043c\u043e\u0434\u0443\u043b\u044c \u0432 \u043d\u0430\u0448 \u043a\u043e\u043d\u0444\u0438\u0433 \u0438 \u043d\u0430\u0441\u043b\u0430\u0436\u0434\u0430\u0442\u044c\u0441\u044f \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u043e\u043c. \u0414\u0435\u043b\u0430\u0435\u0442\u0441\u044f, \u044d\u0442\u043e \u043d\u0435 \u0441\u043e\u0432\u0441\u0435\u043c \u043b\u043e\u0433\u0438\u0447\u043d\u043e. \u041c\u044b \u0434\u043e\u043b\u0436\u043d\u044b \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u0441\u0441\u044b\u043b\u043a\u0443 \u043d\u0430 \u043e\u0431\u044a\u0435\u043a\u0442 HTML, \u043f\u0440\u0438\u0447\u0435\u043c \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u043e \u0441 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u043c $raw = true, \u0447\u0442\u043e \u0431\u044b \u043e\u043d \u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043b\u0441\u044f \u0438 \u0441\u0440\u0430\u0431\u043e\u0442\u0430\u043b \u043c\u0435\u0442\u043e\u0434 __construct() \u0432 \u043a\u043b\u0430\u0441\u0441 HTMLPurifier_HTMLDefinition.<br \/>  \u0412 \u043c\u0435\u0442\u043e\u0434\u0435 __construct() \u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u0430\u044f $this-&gt;manager, \u043a\u043e\u0442\u043e\u0440\u0443\u044e \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c, \u0434\u043b\u044f \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f \u043d\u0430\u0448\u0435\u0433\u043e \u043c\u043e\u0434\u0443\u043b\u044f.  <\/p>\n<pre><code class=\"php\">        $htmlpurifier = new GHtmlPurifier();         $config = HTMLPurifier_Config::createDefault();         $config-&gt;set('Cache.SerializerPath',Yii::app()-&gt;getRuntimePath());         $uri = $config-&gt;getDefinition('URI');         $uri-&gt;addFilter(new HTMLPurifier_URIFilter_MakeRedirect(), $config);         $html = $config-&gt;getHTMLDefinition(true); \/\/ \u041f\u043e\u043b\u0443\u0447\u0430\u0435\u043c \u0441\u0441\u044b\u043b\u043a\u0443 \u043d\u0430 \u043e\u0431\u044a\u0435\u043a\u0442 HTMLPurifier_HTMLDefinition         $html-&gt;manager-&gt;addModule('TargetBlankAll'); \/\/ \u0414\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u043c\u043e\u0434\u0443\u043b\u044c \u0447\u0435\u0440\u0435\u0437 \u043c\u0430\u043d\u0430\u0436\u0435\u0440 \u043c\u043e\u0434\u0443\u043b\u0435\u0439         $htmlpurifier-&gt;options = $config;         return $htmlpurifier-&gt;purify($text); <\/code><\/pre>\n<p>  <b>\u0422\u0430-\u0434\u0430\u043c:<\/b>  <\/p>\n<pre><code class=\"html\">&lt;a href=&quot;http:\/\/site.ru\/&quot;&gt;http:\/\/site.ru&lt;\/a&gt; &lt;a href=&quot;http:\/\/habrahabr.ru\/&quot;&gt;http:\/\/habrahabr.ru&lt;\/a&gt; <\/code><\/pre>\n<p>  <\/p>\n<pre><code class=\"html\">&lt;a href=&quot;http:\/\/site.ru\/&quot; target=&quot;_blank&quot;&gt;http:\/\/site.ru&lt;\/a&gt; &lt;a href=&quot;http:\/\/site.ru\/redirect\/?url=http%3A%2F%2Fhabrahabr.ru%2F&quot; target=&quot;_blank&quot;&gt;http:\/\/habrahabr.ru&lt;\/a&gt; <\/code><\/pre>\n<p>  \u041e\u0431\u0435 \u0437\u0430\u0434\u0430\u0447\u0438 \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u044b!  <\/p>\n<hr\/>\n<p>  \u041d\u0430\u0434\u0435\u044e\u0441\u044c \u044d\u0442\u0430 \u0441\u0442\u0430\u0442\u044c\u044f \u043f\u043e\u0437\u043d\u0430\u043a\u043e\u043c\u0438\u043b\u0430 \u0432\u0430\u0441 \u0441 \u044d\u0442\u0438\u043c \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u044b\u043c \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u043e\u043c \u0438 \u043f\u043e\u043c\u043e\u0436\u0435\u0442 \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0432\u0430\u0448 \u0441\u0430\u0439\u0442 \u043e\u0434\u043d\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u043e \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u0435\u0435 \u0438 \u0431\u0435\u0437\u043e\u043f\u0430\u0441\u043d\u0435\u0435, \u0434\u0430\u0432 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u0432\u0430\u0448\u0438\u043c \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044f \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u0442\u044c \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u044b\u0439 \u043a\u043e\u043d\u0442\u0435\u043d\u0442, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f \u0432\u0441\u0435 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0438 html.<\/p>\n<p>  <i>\u042d\u0442\u043e \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430 \u043d\u0435 \u043e\u0442\u043b\u0438\u0447\u0430\u0435\u0442\u0441\u044f \u0431\u044b\u0441\u0442\u0440\u043e\u0439, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043d\u0435 \u0441\u0442\u043e\u0438\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0435\u0451 \u0434\u043b\u044f \u0432\u044b\u0432\u043e\u0434\u0430 \u0434\u0430\u043d\u043d\u044b\u0445 \u043d\u0430 \u043b\u0435\u0442\u0443.<\/i>    \t<\/p>\n<div class=\"clear\"><\/div>\n<\/p><\/div>\n<p> \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"http:\/\/habrahabr.ru\/company\/smartprogress\/blog\/202188\/\"> http:\/\/habrahabr.ru\/company\/smartprogress\/blog\/202188\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<div class=\"content html_format\">   \t<img decoding=\"async\" src=\"http:\/\/habr.habrastorage.org\/post_images\/7b4\/44e\/925\/7b444e9250e31a0f845e8e5f54936935.jpg\"\/><br \/>  <i>\u0411\u0443\u043a\u0432\u0430\u043b\u044c\u043d\u043e \u043f\u0430\u0440\u0443 \u0430\u0431\u0437\u0430\u0446\u0435\u0432 \u044f \u0443\u0434\u0435\u043b\u044e \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e\u0441\u0442\u044f\u043c \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u044d\u0442\u043e\u0439 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 \u0441 \u0444\u0440\u0435\u0439\u043c\u0432\u043e\u0440\u043a\u043e\u043c Yii, \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u043e\u0435 \u0436\u0435 \u0432 \u043f\u043e\u043b\u043d\u043e\u0439 \u043c\u0435\u0440\u0435 \u0443\u043d\u0438\u0432\u0435\u0440\u0441\u0430\u043b\u044c\u043d\u043e \u0438 \u0431\u0443\u0434\u0435\u0442 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e \u0432\u0441\u0435\u043c, \u043a\u0442\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u0438\u043b\u0438 \u043f\u043b\u0430\u043d\u0438\u0440\u0443\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u044d\u0442\u0443 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0443<\/i><\/p>\n<p>  <i>\u0415\u0441\u043b\u0438 \u0432\u044b \u0443\u0436\u0435 \u0445\u043e\u0440\u043e\u0448\u043e \u0437\u043d\u0430\u043a\u043e\u043c\u044b \u0441 Purifier \u0442\u043e \u043c\u043e\u0436\u0435\u0442\u0435 \u0441\u043c\u0435\u043b\u043e \u043d\u0430\u0447\u0438\u043d\u0430\u0442\u044c \u0447\u0438\u0442\u0430\u0442\u044c <a href=\"#pearl_buttons\">\u043e\u0442\u0441\u044e\u0434\u0430<\/a><\/i><\/p>\n<h5>\u041d\u0435\u043c\u043d\u043e\u0433\u043e \u043e HTML Purifier<\/h5>\n<p>  \u0415\u0441\u043b\u0438 \u0432\u044b \u043d\u0435 \u0441\u043b\u044b\u0448\u0430\u043b\u0438 \u043e \u0442\u0430\u043a\u043e\u0439 \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u043e\u0439 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0435 (\u0430 \u043f\u043e\u0438\u0441\u043a \u043d\u0430 \u0425\u0430\u0431\u0440\u0435 \u0433\u043e\u0432\u043e\u0440\u0438\u0442 \u043e \u043d\u0435 \u0442\u0430\u043a\u043e\u0439 \u0443\u0436 \u0431\u043e\u043b\u044c\u0448\u043e\u0439 \u043f\u043e\u043f\u0443\u043b\u044f\u0440\u043d\u043e\u0441\u0442\u0438) \u043a\u0430\u043a <a href=\"http:\/\/htmlpurifier.org\/\">HTML Purifier<\/a>, \u0442\u043e \u0441\u043e\u0432\u0435\u0442\u0443\u044e \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u043e \u043a \u043d\u0435\u0439 \u043f\u0440\u0438\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c\u0441\u044f, \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e \u0435\u0441\u043b\u0438 \u0432\u0430\u0448\u0438 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0438 \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u0443\u044e\u0442 \u043a\u043e\u043d\u0442\u0435\u043d\u0442 \u0432 html \u0444\u043e\u0440\u043c\u0430\u0442\u0435. \u042d\u0442\u043e \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u0440\u044f\u0434\u043e\u0432\u043e\u0439 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c, \u043c\u043e\u0434\u0435\u0440\u0430\u0442\u043e\u0440 \u0438\u043b\u0438 \u0434\u0430\u0436\u0435 \u0430\u0434\u043c\u0438\u043d\u0438\u0441\u0442\u0440\u0430\u0442\u043e\u0440.<br \/>  \u0427\u0442\u043e \u0436\u0435 \u0434\u0435\u043b\u0430\u0435\u0442 \u044d\u0442\u0430 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430?<br \/>  \u0421\u043e\u0433\u043b\u0430\u0441\u043d\u043e \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u0438 \u043e\u043d\u0430 \u043e\u0447\u0438\u0449\u0430\u0435\u0442 \u043b\u044e\u0431\u043e\u0439 html \u043a\u043e\u0434 \u043e\u0442 \u0432\u0441\u0435\u0445 \u0432\u0440\u0435\u0434\u043e\u043d\u043e\u0441\u043d\u044b\u0445, \u043d\u0435\u0432\u0430\u043b\u0438\u0434\u043d\u044b\u0445, \u0437\u0430\u043f\u0440\u0435\u0449\u0435\u043d\u043d\u044b\u0445 (\u0432\u0430\u0448\u0435\u0439 \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u0435\u0439) \u0447\u0430\u0441\u0442\u0435\u0439 \u043a\u043e\u0434\u0430, \u0432 \u0442\u043e\u043c \u0447\u0438\u0441\u043b\u0435 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0435 \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u044b.  <\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-202188","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/202188","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=202188"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/202188\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=202188"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=202188"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=202188"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}