<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:content="http://purl.org/rss/1.0/modules/content/">
  <channel>
    <title>Web on SYM01</title>
    <link>https://sym01.com/categories/web/</link>
    <description>Recent content in Web on SYM01</description>
    <generator>Hugo</generator>
    <language>zh-CN</language>
    <lastBuildDate>Mon, 17 Jun 2024 21:31:33 +0800</lastBuildDate>
    <atom:link href="https://sym01.com/categories/web/index.xml" rel="self" type="application/rss+xml" />
    <item>
      <title>再谈 IP 伪造</title>
      <link>https://sym01.com/posts/2023/ip-forgery/</link>
      <pubDate>Mon, 17 Jun 2024 21:31:33 +0800</pubDate>
      <guid>https://sym01.com/posts/2023/ip-forgery/</guid>
      <description>&lt;h1 id=&#34;0x00-前言&#34;&gt;0x00 前言&lt;/h1&gt;
&lt;p&gt;本篇文章最早由笔者发布在&lt;a href=&#34;https://mp.weixin.qq.com/s/AvYuqTYDuk8jdSDfferMBQ&#34;&gt;漕河泾小黑屋公众号&lt;/a&gt;上。然而，公众号始终不利于分享，故重新发表于博客上。&lt;/p&gt;
&lt;p&gt;本篇文章主要介绍几种常见的伪造来源 IP 的方式。&lt;/p&gt;
&lt;h1 id=&#34;0x01-方式1-x-forwarded-for&#34;&gt;0x01 方式1: X-Forwarded-For&lt;/h1&gt;
&lt;p&gt;这个是最为认知的 IP 伪造方法，早年的 CTF 题目也经常涉及，然而现在知道的人太多， CTF 都不屑于出这类题目。 X-Forwarded-For 诞生的原因比较简单粗暴。 对于一个非常简单的网络模型， 一个网络请求通常只有两方，即请求方与被请求方，如下所示。这样的网络模型下， Web Server 是可以拿到 User 的真实 IP 地址的，即使拿到的可能是路由器的地址。&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;&#34;&gt;&lt;code class=&#34;language-txt&#34; data-lang=&#34;txt&#34;&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;User --&amp;gt; Web Server
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;但是上了规模的网站，其网络模型不会这么简单，它可能长这样：&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;&#34;&gt;&lt;code class=&#34;language-txt&#34; data-lang=&#34;txt&#34;&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;User --&amp;gt; CDN --&amp;gt; Web Server
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;在这种场景下， CDN 依旧可以拿到 User 的真实 IP 地址，然而 Web Server 却无法直接拿到。 为了解决这个问题， 有人提出了 X-Forwarded-For， 它作为 HTTP Header 传递给后端的 Web Server，其格式如下：&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;&#34;&gt;&lt;code class=&#34;language-yaml&#34; data-lang=&#34;yaml&#34;&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;X-Forwarded-For&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;1.0.0.1&lt;/span&gt;, &lt;span style=&#34;color:#ae81ff&#34;&gt;2.0.0.2&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;细心的朋友可能会发现， 我是不是可以直接将 1.0.0.1 改成任意 IP 地址，然后直接将请求发送给 Web Server？没错，这就是非常简单的 X-Forwarded-For IP 伪造攻击。一般这类问题的解决思路是，校验 4 层协议的来源 IP，判断是否为可信 IP，比如是否为 CDN 的 IP。如果可信，才会尝试解析 X-Fowarded-For Header。&lt;/p&gt;</description>
    </item>
  </channel>
</rss>
