<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	xmlns:series="http://unfoldingneurons.com/"
	>

<channel>
	<title>sorgalla.com &#187; Zend_View_Helper</title>
	<atom:link href="http://sorgalla.com/tag/zend_view_helper/feed/" rel="self" type="application/rss+xml" />
	<link>http://sorgalla.com</link>
	<description>PHP, Zend Framework, Datenbanken und was sonst noch so anfällt.</description>
	<lastBuildDate>Tue, 05 Jul 2011 07:20:05 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.3.1</generator>
		<item>
		<title>HTMLPurifier mit dem Zend Framework nutzen, Teil 2</title>
		<link>http://sorgalla.com/2009/12/12/htmlpurifier-mit-dem-zend-framework-nutzen-teil-2/</link>
		<comments>http://sorgalla.com/2009/12/12/htmlpurifier-mit-dem-zend-framework-nutzen-teil-2/#comments</comments>
		<pubDate>Sat, 12 Dec 2009 19:33:33 +0000</pubDate>
		<dc:creator>jan</dc:creator>
				<category><![CDATA[Zend Framework]]></category>
		<category><![CDATA[HTMLPurifier]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[XSS]]></category>
		<category><![CDATA[Zend_View_Helper]]></category>

		<guid isPermaLink="false">http://sorgalla.com/?p=179</guid>
		<description><![CDATA[Im ersten Teil haben wir uns mit der Installation und Integration von HTMLPurifier als Filter für Eingaben beschäftigt. Diesmal geht es um darum Ausgaben entsprechend zu filtern, getreu dem Motto &#8220;Filter input, Escape output&#8221;. Erstellung eines View Helpers Um Variablen in View-Skripten zu escapen, bietet sich ein View Helper an. Wir erstellen uns den Helper [...]]]></description>
			<content:encoded><![CDATA[<p>Im <a href="/2009/12/09/htmlpurifier-mit-dem-zend-framework-nutzen/">ersten Teil</a> haben wir uns mit der Installation und Integration von HTMLPurifier als Filter für Eingaben beschäftigt. Diesmal geht es um darum Ausgaben entsprechend zu filtern, getreu dem Motto &#8220;Filter input, Escape output&#8221;.<span id="more-179"></span></p>
<h3>Erstellung eines View Helpers</h3>
<p>Um Variablen in View-Skripten zu escapen, bietet sich ein <a href="http://framework.zend.com/manual/en/zend.view.helpers.html">View Helper</a> an.</p>
<p>Wir erstellen uns den Helper in <code>library/App/View/Helper/HtmlPurifier.php</code>:</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #339933;">&amp;</span>lt<span style="color: #339933;">;</span>?php
<span style="color: #009933; font-style: italic;">/**
 * @see Zend_View_Helper_Abstract
 */</span>
<span style="color: #b1b100;">require_once</span> <span style="color: #0000ff;">'Zend/View/Helper/Abstract.php'</span><span style="color: #339933;">;</span>
&nbsp;
<span style="color: #009933; font-style: italic;">/**
 * @see App_Filter_HtmlPurifier
 */</span>
<span style="color: #b1b100;">require_once</span> <span style="color: #0000ff;">'App/Filter/HtmlPurifier.php'</span><span style="color: #339933;">;</span>
&nbsp;
<span style="color: #009933; font-style: italic;">/**
 * @category App
 * @package App_View
 * @subpackage Helper
 */</span>
<span style="color: #000000; font-weight: bold;">class</span> Zend_View_Helper_HtmlPurifier <span style="color: #000000; font-weight: bold;">extends</span> Zend_View_Helper_Abstract
<span style="color: #009900;">&#123;</span>
    <span style="color: #009933; font-style: italic;">/**
     * Returns the string $value, purified by HTMLPurifier
     *
     * @param string $value
     * @param mixed $config
     * @return string
     */</span>
    <span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000000; font-weight: bold;">function</span> htmlPurifier<span style="color: #009900;">&#40;</span><span style="color: #000088;">$value</span><span style="color: #339933;">,</span> <span style="color: #000088;">$config</span> <span style="color: #339933;">=</span> <span style="color: #009900; font-weight: bold;">null</span><span style="color: #009900;">&#41;</span>
    <span style="color: #009900;">&#123;</span>
        <span style="color: #000088;">$filter</span> <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> App_Filter_HtmlPurifier<span style="color: #009900;">&#40;</span><span style="color: #000088;">$config</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
        <span style="color: #b1b100;">return</span> <span style="color: #000088;">$filter</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">filter</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$value</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    <span style="color: #009900;">&#125;</span>
<span style="color: #009900;">&#125;</span></pre></div></div>

<p>Der Code ist relativ simpel, da wir einfach unseren bereits erstellten Filter nutzen.</p>
<p>Nun müssen wir dem <code>Zend_View</code>-Objekt den <a href="http://framework.zend.com/manual/en/zend.view.helpers.html#zend.view.helpers.paths">Helper-Pfad</a> mitteilen:</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000088;">$view</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">setHelperPath</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'App/View/Helper'</span><span style="color: #339933;">,</span> <span style="color: #0000ff;">'App_View_Helper'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></div></div>

<p>Oder alternativ, falls <a href="http://framework.zend.com/manual/en/zend.application.available-resources.html#zend.application.available-resources.view">Zend_Application</a> genutzt wird, folgendes in die application.ini eintragen:</p>

<div class="wp_syntax"><div class="code"><pre class="text" style="font-family:monospace;">resources.view.helperPath.app.App_View_Helper = &quot;App/View/Helper&quot;</pre></div></div>

<p>Und so lässt sich dann der View Helper in den View-Skripten nutzen:</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;">&lt;p&gt;
    <span style="color: #000000; font-weight: bold;">&lt;?php</span> <span style="color: #b1b100;">echo</span> <span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">htmlPurifier</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">comment_text</span><span style="color: #339933;">,</span> <span style="color: #990000;">array</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'HTML.Allowed'</span> <span style="color: #339933;">=&gt;</span> <span style="color: #0000ff;">'b,strong,a[href]'</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span> <span style="color: #000000; font-weight: bold;">?&gt;</span>
&lt;/p&gt;</pre></div></div>

<h3>Links zum Thema</h3>
<ul>
<li><a href="http://htmlpurifier.org">HTMLPurifier</a></li>
<li><a href="http://framework.zend.com/manual/en/zend.view.helpers.html">Zend_View-Helpers</a></li>
</ul>
<div class="tweetthis" style="text-align:left;"><p> <a target="_blank" class="tt" href="http://twitter.com/intent/tweet?text=HTMLPurifier+mit+dem+Zend+Framework+nutzen%2C+Teil+2+http%3A%2F%2Fsorgalla.com%2F%3Fp%3D179+%2Fby+%40jansor" title="Post to Twitter"><img class="nothumb" src="http://sorgalla.com/wp-content/plugins/tweet-this/icons/en/twitter/tt-twitter3.png" alt="Post to Twitter" /></a> <a target="_blank" class="tt" href="http://delicious.com/post?url=http://sorgalla.com/2009/12/12/htmlpurifier-mit-dem-zend-framework-nutzen-teil-2/&amp;title=HTMLPurifier+mit+dem+Zend+Framework+nutzen%2C+Teil+2" title="Post to Delicious"><img class="nothumb" src="http://sorgalla.com/wp-content/plugins/tweet-this/icons/en/delicious/tt-delicious.png" alt="Post to Delicious" /></a> <a target="_blank" class="tt" href="http://digg.com/submit?url=http://sorgalla.com/2009/12/12/htmlpurifier-mit-dem-zend-framework-nutzen-teil-2/&amp;title=HTMLPurifier+mit+dem+Zend+Framework+nutzen%2C+Teil+2" title="Post to Digg"><img class="nothumb" src="http://sorgalla.com/wp-content/plugins/tweet-this/icons/en/digg/tt-digg.png" alt="Post to Digg" /></a> <a target="_blank" class="tt" href="http://www.facebook.com/share.php?u=http://sorgalla.com/2009/12/12/htmlpurifier-mit-dem-zend-framework-nutzen-teil-2/&amp;t=HTMLPurifier+mit+dem+Zend+Framework+nutzen%2C+Teil+2" title="Post to Facebook"><img class="nothumb" src="http://sorgalla.com/wp-content/plugins/tweet-this/icons/en/facebook/tt-facebook.png" alt="Post to Facebook" /></a> <a target="_blank" class="tt" href="http://reddit.com/submit?url=http://sorgalla.com/2009/12/12/htmlpurifier-mit-dem-zend-framework-nutzen-teil-2/&amp;title=HTMLPurifier+mit+dem+Zend+Framework+nutzen%2C+Teil+2" title="Post to Reddit"><img class="nothumb" src="http://sorgalla.com/wp-content/plugins/tweet-this/icons/en/reddit/tt-reddit.png" alt="Post to Reddit" /></a></p></div>]]></content:encoded>
			<wfw:commentRss>http://sorgalla.com/2009/12/12/htmlpurifier-mit-dem-zend-framework-nutzen-teil-2/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
	
		<series:name><![CDATA[HTMLPurifier mit dem Zend Framework nutzen]]></series:name>
	</item>
	</channel>
</rss>

