<?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/"
	>

<channel>
	<title>Zihni Kaya &#187; htmlentities</title>
	<atom:link href="http://www.zihni.net/tag/htmlentities/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.zihni.net</link>
	<description></description>
	<lastBuildDate>Wed, 16 Nov 2011 07:22:20 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.1.3</generator>
		<item>
		<title>Güvenli PHP Uygulamaları &#8211; Cross site scripting(XSS)</title>
		<link>http://www.zihni.net/php/guvenli-php-uygulamalari-cross-site-scripting-xss/</link>
		<comments>http://www.zihni.net/php/guvenli-php-uygulamalari-cross-site-scripting-xss/#comments</comments>
		<pubDate>Fri, 13 Feb 2009 22:42:39 +0000</pubDate>
		<dc:creator>Zihni</dc:creator>
				<category><![CDATA[PHP]]></category>
		<category><![CDATA[güvenlik]]></category>
		<category><![CDATA[htmlentities]]></category>

		<guid isPermaLink="false">http://www.zihni.net/?p=417</guid>
		<description><![CDATA[Kullanıcının betiklerimize html kodu enjekte etmesiyle ortaya çıkar. Girdi filtrelenmeden çıktı olarak sunuluyorsa bu saldıya uğranabilir. Aşağıdaki gibi bir formumuz olsun: 1 2 3 4 &#60;form id=&#34;form1&#34; action=&#34;&#34; method=&#34;post&#34;&#62; &#60;textarea name=&#34;mesaj&#34;&#62;&#60;/textarea&#62; &#60;input type=&#34;submit&#34; value=&#34;gönder&#34; /&#62; &#60;/form&#62; Formdaki mesaj alanına aşağıdaki javascript kodunun enjekte edildiğini varsayalım. 1 2 3 &#60;?php &#60;script type=&#34;text/javascript&#34;&#62;window.location = 'http://www.zihni.net' &#60;/script&#62; ?&#62; [...]]]></description>
			<content:encoded><![CDATA[<p>Kullanıcının betiklerimize html kodu enjekte etmesiyle ortaya çıkar.<br />
Girdi filtrelenmeden çıktı olarak sunuluyorsa bu saldıya uğranabilir.</p>
<p>Aşağıdaki gibi bir formumuz olsun:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
</pre></td><td class="code"><pre class="javascript" style="font-family:monospace;"><span style="color: #339933;">&lt;</span>form id<span style="color: #339933;">=</span><span style="color: #3366CC;">&quot;form1&quot;</span> action<span style="color: #339933;">=</span><span style="color: #3366CC;">&quot;&quot;</span> method<span style="color: #339933;">=</span><span style="color: #3366CC;">&quot;post&quot;</span><span style="color: #339933;">&gt;</span>
<span style="color: #339933;">&lt;</span>textarea <span style="color: #000066;">name</span><span style="color: #339933;">=</span><span style="color: #3366CC;">&quot;mesaj&quot;</span><span style="color: #339933;">&gt;&lt;/</span>textarea<span style="color: #339933;">&gt;</span>
<span style="color: #339933;">&lt;</span>input type<span style="color: #339933;">=</span><span style="color: #3366CC;">&quot;submit&quot;</span> value<span style="color: #339933;">=</span><span style="color: #3366CC;">&quot;gönder&quot;</span> <span style="color: #339933;">/&gt;</span>
<span style="color: #339933;">&lt;/</span>form<span style="color: #339933;">&gt;</span></pre></td></tr></table></div>

<p>Formdaki mesaj alanına  aşağıdaki javascript kodunun enjekte edildiğini varsayalım.</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
</pre></td><td class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">&lt;?php</span> 
<span style="color: #339933;">&lt;</span>script type<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;text/javascript&quot;</span><span style="color: #339933;">&gt;</span>window<span style="color: #339933;">.</span>location <span style="color: #339933;">=</span> <span style="color: #0000ff;">'http://www.zihni.net'</span> <span style="color: #000000; font-weight: bold;">&lt;/script&gt;</span>
<span style="color: #000000; font-weight: bold;">?&gt;</span></pre></td></tr></table></div>

<p>Girdiyi filtrelemeden, aşağıdaki şekilde ekrana yazdırırsak, sayfaya giren her kullanıcıyı istediğimiz siteye yönlendiririz.</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
</pre></td><td class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">&lt;?php</span> 
<span style="color: #990000;">echo</span> <span style="color: #000088;">$_POST</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'mesaj'</span><span style="color: #009900;">&#93;</span><span style="color: #339933;">;</span>
<span style="color: #000000; font-weight: bold;">?&gt;</span></pre></td></tr></table></div>

<p>Yukardaki kodun zararlı etkilerinden korunmak için girdiyi <i>htmlentities()</i> işleviyle filtrelememiz gerekir.</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
</pre></td><td class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">&lt;?php</span> 
<span style="color: #990000;">echo</span> <span style="color: #990000;">htmlentities</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$_POST</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'mesaj'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #000000; font-weight: bold;">?&gt;</span></pre></td></tr></table></div>

]]></content:encoded>
			<wfw:commentRss>http://www.zihni.net/php/guvenli-php-uygulamalari-cross-site-scripting-xss/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>Güvenli PHP Uygulamaları &#8211; Kullanıcı Girdilerinin Filtrelenmesi</title>
		<link>http://www.zihni.net/php/kullanici-girdilerini-filtrelenmesi/</link>
		<comments>http://www.zihni.net/php/kullanici-girdilerini-filtrelenmesi/#comments</comments>
		<pubDate>Mon, 02 Feb 2009 04:26:20 +0000</pubDate>
		<dc:creator>Zihni</dc:creator>
				<category><![CDATA[PHP]]></category>
		<category><![CDATA[htmlentities]]></category>
		<category><![CDATA[strip_tags]]></category>

		<guid isPermaLink="false">http://www.zihni.net/?p=316</guid>
		<description><![CDATA[Kullanıcı girdilerine güvenilmemeli, betiklerimizin güvenliği için tüm girdiler filtrelenmelidir. Örneğin kullanıcıdan yaş bilgisini isteyelim: Kullanıcıdan beklenen girdi, sayı türünde bir değerdir. Aşağıdaki kod bu doğrulamayı yapar. $sonuc = preg_match&#40;&#34;/[0-9]{1,3}/&#34;,$_POST&#91;'yas'&#93;&#41;; if&#40;$sonuc === true&#41; echo &#34;Girdi doğrulandı&#34;; else echo &#34;Girdi sayı değil&#34;; Kullanıcının hayat hikayesini istediğimizi varsayalım, yukardaki gibi bir basit bir doğrulama yapamayız, bunun yerine php [...]]]></description>
			<content:encoded><![CDATA[<p>Kullanıcı girdilerine güvenilmemeli, betiklerimizin güvenliği için<br />
tüm girdiler filtrelenmelidir.</p>
<p>Örneğin kullanıcıdan yaş bilgisini isteyelim:</p>
<p>Kullanıcıdan beklenen girdi, sayı türünde bir değerdir.<br />
Aşağıdaki kod bu doğrulamayı yapar.</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000088;">$sonuc</span> <span style="color: #339933;">=</span> <span style="color: #990000;">preg_match</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">&quot;/[0-9]{1,3}/&quot;</span><span style="color: #339933;">,</span><span style="color: #000088;">$_POST</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'yas'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #b1b100;">if</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$sonuc</span> <span style="color: #339933;">===</span> <span style="color: #000000; font-weight: bold;">true</span><span style="color: #009900;">&#41;</span>
<span style="color: #990000;">echo</span> <span style="color: #0000ff;">&quot;Girdi doğrulandı&quot;</span><span style="color: #339933;">;</span>
<span style="color: #b1b100;">else</span>
<span style="color: #990000;">echo</span> <span style="color: #0000ff;">&quot;Girdi sayı değil&quot;</span><span style="color: #339933;">;</span></pre></div></div>

<p>Kullanıcının hayat hikayesini istediğimizi varsayalım, yukardaki gibi bir basit bir doğrulama yapamayız, bunun yerine php nin bize sunduğu temel filtreleme işlevlerinden yararlanabiliriz.<br />
Html tagları sorunlara yol açabilir.<br />
stript_tags() işlevi html etiketlerini yok eder.</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000088;">$girdi</span> <span style="color: #339933;">=</span> <span style="color: #0000ff;">&quot;&lt;h1&gt;büyük bi başlık&lt;/h1&gt;&lt;span&gt;span etiketi&lt;/span&gt;&quot;</span><span style="color: #339933;">;</span>
<span style="color: #990000;">echo</span> <span style="color: #990000;">strip_tags</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$girdi</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></div></div>

<p>Yukardaki örneğin çıktısı:</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;">büyük bi başlık span etiketi</pre></div></div>

<p>Bazı etiketlere izin vermek istiyorsak:</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000088;">$girdi</span> <span style="color: #339933;">=</span> <span style="color: #0000ff;">&quot;&lt;h1&gt;büyük bi başlık&lt;/h1&gt;&lt;span&gt;span etiketi&lt;/span&gt;&quot;</span><span style="color: #339933;">;</span>
<span style="color: #990000;">echo</span> <span style="color: #990000;">strip_tags</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$girdi</span><span style="color: #339933;">,</span><span style="color: #0000ff;">&quot;&lt;span&gt;&quot;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;&lt;/</span>span<span style="color: #339933;">&gt;</span></pre></div></div>

<p>Yukardaki örneğin çıktısı:</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;">büyük bi başlık <span style="color: #339933;">&lt;</span>span<span style="color: #339933;">&gt;</span>span etiketi<span style="color: #339933;">&lt;/</span>span<span style="color: #339933;">&gt;</span></pre></div></div>

<p>htmlentities() işlevi tüm html karakterlerini html entitilerine çevirir.</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000088;">$girdi</span> <span style="color: #339933;">=</span> <span style="color: #0000ff;">&quot;&lt;h1&gt;büyük bi başlık&lt;/h1&gt;&quot;</span><span style="color: #339933;">;</span>
<span style="color: #990000;">echo</span> <span style="color: #990000;">htmlentities</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$girdi</span><span style="color: #339933;">,</span> ENT_QUOTES<span style="color: #339933;">,</span><span style="color: #0000ff;">'UTF-8'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></div></div>

<p>yukarıdaki örneğin çıktısı:</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>h1<span style="color: #339933;">&amp;</span>gt<span style="color: #339933;">;</span>büyük bi başlık<span style="color: #339933;">&amp;</span>lt<span style="color: #339933;">;</span>h1<span style="color: #339933;">&amp;</span>gt<span style="color: #339933;">;</span></pre></div></div>

]]></content:encoded>
			<wfw:commentRss>http://www.zihni.net/php/kullanici-girdilerini-filtrelenmesi/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
	</channel>
</rss>

