<?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 Happy Pessimist &#187; entwicklung</title>
	<atom:link href="http://www.the-happy-pessimist.de/kategorie/entwicklung/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.the-happy-pessimist.de</link>
	<description>Die Welt geht den Bach herunter, aber ich werde schon irgendwie durchkommen!</description>
	<lastBuildDate>Tue, 27 Sep 2011 06:53:03 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.3.1</generator>
		<item>
		<title>this website is cracked by a &#8230; hacker</title>
		<link>http://www.the-happy-pessimist.de/2008/08/this-website-is-cracked-by-a-hacker/?utm_source=rss&#038;utm_medium=rss&#038;utm_campaign=this-website-is-cracked-by-a-hacker</link>
		<comments>http://www.the-happy-pessimist.de/2008/08/this-website-is-cracked-by-a-hacker/#comments</comments>
		<pubDate>Fri, 22 Aug 2008 14:50:58 +0000</pubDate>
		<dc:creator>Ralph</dc:creator>
				<category><![CDATA[digital-live]]></category>
		<category><![CDATA[entwicklung]]></category>
		<category><![CDATA[cracked]]></category>
		<category><![CDATA[hacker]]></category>
		<category><![CDATA[website]]></category>

		<guid isPermaLink="false">http://www.the-happy-pessimist.de/?p=394</guid>
		<description><![CDATA[Systemadministration, Viren, Hacks etc. war noch nie mein Ding, aber diesmal hat jemand meinen Sportsgeist geweckt. Was war los? Ich betreue für einen Kunden eine Website. Geschrieben wurde sie von einer Hamburger Agentur, ich nehme ab und zu einige redaktionelle &#8230; <a href="http://www.the-happy-pessimist.de/2008/08/this-website-is-cracked-by-a-hacker/">Weiterlesen <span class="meta-nav">&#8594;</span></a>]]></description>
			<content:encoded><![CDATA[<p>Systemadministration, Viren, Hacks etc. war noch nie mein Ding, aber diesmal hat jemand meinen Sportsgeist geweckt. Was war los?</p>
<p>Ich betreue für einen Kunden eine Website. Geschrieben wurde sie von einer Hamburger Agentur, ich nehme ab und zu einige redaktionelle Änderungen vor, nichts großes.  Seit einiger Zeit landen jetzt immer irgendwelche PHP Dateien auf dem Server. Letzte Woche wurde die Seite dann mehrmals ganz gehackt. In schrillen Farben war dann nur noch &#8220;This side is cracked by a turkish/thai or whatever hacker&#8221; zu sehen.  Was war los? Im Accesslog fand ich dies hier:</p>
<p><a href="http://www.the-happy-pessimist.de/wp-content/uploads/2008/08/access-log1.gif"><img class="size-full wp-image-397 alignnone" title="Access Log - Hackerangriff" src="http://www.the-happy-pessimist.de/wp-content/uploads/2008/08/access-log1.gif" alt="" width="500" height="51" /></a></p>
<p>Die Seite ist zweisprachig, Deutsch und Englisch. Gesteuert wird das über den Parameter &#8216;lang&#8217; der die Werte &#8216;de&#8217; und &#8216;eng&#8217; enthalten kann (soll). Hier wird er jetzt aber mit einer URL belegt. Und diese URL wiederum zeigt auf eine Datei, die über 2000 Zeilen PHP/HTML Code enthält, zusätzlich noch arrays mit Binärdaten. Alles super strukturiert und kommentiert. </p>
<p>Aber wie geht&#8217;es jetzt weiter? In der index Datei der Website sieht es so aus:</p>
<p><code>&lt;?php if ($_REQUEST[lang] == "" OR $_REQUEST[lang] == "de") {<br />
  &lt;!-- Deutscher Teil --&gt;  }<br />
else {<br />
  &lt;!-- Englischer Teil --&gt; }?&gt;</code></p>
<p>Wenn es nicht Deutsch ist, dann kann es ja wohl nur noch Englisch sein. Dumm wenn dan im Englischen Teil das hier passiert:</p>
<p><code>include $_REQUEST[lang]."/"."$_REQUEST[seite].php";</code></p>
<p>Blöder hätte man das hier nicht programmieren können. Zuerst das fehlende</p>
<p><code>elseif ($_REQUEST[lang]=="eng") { .. }</code></p>
<p>und dann noch der direkte Benutzung des Inhalts des Parameters &#8216;lang&#8217;, in dem eben nicht &#8216;eng&#8217; steht. Jetzt ist die Oben angesprochene Datei erfolgreich eingebettet. Zur Belohnung ist auf der Website nun ein komfortabler Systemmonitor integriert. Passwörter auslesen, Berechtigungen ändern, alles möglich. Für die Datenbank steht ein ein mächtiger Browser zur Verfügung, was will man mehr.</p>
<p><a href="http://www.the-happy-pessimist.de/wp-content/uploads/2008/08/hack.png"><img class="alignnone size-full wp-image-413" title="Systemmonitor" src="http://www.the-happy-pessimist.de/wp-content/uploads/2008/08/hack.png" alt="" width="406" height="203" /></a></p>
<p>Ich habe das Loch vor etwa 10 Tagen gestopft. Seitdem ist Ruhe, abgesehen davon, dass alle 2 Minuten Requests in der oben beschriebenen Art eingehen. Bin mal gespannt, wie lange die das noch versuchen.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.the-happy-pessimist.de/2008/08/this-website-is-cracked-by-a-hacker/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>client-side database storage</title>
		<link>http://www.the-happy-pessimist.de/2008/02/client-side-database-storage/?utm_source=rss&#038;utm_medium=rss&#038;utm_campaign=client-side-database-storage</link>
		<comments>http://www.the-happy-pessimist.de/2008/02/client-side-database-storage/#comments</comments>
		<pubDate>Thu, 07 Feb 2008 12:05:00 +0000</pubDate>
		<dc:creator>Ralph</dc:creator>
				<category><![CDATA[entwicklung]]></category>
		<category><![CDATA[Web]]></category>

		<guid isPermaLink="false">http://abmxul.wordpress.com/2008/02/07/client-side-database-storage/</guid>
		<description><![CDATA[Ein extrem spannendes Thema, mit dem sich auch der kommende HTML Standard 5 befasst. Webanwendungen können so Daten in einer Datenbank auf dem Client speichern, und so auch offline sinnvoll genutzt werden. Im grunde funktioniert iTunes bereits heute so. In &#8230; <a href="http://www.the-happy-pessimist.de/2008/02/client-side-database-storage/">Weiterlesen <span class="meta-nav">&#8594;</span></a>]]></description>
			<content:encoded><![CDATA[<p>Ein extrem spannendes Thema, mit dem sich auch der kommende HTML Standard 5 befasst. Webanwendungen können so Daten in einer Datenbank auf dem Client speichern, und so  auch offline sinnvoll genutzt werden.</p>
<p>Im grunde funktioniert iTunes bereits heute so. In der Bedienung macht es keinen Unterschied, ob man online im Shop stöbert, oder offline auf seinem Bestand arbeitet.</p>
<p>Safari 3.1 erscheint in Kürze und wird dieses Feature bereits unterstützen.</p>
<p>Links: <a href="http://webkit.org/blog/126/webkit-does-html5-client-side-database-storage/">Safari 3.1</a></p>
]]></content:encoded>
			<wfw:commentRss>http://www.the-happy-pessimist.de/2008/02/client-side-database-storage/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Sätze &#8230;</title>
		<link>http://www.the-happy-pessimist.de/2007/10/satze/?utm_source=rss&#038;utm_medium=rss&#038;utm_campaign=satze</link>
		<comments>http://www.the-happy-pessimist.de/2007/10/satze/#comments</comments>
		<pubDate>Wed, 24 Oct 2007 08:40:00 +0000</pubDate>
		<dc:creator>Ralph</dc:creator>
				<category><![CDATA[entwicklung]]></category>

		<guid isPermaLink="false">http://abmxul.wordpress.com/2007/10/24/satze/</guid>
		<description><![CDATA[&#8230; die die Welt nicht braucht: The &#8220;Successfully installed&#8221; message does not mean that RMagick was successfully installed Aus einer Anweisung zur Installation eines Programmpaketes.]]></description>
			<content:encoded><![CDATA[<p>&#8230; die die Welt nicht braucht:<br />
<blockquote>The &#8220;Successfully installed&#8221; message does not mean that RMagick was successfully installed</p></blockquote>
<p>Aus einer Anweisung zur Installation eines Programmpaketes.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.the-happy-pessimist.de/2007/10/satze/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

