<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>Path Traversal on 4mN3s14 | CTF Player &amp; Student</title><link>https://john-jkar.github.io/myblog/tags/path-traversal/</link><description>Recent content in Path Traversal on 4mN3s14 | CTF Player &amp; Student</description><generator>Hugo</generator><language>en-us</language><lastBuildDate>Fri, 27 Feb 2026 00:00:00 +0000</lastBuildDate><atom:link href="https://john-jkar.github.io/myblog/tags/path-traversal/index.xml" rel="self" type="application/rss+xml"/><item><title>Local File Inclusion (LFI) - CTF Writeup</title><link>https://john-jkar.github.io/myblog/posts/lfi/</link><pubDate>Fri, 27 Feb 2026 00:00:00 +0000</pubDate><guid>https://john-jkar.github.io/myblog/posts/lfi/</guid><description>&lt;h1 id="alpaca-rangers--daily-alpacahack-write-up"&gt;Alpaca Rangers — Daily Alpacahack Write-up&lt;/h1&gt;
&lt;p&gt;&lt;strong&gt;Category:&lt;/strong&gt; Web &lt;strong&gt;Difficulty:&lt;/strong&gt; Medium &lt;strong&gt;Topic:&lt;/strong&gt; Local File Inclusion (LFI)&lt;/p&gt;
&lt;h2 id="description"&gt;Description&lt;/h2&gt;








&lt;blockquote class="blockquote-regular"&gt;
 &lt;p&gt;Hero of Justice, Alpaca Rangers!&lt;/p&gt;

&lt;/blockquote&gt;
&lt;p&gt;We&amp;rsquo;re given a PHP image viewer that loads files via a &lt;code&gt;?img=&lt;/code&gt; GET parameter.&lt;/p&gt;
&lt;h2 id="source-code-analysis"&gt;Source Code Analysis&lt;/h2&gt;
&lt;div class="highlight"&gt;&lt;pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"&gt;&lt;code class="language-php" data-lang="php"&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;$targetPath &lt;span style="color:#f92672"&gt;=&lt;/span&gt; $_GET[&lt;span style="color:#e6db74"&gt;&amp;#39;img&amp;#39;&lt;/span&gt;] &lt;span style="color:#f92672"&gt;??&lt;/span&gt; &lt;span style="color:#e6db74"&gt;&amp;#39;&amp;#39;&lt;/span&gt;;
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;&lt;span style="color:#66d9ef"&gt;if&lt;/span&gt; (&lt;span style="color:#a6e22e"&gt;str_starts_with&lt;/span&gt;($targetPath, &lt;span style="color:#e6db74"&gt;&amp;#39;/&amp;#39;&lt;/span&gt;) &lt;span style="color:#f92672"&gt;||&lt;/span&gt; &lt;span style="color:#a6e22e"&gt;str_starts_with&lt;/span&gt;($targetPath, &lt;span style="color:#e6db74"&gt;&amp;#39;\\&amp;#39;&lt;/span&gt;) &lt;span style="color:#f92672"&gt;||&lt;/span&gt; &lt;span style="color:#a6e22e"&gt;str_contains&lt;/span&gt;($targetPath, &lt;span style="color:#e6db74"&gt;&amp;#39;..&amp;#39;&lt;/span&gt;)) {
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt; $errorMessage &lt;span style="color:#f92672"&gt;=&lt;/span&gt; &lt;span style="color:#e6db74"&gt;&amp;#39;Invalid path.&amp;#39;&lt;/span&gt;;
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;} &lt;span style="color:#66d9ef"&gt;else&lt;/span&gt; {
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt; $contents &lt;span style="color:#f92672"&gt;=&lt;/span&gt; &lt;span style="color:#f92672"&gt;@&lt;/span&gt;&lt;span style="color:#a6e22e"&gt;file_get_contents&lt;/span&gt;($targetPath);
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt; &lt;span style="color:#f92672"&gt;...&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt; $dataUri &lt;span style="color:#f92672"&gt;=&lt;/span&gt; &lt;span style="color:#e6db74"&gt;&amp;#39;data:&amp;#39;&lt;/span&gt; &lt;span style="color:#f92672"&gt;.&lt;/span&gt; $mimeType &lt;span style="color:#f92672"&gt;.&lt;/span&gt; &lt;span style="color:#e6db74"&gt;&amp;#39;;base64,&amp;#39;&lt;/span&gt; &lt;span style="color:#f92672"&gt;.&lt;/span&gt; &lt;span style="color:#a6e22e"&gt;base64_encode&lt;/span&gt;($contents);
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;}
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;The app tries to block path traversal by rejecting anything that:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;Starts with &lt;code&gt;/&lt;/code&gt; or &lt;code&gt;\&lt;/code&gt;&lt;/li&gt;
&lt;li&gt;Contains &lt;code&gt;..&lt;/code&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;However, it passes the raw user input directly into &lt;code&gt;file_get_contents()&lt;/code&gt; — which in PHP supports &lt;strong&gt;stream wrappers&lt;/strong&gt; like &lt;code&gt;php://&lt;/code&gt;, &lt;code&gt;file://&lt;/code&gt;, &lt;code&gt;http://&lt;/code&gt;, etc.&lt;/p&gt;</description></item></channel></rss>